Hardcaml_step_testbench.Makemodule I : Hardcaml.Interface.Smodule O : Hardcaml.Interface.Smodule Simulator : sig ... endA simulator for the design being tested.
module I_data : Digital_components.Data.S with type t = Hardcaml.Bits.t I.tmodule O_data : sig ... endtype 'a t = ( 'a, O_data.t, I_data.t ) Digital_components.Step_monad.tA testbench takes the circuit's output as its input and produces its output as input for the circuit. An 'a t describes a testbench computation that takes zero or more steps and produces a value of type 'a.
include Hardcaml_step_testbench__.Import.Monad.S with type 'a t := 'a tmodule Monad_infix : sig ... endval return : 'a -> 'a tmodule Let_syntax : sig ... endcycle i_data ~num_cycles waits for num_cycles cycles of the simulator to run, applying i_data to the simulator input ports, and returns the output computed in the final cycle. cycle raises if num_cycles < 1.
val for_ :
Hardcaml_step_testbench__Import.Int.t ->
Hardcaml_step_testbench__Import.Int.t ->
( Hardcaml_step_testbench__Import.Int.t ->
Hardcaml_step_testbench__Import.Unit.t t ) ->
Hardcaml_step_testbench__Import.Unit.t tfor_ i j f does f i, f (i+1), ... f j in sequence. If j < i, then for_ i
j immediately returns unit.
val delay :
I_data.t ->
num_cycles:Hardcaml_step_testbench__Import.Int.t ->
Hardcaml_step_testbench__Import.Unit.t tdelay inputs ~num_cycles applies inputs for num_cycles clock cycles and then returns unit. delay raises if num_cycles < 0.
type ('a, 'b) finished_event =
( 'a, 'b ) Digital_components.Step_monad.Component_finished.t
Digital_components.Step_monad.Event.tval spawn : ( O_data.t -> 'a t ) -> ( 'a, I_data.t ) finished_event tLaunch a new task within the current simulation step.
merge_inputs ~parent ~child merges the child inputs into the parent. If a child input is empty, the parent's value is used.
val spawn_io :
inputs:( parent:'i -> child:I_data.t -> 'i ) ->
outputs:( 'o -> Hardcaml.Bits.t O.t ) ->
( O_data.t -> 'a t ) ->
( ( 'a, I_data.t ) finished_event, 'o Before_and_after_edge.t, 'i )
Digital_components.Step_monad.tLaunch a task from a testbench with a cycle funtion taking 'i to 'o. The inputs and outputs arguments should construct I_data.t and O_data.t from the types of the child testbench.
val wait_for : ( 'a, 'b ) finished_event -> 'a tWait for the given event to occur, and extract its return value.
val wait_for_with_timeout :
( 'a, 'b ) finished_event ->
timeout_in_cycles:Hardcaml_step_testbench__Import.Int.t ->
'a Hardcaml_step_testbench__Import.Option.t tLike wait_for except it stops waiting after timeout_in_cycles and returns None. Note that the spawned task continues to execute.
val input_hold : Hardcaml.Bits.t I.tCall run ~input_default:input_hold to hold inputs their previous value if they are unset by tasks in the testbench.
val input_zero : Hardcaml.Bits.t I.tCall run ~input_default:input_zero to set inputs to zero if unset by tasks in the testbench.
val run_with_timeout :
?input_default:Hardcaml.Bits.t I.t ->
?show_steps:Hardcaml_step_testbench__Import.Bool.t ->
?timeout:Hardcaml_step_testbench__Import.Int.t ->
Hardcaml_step_testbench__Import.Unit.t ->
simulator:Simulator.t ->
testbench:( O_data.t -> 'a t ) ->
'a Hardcaml_step_testbench__Import.Option.tRun the testbench until the main task finishes. The input_default argument controls what should happen if an input is unset by tasks in the testbench on any particular cycle. If a field is set to Bits.empty then the previous value should be held. Otherwise, the value provided is used as the default value for that field.
The optional timeout argument stops the simulation after the given number of steps and returns None. Otherwise it will continue until the testbech completes.
val run_until_finished :
?input_default:Hardcaml.Bits.t I.t ->
?show_steps:Hardcaml_step_testbench__Import.Bool.t ->
Hardcaml_step_testbench__Import.Unit.t ->
simulator:Simulator.t ->
testbench:( O_data.t -> 'a t ) ->
'aRun the testbench until completion.
module List : sig ... endmodule Array : sig ... end