Skip to content
Snippets Groups Projects
Commit ad753436 authored by Florian Schmaus's avatar Florian Schmaus
Browse files

[AbstractWorkStealingScheduler] Move pushBottom() in module

Also rename 'res' to 'pushed' and only notify about new work if there
was work pushed.
parent ca5bcf5c
No related branches found
No related tags found
No related merge requests found
...@@ -284,3 +284,11 @@ auto AbstractWorkStealingScheduler::nextFiberResultFromMpscQueueOrWorkStealing() ...@@ -284,3 +284,11 @@ auto AbstractWorkStealingScheduler::nextFiberResultFromMpscQueueOrWorkStealing()
return nextFiberResultViaWorkStealing(); return nextFiberResultViaWorkStealing();
} }
auto AbstractWorkStealingScheduler::pushBottom(AbstractFiber& fiber) -> bool {
auto pushed = queue.pushBottom(&fiber);
if (pushed) [[likely]] {
onNewWork<CallerEnvironment::EMPER>(emper::FiberHint{emper::FiberSource::local});
}
return pushed;
}
...@@ -5,10 +5,7 @@ ...@@ -5,10 +5,7 @@
#include <cstddef> // for size_t #include <cstddef> // for size_t
#include <optional> #include <optional>
#include "CallerEnvironment.hpp"
#include "Fiber.hpp" #include "Fiber.hpp"
#include "FiberHint.hpp"
#include "FiberSource.hpp"
#include "Scheduler.hpp" #include "Scheduler.hpp"
#include "emper-common.h" #include "emper-common.h"
#include "lib/adt/MpscQueue.hpp" #include "lib/adt/MpscQueue.hpp"
...@@ -48,11 +45,7 @@ class AbstractWorkStealingScheduler : public Scheduler { ...@@ -48,11 +45,7 @@ class AbstractWorkStealingScheduler : public Scheduler {
auto nextFiberResultViaWorkStealing() -> std::optional<NextFiberResult>; auto nextFiberResultViaWorkStealing() -> std::optional<NextFiberResult>;
auto nextFiberResultFromMpscQueueOrWorkStealing() -> std::optional<NextFiberResult>; auto nextFiberResultFromMpscQueueOrWorkStealing() -> std::optional<NextFiberResult>;
auto pushBottom(AbstractFiber& fiber) -> bool override { auto pushBottom(AbstractFiber& fiber) -> bool override;
bool res = queue.pushBottom(&fiber);
onNewWork<CallerEnvironment::EMPER>(emper::FiberHint{emper::FiberSource::local});
return res;
}
auto popBottom() -> AbstractFiber* override { auto popBottom() -> AbstractFiber* override {
AbstractFiber* fiber; AbstractFiber* fiber;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment