type task
= Hardcaml__.Import.unit -> Hardcaml__.Import.unit
val create : in_ports:Port_list.t -> out_ports_before_clock_edge:Port_list.t -> out_ports_after_clock_edge:Port_list.t -> internal_ports:Port_list.t -> reset:task -> cycle_check:task -> cycle_comb0:task -> cycle_seq:task -> cycle_comb1:task -> lookup_signal:(Signal.Uid.t -> Bits.t Hardcaml__.Import.ref) -> lookup_reg:(Signal.Uid.t -> Bits.t Hardcaml__.Import.ref) -> t_port_list
module Step : sig ... end
val modify : ('i, 'o) t -> (Side.t * Step.t * task) Hardcaml__.Import.list -> ('i, 'o) t
val coerce : (Port_list.t, Port_list.t) t -> to_input:(Port_list.t -> 'i) -> to_output:(Port_list.t -> 'o) -> ('i, 'o) t