Simulation { state: State { insns: Insns { state_layout: StateLayout { ty: TypeLayout { small_slots: StatePartLayout { len: 12, debug_data: [ SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: UInt<4>, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: Bool, }, SlotDebugData { name: "", ty: UInt<4>, }, SlotDebugData { name: "", ty: UInt<4>, }, SlotDebugData { name: "", ty: Bool, }, ], .. }, big_slots: StatePartLayout { len: 28, debug_data: [ SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.addr", ty: UInt<4>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.en", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.clk", ty: Clock, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.0", ty: UInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.1", ty: SInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.addr", ty: UInt<4>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.en", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.clk", ty: Clock, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.0", ty: UInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.1", ty: SInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.0", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.1", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.addr", ty: UInt<4>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.en", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.clk", ty: Clock, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.1", ty: SInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.addr", ty: UInt<4>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.en", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.clk", ty: Clock, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.0", ty: UInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.1", ty: SInt<8>, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.0", ty: Bool, }, SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.1", ty: Bool, }, SlotDebugData { name: ".0", ty: UInt<8>, }, SlotDebugData { name: ".1", ty: SInt<8>, }, SlotDebugData { name: ".0", ty: Bool, }, SlotDebugData { name: ".1", ty: Bool, }, ], .. }, }, memories: StatePartLayout { len: 1, debug_data: [ (), ], layout_data: [ MemoryData { array_type: Array, 1: SInt<8>}, 16>, data: [ // len = 0x10 [0x0]: 0x2301, [0x1]: 0x2301, [0x2]: 0x2301, [0x3]: 0x2301, [0x4]: 0x2301, [0x5]: 0x2301, [0x6]: 0x2301, [0x7]: 0x2301, [0x8]: 0x2301, [0x9]: 0x2301, [0xa]: 0x2301, [0xb]: 0x2301, [0xc]: 0x2301, [0xd]: 0x2301, [0xe]: 0x2301, [0xf]: 0x2301, ], }, ], .. }, }, insns: [ // at: module-XXXXXXXXXX.rs:8:1 0: Copy { dest: StatePartIndex(17), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.addr", ty: UInt<4> }, src: StatePartIndex(5), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.addr", ty: UInt<4> }, }, 1: Copy { dest: StatePartIndex(18), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.en", ty: Bool }, src: StatePartIndex(6), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.en", ty: Bool }, }, 2: Copy { dest: StatePartIndex(19), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.clk", ty: Clock }, src: StatePartIndex(7), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.clk", ty: Clock }, }, 3: Copy { dest: StatePartIndex(20), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.0", ty: UInt<8> }, src: StatePartIndex(8), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.0", ty: UInt<8> }, }, 4: Copy { dest: StatePartIndex(21), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.1", ty: SInt<8> }, src: StatePartIndex(9), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.1", ty: SInt<8> }, }, 5: Copy { dest: StatePartIndex(22), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.0", ty: Bool }, src: StatePartIndex(10), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.0", ty: Bool }, }, 6: Copy { dest: StatePartIndex(23), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.1", ty: Bool }, src: StatePartIndex(11), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.1", ty: Bool }, }, // at: module-XXXXXXXXXX.rs:6:1 7: Copy { dest: StatePartIndex(14), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.clk", ty: Clock }, src: StatePartIndex(2), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.clk", ty: Clock }, }, 8: Copy { dest: StatePartIndex(13), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.en", ty: Bool }, src: StatePartIndex(1), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.en", ty: Bool }, }, 9: Copy { dest: StatePartIndex(12), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.addr", ty: UInt<4> }, src: StatePartIndex(0), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.addr", ty: UInt<4> }, }, // at: module-XXXXXXXXXX.rs:4:1 10: CastBigToArrayIndex { dest: StatePartIndex(9), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, src: StatePartIndex(17), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.addr", ty: UInt<4> }, }, 11: IsNonZeroDestIsSmall { dest: StatePartIndex(8), // (0x0 0) SlotDebugData { name: "", ty: Bool }, src: StatePartIndex(18), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.en", ty: Bool }, }, 12: IsNonZeroDestIsSmall { dest: StatePartIndex(7), // (0x0 0) SlotDebugData { name: "", ty: Bool }, src: StatePartIndex(19), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.clk", ty: Clock }, }, 13: AndSmall { dest: StatePartIndex(6), // (0x0 0) SlotDebugData { name: "", ty: Bool }, lhs: StatePartIndex(7), // (0x0 0) SlotDebugData { name: "", ty: Bool }, rhs: StatePartIndex(5), // (0x1 1) SlotDebugData { name: "", ty: Bool }, }, 14: CastBigToArrayIndex { dest: StatePartIndex(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, src: StatePartIndex(12), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.addr", ty: UInt<4> }, }, 15: IsNonZeroDestIsSmall { dest: StatePartIndex(3), // (0x1 1) SlotDebugData { name: "", ty: Bool }, src: StatePartIndex(13), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.en", ty: Bool }, }, 16: BranchIfSmallZero { target: 20, value: StatePartIndex(3), // (0x1 1) SlotDebugData { name: "", ty: Bool }, }, 17: MemoryReadUInt { dest: StatePartIndex(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> }, memory: StatePartIndex(0), // (MemoryData { // array_type: Array, 1: SInt<8>}, 16>, // data: [ // // len = 0x10 // [0x0]: 0x4050, // [0x1]: 0xa090, // [0x2]: 0xc0b0, // [0x3]: 0x2301, // [0x4]: 0x2301, // [0x5]: 0x2301, // [0x6]: 0x2301, // [0x7]: 0x2301, // [0x8]: 0x2301, // [0x9]: 0x2301, // [0xa]: 0x2301, // [0xb]: 0x2301, // [0xc]: 0x2301, // [0xd]: 0x2301, // [0xe]: 0x2301, // [0xf]: 0x2301, // ], // }) (), addr: StatePartIndex(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, stride: 16, start: 0, width: 8, }, 18: MemoryReadSInt { dest: StatePartIndex(16), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.1", ty: SInt<8> }, memory: StatePartIndex(0), // (MemoryData { // array_type: Array, 1: SInt<8>}, 16>, // data: [ // // len = 0x10 // [0x0]: 0x4050, // [0x1]: 0xa090, // [0x2]: 0xc0b0, // [0x3]: 0x2301, // [0x4]: 0x2301, // [0x5]: 0x2301, // [0x6]: 0x2301, // [0x7]: 0x2301, // [0x8]: 0x2301, // [0x9]: 0x2301, // [0xa]: 0x2301, // [0xb]: 0x2301, // [0xc]: 0x2301, // [0xd]: 0x2301, // [0xe]: 0x2301, // [0xf]: 0x2301, // ], // }) (), addr: StatePartIndex(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, stride: 16, start: 8, width: 8, }, 19: Branch { target: 22, }, 20: Const { dest: StatePartIndex(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> }, value: 0x0, }, 21: Const { dest: StatePartIndex(16), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.1", ty: SInt<8> }, value: 0x0, }, // at: module-XXXXXXXXXX.rs:6:1 22: Copy { dest: StatePartIndex(3), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.0", ty: UInt<8> }, src: StatePartIndex(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> }, }, 23: Copy { dest: StatePartIndex(4), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.1", ty: SInt<8> }, src: StatePartIndex(16), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.1", ty: SInt<8> }, }, // at: module-XXXXXXXXXX.rs:4:1 24: IsNonZeroDestIsSmall { dest: StatePartIndex(2), // (0x0 0) SlotDebugData { name: "", ty: Bool }, src: StatePartIndex(14), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.clk", ty: Clock }, }, 25: AndSmall { dest: StatePartIndex(1), // (0x0 0) SlotDebugData { name: "", ty: Bool }, lhs: StatePartIndex(2), // (0x0 0) SlotDebugData { name: "", ty: Bool }, rhs: StatePartIndex(0), // (0x1 1) SlotDebugData { name: "", ty: Bool }, }, 26: BranchIfSmallZero { target: 27, value: StatePartIndex(1), // (0x0 0) SlotDebugData { name: "", ty: Bool }, }, 27: BranchIfSmallZero { target: 39, value: StatePartIndex(6), // (0x0 0) SlotDebugData { name: "", ty: Bool }, }, 28: CopySmall { dest: StatePartIndex(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, src: StatePartIndex(9), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, }, 29: CopySmall { dest: StatePartIndex(11), // (0x0 0) SlotDebugData { name: "", ty: Bool }, src: StatePartIndex(8), // (0x0 0) SlotDebugData { name: "", ty: Bool }, }, 30: Copy { dest: StatePartIndex(24), // (0xd0) SlotDebugData { name: ".0", ty: UInt<8> }, src: StatePartIndex(20), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.0", ty: UInt<8> }, }, 31: Copy { dest: StatePartIndex(25), // (-0x20) SlotDebugData { name: ".1", ty: SInt<8> }, src: StatePartIndex(21), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.1", ty: SInt<8> }, }, 32: Copy { dest: StatePartIndex(26), // (0x1) SlotDebugData { name: ".0", ty: Bool }, src: StatePartIndex(22), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.0", ty: Bool }, }, 33: Copy { dest: StatePartIndex(27), // (0x1) SlotDebugData { name: ".1", ty: Bool }, src: StatePartIndex(23), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.1", ty: Bool }, }, 34: BranchIfSmallZero { target: 39, value: StatePartIndex(11), // (0x0 0) SlotDebugData { name: "", ty: Bool }, }, 35: BranchIfZero { target: 37, value: StatePartIndex(26), // (0x1) SlotDebugData { name: ".0", ty: Bool }, }, 36: MemoryWriteUInt { value: StatePartIndex(24), // (0xd0) SlotDebugData { name: ".0", ty: UInt<8> }, memory: StatePartIndex(0), // (MemoryData { // array_type: Array, 1: SInt<8>}, 16>, // data: [ // // len = 0x10 // [0x0]: 0x4050, // [0x1]: 0xa090, // [0x2]: 0xc0b0, // [0x3]: 0x2301, // [0x4]: 0x2301, // [0x5]: 0x2301, // [0x6]: 0x2301, // [0x7]: 0x2301, // [0x8]: 0x2301, // [0x9]: 0x2301, // [0xa]: 0x2301, // [0xb]: 0x2301, // [0xc]: 0x2301, // [0xd]: 0x2301, // [0xe]: 0x2301, // [0xf]: 0x2301, // ], // }) (), addr: StatePartIndex(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, stride: 16, start: 0, width: 8, }, 37: BranchIfZero { target: 39, value: StatePartIndex(27), // (0x1) SlotDebugData { name: ".1", ty: Bool }, }, 38: MemoryWriteSInt { value: StatePartIndex(25), // (-0x20) SlotDebugData { name: ".1", ty: SInt<8> }, memory: StatePartIndex(0), // (MemoryData { // array_type: Array, 1: SInt<8>}, 16>, // data: [ // // len = 0x10 // [0x0]: 0x4050, // [0x1]: 0xa090, // [0x2]: 0xc0b0, // [0x3]: 0x2301, // [0x4]: 0x2301, // [0x5]: 0x2301, // [0x6]: 0x2301, // [0x7]: 0x2301, // [0x8]: 0x2301, // [0x9]: 0x2301, // [0xa]: 0x2301, // [0xb]: 0x2301, // [0xc]: 0x2301, // [0xd]: 0x2301, // [0xe]: 0x2301, // [0xf]: 0x2301, // ], // }) (), addr: StatePartIndex(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> }, stride: 16, start: 8, width: 8, }, 39: XorSmallImmediate { dest: StatePartIndex(0), // (0x1 1) SlotDebugData { name: "", ty: Bool }, lhs: StatePartIndex(2), // (0x0 0) SlotDebugData { name: "", ty: Bool }, rhs: 0x1, }, 40: XorSmallImmediate { dest: StatePartIndex(5), // (0x1 1) SlotDebugData { name: "", ty: Bool }, lhs: StatePartIndex(7), // (0x0 0) SlotDebugData { name: "", ty: Bool }, rhs: 0x1, }, // at: module-XXXXXXXXXX.rs:1:1 41: Return, ], .. }, pc: 41, memory_write_log: [], memories: StatePart { value: [ MemoryData { array_type: Array, 1: SInt<8>}, 16>, data: [ // len = 0x10 [0x0]: 0x4050, [0x1]: 0xa090, [0x2]: 0xc0b0, [0x3]: 0x2301, [0x4]: 0x2301, [0x5]: 0x2301, [0x6]: 0x2301, [0x7]: 0x2301, [0x8]: 0x2301, [0x9]: 0x2301, [0xa]: 0x2301, [0xb]: 0x2301, [0xc]: 0x2301, [0xd]: 0x2301, [0xe]: 0x2301, [0xf]: 0x2301, ], }, ], }, small_slots: StatePart { value: [ 1, 0, 0, 1, 2, 1, 0, 0, 0, 2, 2, 0, ], }, big_slots: StatePart { value: [ 2, 1, 0, 176, -64, 2, 0, 0, 208, -32, 1, 1, 2, 1, 0, 176, -64, 2, 0, 0, 208, -32, 1, 1, 208, -32, 1, 1, ], }, }, io: Instance { name: ::memories, instantiated: Module { name: memories, .. }, }, main_module: SimulationModuleState { base_targets: [ Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w, ], uninitialized_ios: {}, io_targets: { Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.addr, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.clk, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.data, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.data.0, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.data.1, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.r.en, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.addr, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.clk, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.data, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.data.0, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.data.1, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.en, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.mask, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.mask.0, Instance { name: ::memories, instantiated: Module { name: memories, .. }, }.w.mask.1, }, did_initial_settle: true, }, extern_modules: [], state_ready_to_run: false, trace_decls: TraceModule { name: "memories", children: [ TraceModuleIO { name: "r", child: TraceBundle { name: "r", fields: [ TraceUInt { location: TraceScalarId(0), name: "addr", ty: UInt<4>, flow: Source, }, TraceBool { location: TraceScalarId(1), name: "en", flow: Source, }, TraceClock { location: TraceScalarId(2), name: "clk", flow: Source, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(3), name: "0", ty: UInt<8>, flow: Sink, }, TraceSInt { location: TraceScalarId(4), name: "1", ty: SInt<8>, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, flow: Source, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, flow: Source, }, TraceModuleIO { name: "w", child: TraceBundle { name: "w", fields: [ TraceUInt { location: TraceScalarId(5), name: "addr", ty: UInt<4>, flow: Source, }, TraceBool { location: TraceScalarId(6), name: "en", flow: Source, }, TraceClock { location: TraceScalarId(7), name: "clk", flow: Source, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(8), name: "0", ty: UInt<8>, flow: Source, }, TraceSInt { location: TraceScalarId(9), name: "1", ty: SInt<8>, flow: Source, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Source, }, TraceBundle { name: "mask", fields: [ TraceBool { location: TraceScalarId(10), name: "0", flow: Source, }, TraceBool { location: TraceScalarId(11), name: "1", flow: Source, }, ], ty: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, flow: Source, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, flow: Source, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, flow: Source, }, TraceMem { id: TraceMemoryId(0), name: "mem", stride: 16, element_type: TraceBundle { name: "mem", fields: [ TraceUInt { location: TraceMemoryLocation { id: TraceMemoryId(0), depth: 16, stride: 16, start: 0, len: 8, }, name: "0", ty: UInt<8>, flow: Duplex, }, TraceSInt { location: TraceMemoryLocation { id: TraceMemoryId(0), depth: 16, stride: 16, start: 8, len: 8, }, name: "1", ty: SInt<8>, flow: Duplex, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Duplex, }, ports: [ TraceMemPort { name: "r0", bundle: TraceBundle { name: "r0", fields: [ TraceUInt { location: TraceScalarId(12), name: "addr", ty: UInt<4>, flow: Sink, }, TraceBool { location: TraceScalarId(13), name: "en", flow: Sink, }, TraceClock { location: TraceScalarId(14), name: "clk", flow: Sink, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(15), name: "0", ty: UInt<8>, flow: Source, }, TraceSInt { location: TraceScalarId(16), name: "1", ty: SInt<8>, flow: Source, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Source, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, flow: Sink, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, }, TraceMemPort { name: "w1", bundle: TraceBundle { name: "w1", fields: [ TraceUInt { location: TraceScalarId(17), name: "addr", ty: UInt<4>, flow: Sink, }, TraceBool { location: TraceScalarId(18), name: "en", flow: Sink, }, TraceClock { location: TraceScalarId(19), name: "clk", flow: Sink, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(20), name: "0", ty: UInt<8>, flow: Sink, }, TraceSInt { location: TraceScalarId(21), name: "1", ty: SInt<8>, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Sink, }, TraceBundle { name: "mask", fields: [ TraceBool { location: TraceScalarId(22), name: "0", flow: Sink, }, TraceBool { location: TraceScalarId(23), name: "1", flow: Sink, }, ], ty: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, flow: Sink, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, }, ], array_type: Array, 1: SInt<8>}, 16>, }, ], }, traces: [ SimTrace { id: TraceScalarId(0), kind: BigUInt { index: StatePartIndex(0), ty: UInt<4>, }, state: 0x2, last_state: 0x2, }, SimTrace { id: TraceScalarId(1), kind: BigBool { index: StatePartIndex(1), }, state: 0x1, last_state: 0x1, }, SimTrace { id: TraceScalarId(2), kind: BigClock { index: StatePartIndex(2), }, state: 0x0, last_state: 0x1, }, SimTrace { id: TraceScalarId(3), kind: BigUInt { index: StatePartIndex(3), ty: UInt<8>, }, state: 0xb0, last_state: 0xb0, }, SimTrace { id: TraceScalarId(4), kind: BigSInt { index: StatePartIndex(4), ty: SInt<8>, }, state: 0xc0, last_state: 0xc0, }, SimTrace { id: TraceScalarId(5), kind: BigUInt { index: StatePartIndex(5), ty: UInt<4>, }, state: 0x2, last_state: 0x2, }, SimTrace { id: TraceScalarId(6), kind: BigBool { index: StatePartIndex(6), }, state: 0x0, last_state: 0x0, }, SimTrace { id: TraceScalarId(7), kind: BigClock { index: StatePartIndex(7), }, state: 0x0, last_state: 0x1, }, SimTrace { id: TraceScalarId(8), kind: BigUInt { index: StatePartIndex(8), ty: UInt<8>, }, state: 0xd0, last_state: 0xd0, }, SimTrace { id: TraceScalarId(9), kind: BigSInt { index: StatePartIndex(9), ty: SInt<8>, }, state: 0xe0, last_state: 0xe0, }, SimTrace { id: TraceScalarId(10), kind: BigBool { index: StatePartIndex(10), }, state: 0x1, last_state: 0x1, }, SimTrace { id: TraceScalarId(11), kind: BigBool { index: StatePartIndex(11), }, state: 0x1, last_state: 0x1, }, SimTrace { id: TraceScalarId(12), kind: BigUInt { index: StatePartIndex(12), ty: UInt<4>, }, state: 0x2, last_state: 0x2, }, SimTrace { id: TraceScalarId(13), kind: BigBool { index: StatePartIndex(13), }, state: 0x1, last_state: 0x1, }, SimTrace { id: TraceScalarId(14), kind: BigClock { index: StatePartIndex(14), }, state: 0x0, last_state: 0x1, }, SimTrace { id: TraceScalarId(15), kind: BigUInt { index: StatePartIndex(15), ty: UInt<8>, }, state: 0xb0, last_state: 0xb0, }, SimTrace { id: TraceScalarId(16), kind: BigSInt { index: StatePartIndex(16), ty: SInt<8>, }, state: 0xc0, last_state: 0xc0, }, SimTrace { id: TraceScalarId(17), kind: BigUInt { index: StatePartIndex(17), ty: UInt<4>, }, state: 0x2, last_state: 0x2, }, SimTrace { id: TraceScalarId(18), kind: BigBool { index: StatePartIndex(18), }, state: 0x0, last_state: 0x0, }, SimTrace { id: TraceScalarId(19), kind: BigClock { index: StatePartIndex(19), }, state: 0x0, last_state: 0x1, }, SimTrace { id: TraceScalarId(20), kind: BigUInt { index: StatePartIndex(20), ty: UInt<8>, }, state: 0xd0, last_state: 0xd0, }, SimTrace { id: TraceScalarId(21), kind: BigSInt { index: StatePartIndex(21), ty: SInt<8>, }, state: 0xe0, last_state: 0xe0, }, SimTrace { id: TraceScalarId(22), kind: BigBool { index: StatePartIndex(22), }, state: 0x1, last_state: 0x1, }, SimTrace { id: TraceScalarId(23), kind: BigBool { index: StatePartIndex(23), }, state: 0x1, last_state: 0x1, }, ], trace_memories: { StatePartIndex(0): TraceMem { id: TraceMemoryId(0), name: "mem", stride: 16, element_type: TraceBundle { name: "mem", fields: [ TraceUInt { location: TraceMemoryLocation { id: TraceMemoryId(0), depth: 16, stride: 16, start: 0, len: 8, }, name: "0", ty: UInt<8>, flow: Duplex, }, TraceSInt { location: TraceMemoryLocation { id: TraceMemoryId(0), depth: 16, stride: 16, start: 8, len: 8, }, name: "1", ty: SInt<8>, flow: Duplex, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Duplex, }, ports: [ TraceMemPort { name: "r0", bundle: TraceBundle { name: "r0", fields: [ TraceUInt { location: TraceScalarId(12), name: "addr", ty: UInt<4>, flow: Sink, }, TraceBool { location: TraceScalarId(13), name: "en", flow: Sink, }, TraceClock { location: TraceScalarId(14), name: "clk", flow: Sink, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(15), name: "0", ty: UInt<8>, flow: Source, }, TraceSInt { location: TraceScalarId(16), name: "1", ty: SInt<8>, flow: Source, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Source, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, flow: Sink, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, #[hdl(flip)] /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, }, }, TraceMemPort { name: "w1", bundle: TraceBundle { name: "w1", fields: [ TraceUInt { location: TraceScalarId(17), name: "addr", ty: UInt<4>, flow: Sink, }, TraceBool { location: TraceScalarId(18), name: "en", flow: Sink, }, TraceClock { location: TraceScalarId(19), name: "clk", flow: Sink, }, TraceBundle { name: "data", fields: [ TraceUInt { location: TraceScalarId(20), name: "0", ty: UInt<8>, flow: Sink, }, TraceSInt { location: TraceScalarId(21), name: "1", ty: SInt<8>, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, flow: Sink, }, TraceBundle { name: "mask", fields: [ TraceBool { location: TraceScalarId(22), name: "0", flow: Sink, }, TraceBool { location: TraceScalarId(23), name: "1", flow: Sink, }, ], ty: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, flow: Sink, }, ], ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, flow: Sink, }, ty: Bundle { /* offset = 0 */ addr: UInt<4>, /* offset = 4 */ en: Bool, /* offset = 5 */ clk: Clock, /* offset = 6 */ data: Bundle { /* offset = 0 */ 0: UInt<8>, /* offset = 8 */ 1: SInt<8>, }, /* offset = 22 */ mask: Bundle { /* offset = 0 */ 0: Bool, /* offset = 1 */ 1: Bool, }, }, }, ], array_type: Array, 1: SInt<8>}, 16>, }, }, trace_writers: [ Running( VcdWriter { finished_init: true, timescale: 1 ps, .. }, ), ], instant: 22 μs, clocks_triggered: [ StatePartIndex(1), StatePartIndex(6), ], .. }