Improve dpor docs

This commit is contained in:
Michael Walker 2016-03-30 05:57:23 +01:00
parent 7d02708f92
commit 39658767df
3 changed files with 23 additions and 22 deletions

View File

@ -31,15 +31,15 @@ module Test.DPOR
, BacktrackStep(..) , BacktrackStep(..)
, backtrackAt , backtrackAt
-- * Bounds -- ** Bounding
, BoundFunc , BoundFunc
, (&+&) , (&+&)
, trueBound , trueBound
-- ** Pre-emption bounding -- *** Preemption
-- | DPOR with pre-emption bounding. This adds conservative -- | DPOR with preemption bounding. This adds conservative
-- backtracking points at the prior context switch whenever a -- backtracking points at the prior context switch whenever a
-- non-conervative backtracking point is added, as alternative -- non-conervative backtracking point is added, as alternative
-- decisions can influence the reachability of different states. -- decisions can influence the reachability of different states.
@ -52,7 +52,7 @@ module Test.DPOR
, preempBacktrack , preempBacktrack
, preempCount , preempCount
-- ** Fair bounding -- *** Fair
-- | DPOR using fair bounding. This bounds the maximum difference -- | DPOR using fair bounding. This bounds the maximum difference
-- between the number of yield operations different threads have -- between the number of yield operations different threads have
@ -67,7 +67,7 @@ module Test.DPOR
, yieldCount , yieldCount
, maxYieldCountDiff , maxYieldCountDiff
-- ** Length Bounding -- *** Length
-- | BPOR using length bounding. This bounds the maximum length (in -- | BPOR using length bounding. This bounds the maximum length (in
-- terms of primitive actions) of an execution. -- terms of primitive actions) of an execution.
@ -111,10 +111,10 @@ import Test.DPOR.Schedule
-- preserved between different schedules, and built up from scratch -- preserved between different schedules, and built up from scratch
-- each time. -- each time.
-- --
-- The three dependency functions must be consistent: if we can -- The dependency functions must be consistent: if we can convert
-- convert between @action@ and @lookahead@, and supply some sensible -- between @action@ and @lookahead@, and supply some sensible default
-- default state, then (1) == true implies that (2) is. In practice, -- state, then (1) == true implies that (2) is. In practice, (1) is
-- (1) is the most specific and (2) will be more pessimistic (due to, -- the most specific and (2) will be more pessimistic (due to,
-- typically, less information being available when merely looking -- typically, less information being available when merely looking
-- ahead). -- ahead).
dpor :: ( Ord tid dpor :: ( Ord tid
@ -204,10 +204,8 @@ dpor didYield
addBacktracks = incorporateBacktrackSteps inBound addBacktracks = incorporateBacktrackSteps inBound
-- | Add a backtracking point. If the thread isn't runnable, add all -- | Add a backtracking point. If the thread isn't runnable, add all
-- runnable threads. -- runnable threads. If the backtracking point is already present,
-- -- don't re-add it UNLESS this would make it conservative.
-- If the backtracking point is already present, don't re-add it
-- UNLESS this is a conservative backtracking point.
backtrackAt :: Ord tid backtrackAt :: Ord tid
=> (BacktrackStep tid action lookahead s -> Bool) => (BacktrackStep tid action lookahead s -> Bool)
-- ^ If this returns @True@, backtrack to all runnable threads, -- ^ If this returns @True@, backtrack to all runnable threads,
@ -255,19 +253,19 @@ trueBound :: BoundFunc tid action lookahead
trueBound _ _ = True trueBound _ _ = True
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- Pre-emption bounding -- Preemption bounding
newtype PreemptionBound = PreemptionBound Int newtype PreemptionBound = PreemptionBound Int
deriving (NFData, Enum, Eq, Ord, Num, Real, Integral, Read, Show) deriving (NFData, Enum, Eq, Ord, Num, Real, Integral, Read, Show)
-- | A sensible default pre-emption bound: 2. -- | A sensible default preemption bound: 2.
-- --
-- See /Concurrency Testing Using Schedule Bounding: an Empirical -- See /Concurrency Testing Using Schedule Bounding: an Empirical Study/,
-- Study/, P. Thomson, A. F. Donaldson, A. Betts for justification. -- P. Thomson, A. F. Donaldson, A. Betts for justification.
defaultPreemptionBound :: PreemptionBound defaultPreemptionBound :: PreemptionBound
defaultPreemptionBound = 2 defaultPreemptionBound = 2
-- | Pre-emption bound function -- | Preemption bound function
preempBound :: (action -> Bool) preempBound :: (action -> Bool)
-- ^ Determine if a thread yielded. -- ^ Determine if a thread yielded.
-> PreemptionBound -> PreemptionBound
@ -281,7 +279,7 @@ preempBound didYield (PreemptionBound pb) ts dl =
-- of the artificial dependency imposed by the bound. -- of the artificial dependency imposed by the bound.
preempBacktrack :: Ord tid preempBacktrack :: Ord tid
=> (action -> Bool) => (action -> Bool)
-- ^ If this is true of the action at a pre-emptive context switch, -- ^ If this is true of the action at a preemptive context switch,
-- do NOT use that point for the conservative point, try earlier. -- do NOT use that point for the conservative point, try earlier.
-> BacktrackFunc tid action lookahead s -> BacktrackFunc tid action lookahead s
preempBacktrack ignore bs i tid = preempBacktrack ignore bs i tid =
@ -304,7 +302,7 @@ preempBacktrack ignore bs i tid =
-- Add a backtracking point. -- Add a backtracking point.
backtrack = backtrackAt $ const False backtrack = backtrackAt $ const False
-- Count the number of pre-emptions in a schedule prefix. -- | Count the number of preemptions in a schedule prefix.
preempCount :: (action -> Bool) preempCount :: (action -> Bool)
-- ^ Determine if a thread yielded. -- ^ Determine if a thread yielded.
-> [(Decision tid, action)] -> [(Decision tid, action)]

View File

@ -369,6 +369,10 @@ type BoundFunc tid action lookahead = [(Decision tid, action)] -> (Decision tid,
-- effects of the bounding function. For example, under pre-emption -- effects of the bounding function. For example, under pre-emption
-- bounding a conservative backtracking point is added at the prior -- bounding a conservative backtracking point is added at the prior
-- context switch. -- context switch.
--
-- In general, a backtracking function should identify one or more
-- backtracking points, and then use @backtrackAt@ to do the actual
-- work.
type BacktrackFunc tid action lookahead s = [BacktrackStep tid action lookahead s] -> Int -> tid -> [BacktrackStep tid action lookahead s] type BacktrackFunc tid action lookahead s = [BacktrackStep tid action lookahead s] -> Int -> tid -> [BacktrackStep tid action lookahead s]
-- | DPOR scheduler: takes a list of decisions, and maintains a trace -- | DPOR scheduler: takes a list of decisions, and maintains a trace

View File

@ -38,8 +38,7 @@ import System.Random (RandomGen, randomR)
-- 4. The state. -- 4. The state.
-- --
-- It returns a thread to execute, or @Nothing@ if execution should -- It returns a thread to execute, or @Nothing@ if execution should
-- abort here, and also a new state. Execution may be aborted if all -- abort here, and also a new state.
-- of the runnable threads are in the sleep set.
type Scheduler tid action lookahead s type Scheduler tid action lookahead s
= [(Decision tid, action)] = [(Decision tid, action)]
-> Maybe (tid, action) -> Maybe (tid, action)