diff options
author | Pixel <pixel@nobis-crew.org> | 2012-04-08 16:33:53 -0700 |
---|---|---|
committer | Pixel <pixel@nobis-crew.org> | 2012-04-08 16:33:53 -0700 |
commit | 1548da7eb85e8199e49c0a4e7e3c53fb2184177e (patch) | |
tree | 03ab0059404f3fd0b985853a166be1293b071ce9 /src/TaskMan.cc | |
parent | 0fb5f42ca43f11bd37ddc89aa7c7b098d764b28c (diff) |
Few more quirks into the stackless mode; we don't want to allocate stacks nor create any co-routine (or fiber) if we're stackless.
Diffstat (limited to 'src/TaskMan.cc')
-rw-r--r-- | src/TaskMan.cc | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/TaskMan.cc b/src/TaskMan.cc index 048b27a..33d07d0 100644 --- a/src/TaskMan.cc +++ b/src/TaskMan.cc @@ -192,10 +192,11 @@ Balau::TaskMan::~TaskMan() { } void * Balau::TaskMan::getStack() { + if (!Task::needsStacks()) + return NULL; void * r = NULL; if (m_nStacks == 0) { - if (Task::needsStacks()) - r = malloc(Task::stackSize()); + r = malloc(Task::stackSize()); } else { r = m_stacks.front(); m_stacks.pop(); @@ -298,7 +299,7 @@ int Balau::TaskMan::mainLoop() { Printer::elog(E_TASK, "TaskMan at %p popped task %p...", this, t); IAssert(m_tasks.find(t) == m_tasks.end(), "TaskMan got task %p twice... ?", t); ev_now_update(m_loop); - t->setup(this, getStack()); + t->setup(this, t->isStackless() ? NULL : getStack()); m_tasks.insert(t); starting.insert(t); } |