| Copyright | (C) 2015 Edward Kmett and Ted Cooper |
|---|---|
| License | BSD-style (see the file LICENSE) |
| Maintainer | Edward Kmett <ekmett@gmail.com> Ted Cooper <anthezium@gmail.com> |
| Stability | experimental |
| Portability | non-portable |
| Safe Haskell | Trustworthy |
| Language | Haskell2010 |
Control.Concurrent.RCU.QSBR
Contents
Description
Quiescent-State-Based Reclamation
- data SRef s a
- data RCU s a
- runRCU :: (forall s. RCU s a) -> IO a
- class Monad m => MonadNew s m | m -> s where
- class MonadNew s m => MonadReading s m | m -> s where
- class MonadReading s m => MonadWriting s m | m -> s where
- class (MonadReading s (Reading m), MonadWriting s (Writing m), MonadNew s m) => MonadRCU s m | m -> s where
- data ReadingRCU s a
- data WritingRCU s a
- data RCUThread s a
Documentation
Shared references
Instances
| MonadRCU (SRef s) (RCU s) Source # | |
| MonadWriting (SRef s) (WritingRCU s) Source # | |
| MonadReading (SRef s) (WritingRCU s) Source # | |
| MonadReading (SRef s) (ReadingRCU s) Source # | |
| MonadNew (SRef s) (RCU s) Source # | |
| MonadNew (SRef s) (WritingRCU s) Source # | |
| MonadNew (SRef s) (ReadingRCU s) Source # | |
| Eq (SRef s a) Source # | |
class Monad m => MonadNew s m | m -> s where Source #
Methods
newSRef :: a -> m (s a) Source #
Build a new shared reference
newSRef :: (m ~ t n, MonadTrans t, MonadNew s n) => a -> m (s a) Source #
Build a new shared reference
Instances
| MonadNew s m => MonadNew s (MaybeT m) Source # | |
| MonadNew s m => MonadNew s (IdentityT * m) Source # | |
| MonadNew s m => MonadNew s (ExceptT e m) Source # | |
| MonadNew s' m => MonadNew s' (StateT s m) Source # | |
| MonadNew s' m => MonadNew s' (StateT s m) Source # | |
| (MonadNew s m, Monoid w) => MonadNew s (WriterT w m) Source # | |
| (MonadNew s m, Monoid w) => MonadNew s (WriterT w m) Source # | |
| MonadNew s m => MonadNew s (ReaderT * e m) Source # | |
| (MonadNew s' m, Monoid w) => MonadNew s' (RWST r w s m) Source # | |
| (MonadNew s' m, Monoid w) => MonadNew s' (RWST r w s m) Source # | |
| MonadNew (SRef s) (RCU s) Source # | |
| MonadNew (SRef s) (WritingRCU s) Source # | |
| MonadNew (SRef s) (ReadingRCU s) Source # | |
| MonadNew (SRef s) (RCU s) Source # | |
| MonadNew (SRef s) (WritingRCU s) Source # | |
| MonadNew (SRef s) (ReadingRCU s) Source # | |
class MonadNew s m => MonadReading s m | m -> s where Source #
This is a read-side critical section
Methods
readSRef :: s a -> m a Source #
Read a shared reference.
readSRef :: (m ~ t n, MonadTrans t, MonadReading s n) => s a -> m a Source #
Read a shared reference.
Instances
| MonadReading s m => MonadReading s (MaybeT m) Source # | |
| MonadReading s m => MonadReading s (IdentityT * m) Source # | |
| MonadReading s m => MonadReading s (ExceptT e m) Source # | |
| MonadReading s' m => MonadReading s' (StateT s m) Source # | |
| MonadReading s' m => MonadReading s' (StateT s m) Source # | |
| (MonadReading s m, Monoid w) => MonadReading s (WriterT w m) Source # | |
| (MonadReading s m, Monoid w) => MonadReading s (WriterT w m) Source # | |
| MonadReading s m => MonadReading s (ReaderT * e m) Source # | |
| (MonadReading s' m, Monoid w) => MonadReading s' (RWST r w s m) Source # | |
| (MonadReading s' m, Monoid w) => MonadReading s' (RWST r w s m) Source # | |
| MonadReading (SRef s) (WritingRCU s) Source # | |
| MonadReading (SRef s) (ReadingRCU s) Source # | |
| MonadReading (SRef s) (WritingRCU s) Source # | |
| MonadReading (SRef s) (ReadingRCU s) Source # | |
class MonadReading s m => MonadWriting s m | m -> s where Source #
This is a write-side critical section
Methods
writeSRef :: s a -> a -> m () Source #
Write to a shared reference.
writeSRef :: (m ~ t n, MonadTrans t, MonadWriting s n) => s a -> a -> m () Source #
Write to a shared reference.
synchronize :: m () Source #
Synchronize with other writers.
No other writer can straddle this time bound. It will either see writes from before, or writes after, but never some of both!
synchronize :: (m ~ t n, MonadTrans t, MonadWriting s n) => m () Source #
Synchronize with other writers.
No other writer can straddle this time bound. It will either see writes from before, or writes after, but never some of both!
Instances
| MonadWriting s m => MonadWriting s (MaybeT m) Source # | |
| MonadWriting s m => MonadWriting s (ExceptT e m) Source # | |
| MonadWriting s m => MonadWriting s (IdentityT * m) Source # | |
| MonadWriting s' m => MonadWriting s' (StateT s m) Source # | |
| MonadWriting s' m => MonadWriting s' (StateT s m) Source # | |
| (MonadWriting s m, Monoid w) => MonadWriting s (WriterT w m) Source # | |
| (MonadWriting s m, Monoid w) => MonadWriting s (WriterT w m) Source # | |
| MonadWriting s m => MonadWriting s (ReaderT * e m) Source # | |
| (MonadWriting s' m, Monoid w) => MonadWriting s' (RWST r w s m) Source # | |
| (MonadWriting s' m, Monoid w) => MonadWriting s' (RWST r w s m) Source # | |
| MonadWriting (SRef s) (WritingRCU s) Source # | |
| MonadWriting (SRef s) (WritingRCU s) Source # | |
class (MonadReading s (Reading m), MonadWriting s (Writing m), MonadNew s m) => MonadRCU s m | m -> s where Source #
This is the executor service that can fork, join and execute critical sections.
Associated Types
type Reading m :: * -> * Source #
A read-side critical section
type Writing m :: * -> * Source #
A write-side critical section
type Thread m :: * -> * Source #
Threads we can fork and join
Methods
forking :: m a -> m (Thread m a) Source #
Fork a thread
joining :: Thread m a -> m a Source #
Join a thread
reading :: Reading m a -> m a Source #
Run a read-side critical section
writing :: Writing m a -> m a Source #
Run a write-side critical section
Instances
| MonadRCU s m => MonadRCU s (MaybeT m) Source # | |
| (MonadRCU s m, Monoid e) => MonadRCU s (WriterT e m) Source # | |
| (MonadRCU s m, Monoid e) => MonadRCU s (WriterT e m) Source # | |
| MonadRCU s m => MonadRCU s (ExceptT e m) Source # | |
| MonadRCU s m => MonadRCU s (IdentityT * m) Source # | |
| MonadRCU s m => MonadRCU s (ReaderT * e m) Source # | |
| MonadRCU (SRef s) (RCU s) Source # | |
| MonadRCU (SRef s) (RCU s) Source # | |
Implementation Details
data ReadingRCU s a Source #
This is the basic read-side critical section for an RCU computation
Instances
| Monad (ReadingRCU s) Source # | |
| Functor (ReadingRCU s) Source # | |
| Applicative (ReadingRCU s) Source # | |
| Alternative (ReadingRCU s) Source # | |
| MonadPlus (ReadingRCU s) Source # | |
| MonadReading (SRef s) (ReadingRCU s) Source # | |
| MonadNew (SRef s) (ReadingRCU s) Source # | |
data WritingRCU s a Source #
This is the basic write-side critical section for an RCU computation
Instances
| Monad (WritingRCU s) Source # | |
| Functor (WritingRCU s) Source # | |
| Applicative (WritingRCU s) Source # | |
| Alternative (WritingRCU s) Source # | |
| MonadPlus (WritingRCU s) Source # | |
| MonadWriting (SRef s) (WritingRCU s) Source # | |
| MonadReading (SRef s) (WritingRCU s) Source # | |
| MonadNew (SRef s) (WritingRCU s) Source # | |