Oliver Kowalke
a847baa932
link/unlink of context protected by spinlock
2015-09-28 19:58:22 +02:00
Oliver Kowalke
eb7c4249d5
rename managed_is_linked() -> worker_is_linked()
2015-09-28 19:35:59 +02:00
Oliver Kowalke
f0cd02e489
remove noexcept from fiber::detach()
2015-09-27 20:40:36 +02:00
Oliver Kowalke
73b03c1d67
use std::allocator_arg for execution_context ctor
2015-09-27 16:09:11 +02:00
Oliver Kowalke
fc404c58eb
unwind at shutdown
...
- scheduler holds a list of managed worker-fibers
- ~scheduler() requests stack unwinding for fibers not yet terminated
2015-09-24 17:35:40 +02:00
Oliver Kowalke
7668f86c26
more comments in scheduler.cpp
2015-09-23 17:44:50 +02:00
Oliver Kowalke
d3076f930b
some enhancements for scheduler
2015-09-23 17:44:35 +02:00
Oliver Kowalke
e38dc9b139
renaming of scheduler member functions
2015-09-22 19:30:29 +02:00
Oliver Kowalke
b43f288469
support for futures added
2015-09-22 19:17:08 +02:00
Oliver Kowalke
1b274d9b73
support for fiber-specific storage
2015-09-22 19:10:09 +02:00
Oliver Kowalke
38aa1f4366
support of detaching fibers added
2015-09-22 19:05:57 +02:00
Oliver Kowalke
128b534058
fix context
2015-09-21 20:34:41 +02:00
Oliver Kowalke
38457260bc
remoce noexcept specifier from context::join()
2015-09-21 20:34:09 +02:00
Oliver Kowalke
1ad58fbba1
add interruption
2015-09-21 20:18:53 +02:00
Oliver Kowalke
2e0d09b3c7
fix comparation of address and nullptr
2015-09-21 20:14:07 +02:00
Oliver Kowalke
eec3d34fb0
remote ready-queue uses differrent hook than local ready-queue
2015-09-20 22:06:59 +02:00
Oliver Kowalke
22a1f1257d
some source code formating
2015-09-20 15:38:43 +02:00
Oliver Kowalke
bba963c64c
class barrier added
2015-09-20 15:38:32 +02:00
Oliver Kowalke
a856a96369
class condtion added
2015-09-20 11:33:59 +02:00
Oliver Kowalke
558012bdcf
rewording of comments in scheduler implementation
2015-09-20 11:28:11 +02:00
Oliver Kowalke
b3660a3432
reorder member variables of context
...
- member hooks must be destroyed before execution_context
- otherwise an segementation fault is caused
- destruction of execution_context deallocates stack on which
the member variables of context are allocated
2015-09-20 11:25:32 +02:00
Oliver Kowalke
c8a1c4e4df
class recursive_timed_mutex added
2015-09-19 18:14:17 +02:00
Oliver Kowalke
6b01f060b7
class timed_mutex added
2015-09-19 18:03:41 +02:00
Oliver Kowalke
1797badafc
fix memory ordering for release-op (spinlock/mutex/recursive_mutex)
2015-09-19 17:38:10 +02:00
Oliver Kowalke
e6ddbe10a1
class recursive_mutex added
2015-09-19 17:27:45 +02:00
Oliver Kowalke
44d4ce82e0
use atomic< context * > as owner type
2015-09-19 17:26:33 +02:00
Oliver Kowalke
3f5e076f3a
class mutex added
2015-09-19 17:01:20 +02:00
Oliver Kowalke
943e21e69b
add support for signaling a context as ready
2015-09-19 16:19:02 +02:00
Oliver Kowalke
59946d4426
add noexcept keyword to scheduler::wait_until() and context::wait_until()
2015-09-19 16:18:36 +02:00
Oliver Kowalke
4e1e9fc240
reminder/comment in scheduler
2015-09-19 16:14:06 +02:00
Oliver Kowalke
a89f4a5979
protect context' wait-queue for concurrent access
...
- protect wait-queue as well termiantion flag
2015-09-19 09:32:14 +02:00
Oliver Kowalke
bbf41e95f3
add spinlock used to protect forr concurrent access (threads)
...
- calls std::this_thread::yield()
2015-09-19 09:31:22 +02:00
Oliver Kowalke
6da902ff09
support sleep_for()/sleep_until()
2015-09-19 08:59:53 +02:00
Oliver Kowalke
8a9c9916c7
support this_fiber::yield()
2015-09-18 17:48:57 +02:00
Oliver Kowalke
bf0ea3749b
add TODO comments
2015-09-18 17:32:19 +02:00
Oliver Kowalke
7a794647ae
replace context::terminated_is_linked() by context::is_terminated()
...
- context::terminated_is_linked() might be missleading because this
state is transient
- if the context is pushed to the terminated-queue,
context::terminated_is_linked() returns true, if the context is
removed from terminated-queue context::terminated_is_linked() returns
false
- new flag flag_terminated intoduced
- flag_terminated will be set in context::set_terminated_(), which will
be called for worker context' in the lambda
2015-09-16 22:17:01 +02:00
Oliver Kowalke
00ae711cd7
join only non-terminated fibers
...
- context::join() adds active-context to wait-queue only
if joined context is not terminated
- we can not use terminated_is_linked() because the context
might already be removed from scheudler's termianted-queue
2015-09-16 22:11:11 +02:00
Oliver Kowalke
70f4d9eeff
rename variable active-context scheduler
2015-09-16 22:10:23 +02:00
Oliver Kowalke
06e3037cc0
add comments ini scheduler
2015-09-16 21:17:42 +02:00
Oliver Kowalke
dd0e1d1893
add autoreset_event for waling up dispatcher context
...
- dispatcher waits on autoreset_event if ready-queue is empty
- autoreset_event is set if a ready context is pushed to the
ready-queue
2015-09-16 21:07:26 +02:00
Oliver Kowalke
a8e90aedb8
add joining a fiber
2015-09-16 20:51:26 +02:00
Oliver Kowalke
ddc5af0a36
run dispatcher context at scheduler destruction
2015-09-16 19:20:47 +02:00
Oliver Kowalke
6d43540a29
cleanup
2015-09-15 19:15:00 +02:00
Oliver Kowalke
73b3843696
test for ready-/runnabl-queue if transfered from remote_ready_queue
2015-09-13 16:35:54 +02:00
Oliver Kowalke
8c4dda107c
support signaling a fiber from another thread
...
- for this first version lockfree::queue<> is used
- maybe Dimitry Byukov's mpsc intrusive queue is better suited
2015-09-13 09:20:35 +02:00
Oliver Kowalke
f3b376224c
comments fxed + break loop of sleeping fibers
2015-09-11 21:35:39 +02:00
Oliver Kowalke
f14be69223
remove scheduler::wait:interval_ + fixups of comments
2015-09-11 21:03:09 +02:00
Oliver Kowalke
693c53d034
fix sleep_queue: cmp-op + use set<>::insert()
2015-09-11 20:45:54 +02:00
Oliver Kowalke
51d08226a4
if not fibers in queues - suspend till signaled or timeout
...
- if no fibers are ready to run suspend the thread and wait till
* signaled by scheduler::signal() for new fiber (ready to run)
* time_point of a sleeping fiber has reached
2015-09-11 20:45:54 +02:00
Oliver Kowalke
abd1ff524c
fixes for signaling interruption and wait
2015-09-11 18:42:16 +02:00