fayalite/crates/fayalite/tests/sim/expected/memories.txt
Jacob Lifshay d1bd176b28
All checks were successful
/ deps (pull_request) Successful in 11m39s
/ test (pull_request) Successful in 3m55s
implement simulation of extern modules
2025-03-21 01:47:14 -07:00

1616 lines
66 KiB
Plaintext

Simulation {
state: State {
insns: Insns {
state_layout: StateLayout {
ty: TypeLayout {
small_slots: StatePartLayout<SmallSlots> {
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<BigSlots> {
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<Memories> {
len: 1,
debug_data: [
(),
],
layout_data: [
MemoryData {
array_type: Array<Bundle {0: UInt<8>, 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<BigSlots>(17), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.addr", ty: UInt<4> },
src: StatePartIndex<BigSlots>(5), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.addr", ty: UInt<4> },
},
1: Copy {
dest: StatePartIndex<BigSlots>(18), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.en", ty: Bool },
src: StatePartIndex<BigSlots>(6), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.en", ty: Bool },
},
2: Copy {
dest: StatePartIndex<BigSlots>(19), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.clk", ty: Clock },
src: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.clk", ty: Clock },
},
3: Copy {
dest: StatePartIndex<BigSlots>(20), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.0", ty: UInt<8> },
src: StatePartIndex<BigSlots>(8), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.0", ty: UInt<8> },
},
4: Copy {
dest: StatePartIndex<BigSlots>(21), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.1", ty: SInt<8> },
src: StatePartIndex<BigSlots>(9), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.data.1", ty: SInt<8> },
},
5: Copy {
dest: StatePartIndex<BigSlots>(22), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.0", ty: Bool },
src: StatePartIndex<BigSlots>(10), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.0", ty: Bool },
},
6: Copy {
dest: StatePartIndex<BigSlots>(23), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.1", ty: Bool },
src: StatePartIndex<BigSlots>(11), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::w.mask.1", ty: Bool },
},
// at: module-XXXXXXXXXX.rs:6:1
7: Copy {
dest: StatePartIndex<BigSlots>(14), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.clk", ty: Clock },
src: StatePartIndex<BigSlots>(2), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.clk", ty: Clock },
},
8: Copy {
dest: StatePartIndex<BigSlots>(13), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.en", ty: Bool },
src: StatePartIndex<BigSlots>(1), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.en", ty: Bool },
},
9: Copy {
dest: StatePartIndex<BigSlots>(12), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.addr", ty: UInt<4> },
src: StatePartIndex<BigSlots>(0), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.addr", ty: UInt<4> },
},
// at: module-XXXXXXXXXX.rs:4:1
10: CastBigToArrayIndex {
dest: StatePartIndex<SmallSlots>(9), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
src: StatePartIndex<BigSlots>(17), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.addr", ty: UInt<4> },
},
11: IsNonZeroDestIsSmall {
dest: StatePartIndex<SmallSlots>(8), // (0x0 0) SlotDebugData { name: "", ty: Bool },
src: StatePartIndex<BigSlots>(18), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.en", ty: Bool },
},
12: IsNonZeroDestIsSmall {
dest: StatePartIndex<SmallSlots>(7), // (0x0 0) SlotDebugData { name: "", ty: Bool },
src: StatePartIndex<BigSlots>(19), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.clk", ty: Clock },
},
13: AndSmall {
dest: StatePartIndex<SmallSlots>(6), // (0x0 0) SlotDebugData { name: "", ty: Bool },
lhs: StatePartIndex<SmallSlots>(7), // (0x0 0) SlotDebugData { name: "", ty: Bool },
rhs: StatePartIndex<SmallSlots>(5), // (0x1 1) SlotDebugData { name: "", ty: Bool },
},
14: CastBigToArrayIndex {
dest: StatePartIndex<SmallSlots>(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
src: StatePartIndex<BigSlots>(12), // (0x2) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.addr", ty: UInt<4> },
},
15: IsNonZeroDestIsSmall {
dest: StatePartIndex<SmallSlots>(3), // (0x1 1) SlotDebugData { name: "", ty: Bool },
src: StatePartIndex<BigSlots>(13), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.en", ty: Bool },
},
16: BranchIfSmallZero {
target: 20,
value: StatePartIndex<SmallSlots>(3), // (0x1 1) SlotDebugData { name: "", ty: Bool },
},
17: MemoryReadUInt {
dest: StatePartIndex<BigSlots>(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> },
memory: StatePartIndex<Memories>(0), // (MemoryData {
// array_type: Array<Bundle {0: UInt<8>, 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<SmallSlots>(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
stride: 16,
start: 0,
width: 8,
},
18: MemoryReadSInt {
dest: StatePartIndex<BigSlots>(16), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.1", ty: SInt<8> },
memory: StatePartIndex<Memories>(0), // (MemoryData {
// array_type: Array<Bundle {0: UInt<8>, 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<SmallSlots>(4), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
stride: 16,
start: 8,
width: 8,
},
19: Branch {
target: 22,
},
20: Const {
dest: StatePartIndex<BigSlots>(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> },
value: 0x0,
},
21: Const {
dest: StatePartIndex<BigSlots>(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<BigSlots>(3), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.0", ty: UInt<8> },
src: StatePartIndex<BigSlots>(15), // (0xb0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.data.0", ty: UInt<8> },
},
23: Copy {
dest: StatePartIndex<BigSlots>(4), // (-0x40) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::r.data.1", ty: SInt<8> },
src: StatePartIndex<BigSlots>(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<SmallSlots>(2), // (0x0 0) SlotDebugData { name: "", ty: Bool },
src: StatePartIndex<BigSlots>(14), // (0x0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::r0.clk", ty: Clock },
},
25: AndSmall {
dest: StatePartIndex<SmallSlots>(1), // (0x0 0) SlotDebugData { name: "", ty: Bool },
lhs: StatePartIndex<SmallSlots>(2), // (0x0 0) SlotDebugData { name: "", ty: Bool },
rhs: StatePartIndex<SmallSlots>(0), // (0x1 1) SlotDebugData { name: "", ty: Bool },
},
26: BranchIfSmallZero {
target: 27,
value: StatePartIndex<SmallSlots>(1), // (0x0 0) SlotDebugData { name: "", ty: Bool },
},
27: BranchIfSmallZero {
target: 39,
value: StatePartIndex<SmallSlots>(6), // (0x0 0) SlotDebugData { name: "", ty: Bool },
},
28: CopySmall {
dest: StatePartIndex<SmallSlots>(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
src: StatePartIndex<SmallSlots>(9), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
},
29: CopySmall {
dest: StatePartIndex<SmallSlots>(11), // (0x0 0) SlotDebugData { name: "", ty: Bool },
src: StatePartIndex<SmallSlots>(8), // (0x0 0) SlotDebugData { name: "", ty: Bool },
},
30: Copy {
dest: StatePartIndex<BigSlots>(24), // (0xd0) SlotDebugData { name: ".0", ty: UInt<8> },
src: StatePartIndex<BigSlots>(20), // (0xd0) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.0", ty: UInt<8> },
},
31: Copy {
dest: StatePartIndex<BigSlots>(25), // (-0x20) SlotDebugData { name: ".1", ty: SInt<8> },
src: StatePartIndex<BigSlots>(21), // (-0x20) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.data.1", ty: SInt<8> },
},
32: Copy {
dest: StatePartIndex<BigSlots>(26), // (0x1) SlotDebugData { name: ".0", ty: Bool },
src: StatePartIndex<BigSlots>(22), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.0", ty: Bool },
},
33: Copy {
dest: StatePartIndex<BigSlots>(27), // (0x1) SlotDebugData { name: ".1", ty: Bool },
src: StatePartIndex<BigSlots>(23), // (0x1) SlotDebugData { name: "InstantiatedModule(memories: memories).memories::mem::w1.mask.1", ty: Bool },
},
34: BranchIfSmallZero {
target: 39,
value: StatePartIndex<SmallSlots>(11), // (0x0 0) SlotDebugData { name: "", ty: Bool },
},
35: BranchIfZero {
target: 37,
value: StatePartIndex<BigSlots>(26), // (0x1) SlotDebugData { name: ".0", ty: Bool },
},
36: MemoryWriteUInt {
value: StatePartIndex<BigSlots>(24), // (0xd0) SlotDebugData { name: ".0", ty: UInt<8> },
memory: StatePartIndex<Memories>(0), // (MemoryData {
// array_type: Array<Bundle {0: UInt<8>, 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<SmallSlots>(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
stride: 16,
start: 0,
width: 8,
},
37: BranchIfZero {
target: 39,
value: StatePartIndex<BigSlots>(27), // (0x1) SlotDebugData { name: ".1", ty: Bool },
},
38: MemoryWriteSInt {
value: StatePartIndex<BigSlots>(25), // (-0x20) SlotDebugData { name: ".1", ty: SInt<8> },
memory: StatePartIndex<Memories>(0), // (MemoryData {
// array_type: Array<Bundle {0: UInt<8>, 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<SmallSlots>(10), // (0x2 2) SlotDebugData { name: "", ty: UInt<4> },
stride: 16,
start: 8,
width: 8,
},
39: XorSmallImmediate {
dest: StatePartIndex<SmallSlots>(0), // (0x1 1) SlotDebugData { name: "", ty: Bool },
lhs: StatePartIndex<SmallSlots>(2), // (0x0 0) SlotDebugData { name: "", ty: Bool },
rhs: 0x1,
},
40: XorSmallImmediate {
dest: StatePartIndex<SmallSlots>(5), // (0x1 1) SlotDebugData { name: "", ty: Bool },
lhs: StatePartIndex<SmallSlots>(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<Bundle {0: UInt<8>, 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: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
},
main_module: SimulationModuleState {
base_targets: [
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w,
],
uninitialized_ios: {},
io_targets: {
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.addr,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.clk,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.data,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.data.0,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.data.1,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.r.en,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.addr,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.clk,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.data,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.data.0,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.data.1,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.en,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.mask,
Instance {
name: <simulator>::memories,
instantiated: Module {
name: memories,
..
},
}.w.mask.0,
Instance {
name: <simulator>::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<Bundle {0: UInt<8>, 1: SInt<8>}, 16>,
},
],
},
traces: [
SimTrace {
id: TraceScalarId(0),
kind: BigUInt {
index: StatePartIndex<BigSlots>(0),
ty: UInt<4>,
},
state: 0x2,
last_state: 0x2,
},
SimTrace {
id: TraceScalarId(1),
kind: BigBool {
index: StatePartIndex<BigSlots>(1),
},
state: 0x1,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(2),
kind: BigClock {
index: StatePartIndex<BigSlots>(2),
},
state: 0x0,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(3),
kind: BigUInt {
index: StatePartIndex<BigSlots>(3),
ty: UInt<8>,
},
state: 0xb0,
last_state: 0xb0,
},
SimTrace {
id: TraceScalarId(4),
kind: BigSInt {
index: StatePartIndex<BigSlots>(4),
ty: SInt<8>,
},
state: 0xc0,
last_state: 0xc0,
},
SimTrace {
id: TraceScalarId(5),
kind: BigUInt {
index: StatePartIndex<BigSlots>(5),
ty: UInt<4>,
},
state: 0x2,
last_state: 0x2,
},
SimTrace {
id: TraceScalarId(6),
kind: BigBool {
index: StatePartIndex<BigSlots>(6),
},
state: 0x0,
last_state: 0x0,
},
SimTrace {
id: TraceScalarId(7),
kind: BigClock {
index: StatePartIndex<BigSlots>(7),
},
state: 0x0,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(8),
kind: BigUInt {
index: StatePartIndex<BigSlots>(8),
ty: UInt<8>,
},
state: 0xd0,
last_state: 0xd0,
},
SimTrace {
id: TraceScalarId(9),
kind: BigSInt {
index: StatePartIndex<BigSlots>(9),
ty: SInt<8>,
},
state: 0xe0,
last_state: 0xe0,
},
SimTrace {
id: TraceScalarId(10),
kind: BigBool {
index: StatePartIndex<BigSlots>(10),
},
state: 0x1,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(11),
kind: BigBool {
index: StatePartIndex<BigSlots>(11),
},
state: 0x1,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(12),
kind: BigUInt {
index: StatePartIndex<BigSlots>(12),
ty: UInt<4>,
},
state: 0x2,
last_state: 0x2,
},
SimTrace {
id: TraceScalarId(13),
kind: BigBool {
index: StatePartIndex<BigSlots>(13),
},
state: 0x1,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(14),
kind: BigClock {
index: StatePartIndex<BigSlots>(14),
},
state: 0x0,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(15),
kind: BigUInt {
index: StatePartIndex<BigSlots>(15),
ty: UInt<8>,
},
state: 0xb0,
last_state: 0xb0,
},
SimTrace {
id: TraceScalarId(16),
kind: BigSInt {
index: StatePartIndex<BigSlots>(16),
ty: SInt<8>,
},
state: 0xc0,
last_state: 0xc0,
},
SimTrace {
id: TraceScalarId(17),
kind: BigUInt {
index: StatePartIndex<BigSlots>(17),
ty: UInt<4>,
},
state: 0x2,
last_state: 0x2,
},
SimTrace {
id: TraceScalarId(18),
kind: BigBool {
index: StatePartIndex<BigSlots>(18),
},
state: 0x0,
last_state: 0x0,
},
SimTrace {
id: TraceScalarId(19),
kind: BigClock {
index: StatePartIndex<BigSlots>(19),
},
state: 0x0,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(20),
kind: BigUInt {
index: StatePartIndex<BigSlots>(20),
ty: UInt<8>,
},
state: 0xd0,
last_state: 0xd0,
},
SimTrace {
id: TraceScalarId(21),
kind: BigSInt {
index: StatePartIndex<BigSlots>(21),
ty: SInt<8>,
},
state: 0xe0,
last_state: 0xe0,
},
SimTrace {
id: TraceScalarId(22),
kind: BigBool {
index: StatePartIndex<BigSlots>(22),
},
state: 0x1,
last_state: 0x1,
},
SimTrace {
id: TraceScalarId(23),
kind: BigBool {
index: StatePartIndex<BigSlots>(23),
},
state: 0x1,
last_state: 0x1,
},
],
trace_memories: {
StatePartIndex<Memories>(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<Bundle {0: UInt<8>, 1: SInt<8>}, 16>,
},
},
trace_writers: [
Running(
VcdWriter {
finished_init: true,
timescale: 1 ps,
..
},
),
],
instant: 22 μs,
clocks_triggered: [
StatePartIndex<SmallSlots>(1),
StatePartIndex<SmallSlots>(6),
],
..
}