1923 lines
84 KiB
Plaintext
1923 lines
84 KiB
Plaintext
Simulation {
|
|
state: State {
|
|
insns: Insns {
|
|
state_layout: StateLayout {
|
|
ty: TypeLayout {
|
|
small_slots: StatePartLayout<SmallSlots> {
|
|
len: 7,
|
|
debug_data: [
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome,
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome,
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
A,
|
|
B,
|
|
C,
|
|
},
|
|
},
|
|
],
|
|
..
|
|
},
|
|
big_slots: StatePartLayout<BigSlots> {
|
|
len: 111,
|
|
debug_data: [
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::cd.clk",
|
|
ty: Clock,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::cd.rst",
|
|
ty: SyncReset,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::en",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::which_in",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::data_in",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::which_out",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::data_out",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::b_out",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::b2_out",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::the_reg",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "InstantiatedModule(enums: enums).enums::the_reg$next",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: ".a[0]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".a[1]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".b",
|
|
ty: SInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "[0]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "[1]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: SInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.a[0]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.a[1]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.b",
|
|
ty: SInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".a[0]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".a[1]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".b",
|
|
ty: SInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "[0]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "[1]",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: SInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<6>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.0",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: ".1.1",
|
|
ty: Bool,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<1>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<3>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<2>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
SlotDebugData {
|
|
name: "",
|
|
ty: UInt<4>,
|
|
},
|
|
],
|
|
..
|
|
},
|
|
},
|
|
memories: StatePartLayout<Memories> {
|
|
len: 0,
|
|
debug_data: [],
|
|
layout_data: [],
|
|
..
|
|
},
|
|
},
|
|
insns: [
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
0: Const {
|
|
dest: StatePartIndex<BigSlots>(98), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
value: 0x1,
|
|
},
|
|
1: Const {
|
|
dest: StatePartIndex<BigSlots>(90), // (0x0) SlotDebugData { name: "", ty: UInt<4> },
|
|
value: 0x0,
|
|
},
|
|
2: Const {
|
|
dest: StatePartIndex<BigSlots>(88), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
value: 0x0,
|
|
},
|
|
3: Copy {
|
|
dest: StatePartIndex<BigSlots>(89), // (0x0) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
src: StatePartIndex<BigSlots>(88), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:18:1
|
|
4: Copy {
|
|
dest: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
src: StatePartIndex<BigSlots>(89), // (0x0) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
5: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(77), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(4), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_in", ty: UInt<4> },
|
|
start: 2,
|
|
len: 2,
|
|
},
|
|
6: CastToSInt {
|
|
dest: StatePartIndex<BigSlots>(78), // (-0x1) SlotDebugData { name: "", ty: SInt<2> },
|
|
src: StatePartIndex<BigSlots>(77), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
dest_width: 2,
|
|
},
|
|
7: Const {
|
|
dest: StatePartIndex<BigSlots>(70), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
value: 0x2,
|
|
},
|
|
8: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(57), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(4), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_in", ty: UInt<4> },
|
|
start: 1,
|
|
len: 1,
|
|
},
|
|
9: Copy {
|
|
dest: StatePartIndex<BigSlots>(58), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(57), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
10: Copy {
|
|
dest: StatePartIndex<BigSlots>(76), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(58), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
11: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(54), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(4), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_in", ty: UInt<4> },
|
|
start: 0,
|
|
len: 1,
|
|
},
|
|
12: Copy {
|
|
dest: StatePartIndex<BigSlots>(55), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(54), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
13: Copy {
|
|
dest: StatePartIndex<BigSlots>(56), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(55), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
14: Copy {
|
|
dest: StatePartIndex<BigSlots>(52), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(56), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
15: Copy {
|
|
dest: StatePartIndex<BigSlots>(53), // (0x1) SlotDebugData { name: ".1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(58), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
16: Copy {
|
|
dest: StatePartIndex<BigSlots>(74), // (0x1) SlotDebugData { name: "[0]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(56), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
17: Copy {
|
|
dest: StatePartIndex<BigSlots>(75), // (0x1) SlotDebugData { name: "[1]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(76), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
18: Copy {
|
|
dest: StatePartIndex<BigSlots>(71), // (0x1) SlotDebugData { name: ".a[0]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(74), // (0x1) SlotDebugData { name: "[0]", ty: UInt<1> },
|
|
},
|
|
19: Copy {
|
|
dest: StatePartIndex<BigSlots>(72), // (0x1) SlotDebugData { name: ".a[1]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(75), // (0x1) SlotDebugData { name: "[1]", ty: UInt<1> },
|
|
},
|
|
20: Copy {
|
|
dest: StatePartIndex<BigSlots>(73), // (-0x1) SlotDebugData { name: ".b", ty: SInt<2> },
|
|
src: StatePartIndex<BigSlots>(78), // (-0x1) SlotDebugData { name: "", ty: SInt<2> },
|
|
},
|
|
21: Copy {
|
|
dest: StatePartIndex<BigSlots>(66), // (0x2) SlotDebugData { name: ".0", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(70), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
22: Copy {
|
|
dest: StatePartIndex<BigSlots>(67), // (0x1) SlotDebugData { name: ".1.a[0]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(71), // (0x1) SlotDebugData { name: ".a[0]", ty: UInt<1> },
|
|
},
|
|
23: Copy {
|
|
dest: StatePartIndex<BigSlots>(68), // (0x1) SlotDebugData { name: ".1.a[1]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(72), // (0x1) SlotDebugData { name: ".a[1]", ty: UInt<1> },
|
|
},
|
|
24: Copy {
|
|
dest: StatePartIndex<BigSlots>(69), // (-0x1) SlotDebugData { name: ".1.b", ty: SInt<2> },
|
|
src: StatePartIndex<BigSlots>(73), // (-0x1) SlotDebugData { name: ".b", ty: SInt<2> },
|
|
},
|
|
25: Shl {
|
|
dest: StatePartIndex<BigSlots>(79), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(68), // (0x1) SlotDebugData { name: ".1.a[1]", ty: UInt<1> },
|
|
rhs: 1,
|
|
},
|
|
26: Or {
|
|
dest: StatePartIndex<BigSlots>(80), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(67), // (0x1) SlotDebugData { name: ".1.a[0]", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(79), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
27: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(81), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(69), // (-0x1) SlotDebugData { name: ".1.b", ty: SInt<2> },
|
|
dest_width: 2,
|
|
},
|
|
28: Shl {
|
|
dest: StatePartIndex<BigSlots>(82), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(81), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: 2,
|
|
},
|
|
29: Or {
|
|
dest: StatePartIndex<BigSlots>(83), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(80), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(82), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
30: Shl {
|
|
dest: StatePartIndex<BigSlots>(84), // (0x3c) SlotDebugData { name: "", ty: UInt<6> },
|
|
lhs: StatePartIndex<BigSlots>(83), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
rhs: 2,
|
|
},
|
|
31: Or {
|
|
dest: StatePartIndex<BigSlots>(85), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
lhs: StatePartIndex<BigSlots>(66), // (0x2) SlotDebugData { name: ".0", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(84), // (0x3c) SlotDebugData { name: "", ty: UInt<6> },
|
|
},
|
|
32: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(86), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
src: StatePartIndex<BigSlots>(85), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
dest_width: 6,
|
|
},
|
|
33: Copy {
|
|
dest: StatePartIndex<BigSlots>(87), // (0x3e) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(86), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
},
|
|
34: Const {
|
|
dest: StatePartIndex<BigSlots>(47), // (0x1) SlotDebugData { name: "", ty: UInt<2> },
|
|
value: 0x1,
|
|
},
|
|
35: CmpEq {
|
|
dest: StatePartIndex<BigSlots>(48), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
lhs: StatePartIndex<BigSlots>(3), // (0x2) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::which_in", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(47), // (0x1) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
36: Copy {
|
|
dest: StatePartIndex<BigSlots>(49), // (0x1) SlotDebugData { name: ".0", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(47), // (0x1) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
37: Copy {
|
|
dest: StatePartIndex<BigSlots>(50), // (0x1) SlotDebugData { name: ".1.0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(52), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
},
|
|
38: Copy {
|
|
dest: StatePartIndex<BigSlots>(51), // (0x1) SlotDebugData { name: ".1.1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(53), // (0x1) SlotDebugData { name: ".1", ty: Bool },
|
|
},
|
|
39: Copy {
|
|
dest: StatePartIndex<BigSlots>(59), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(51), // (0x1) SlotDebugData { name: ".1.1", ty: Bool },
|
|
},
|
|
40: Shl {
|
|
dest: StatePartIndex<BigSlots>(60), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(59), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
rhs: 1,
|
|
},
|
|
41: Or {
|
|
dest: StatePartIndex<BigSlots>(61), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(50), // (0x1) SlotDebugData { name: ".1.0", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(60), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
42: Shl {
|
|
dest: StatePartIndex<BigSlots>(62), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(61), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: 2,
|
|
},
|
|
43: Or {
|
|
dest: StatePartIndex<BigSlots>(63), // (0xd) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(49), // (0x1) SlotDebugData { name: ".0", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(62), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
44: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(64), // (0xd) SlotDebugData { name: "", ty: UInt<6> },
|
|
src: StatePartIndex<BigSlots>(63), // (0xd) SlotDebugData { name: "", ty: UInt<4> },
|
|
dest_width: 6,
|
|
},
|
|
45: Copy {
|
|
dest: StatePartIndex<BigSlots>(65), // (0xd) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(64), // (0xd) SlotDebugData { name: "", ty: UInt<6> },
|
|
},
|
|
46: Const {
|
|
dest: StatePartIndex<BigSlots>(45), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
value: 0x0,
|
|
},
|
|
47: CmpEq {
|
|
dest: StatePartIndex<BigSlots>(46), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
lhs: StatePartIndex<BigSlots>(3), // (0x2) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::which_in", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(45), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
48: Copy {
|
|
dest: StatePartIndex<BigSlots>(29), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
src: StatePartIndex<BigSlots>(23), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
49: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(30), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(29), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
start: 2,
|
|
len: 2,
|
|
},
|
|
50: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(31), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(30), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 0,
|
|
len: 1,
|
|
},
|
|
51: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(32), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(30), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 1,
|
|
len: 1,
|
|
},
|
|
52: Copy {
|
|
dest: StatePartIndex<BigSlots>(33), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(32), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
53: Copy {
|
|
dest: StatePartIndex<BigSlots>(27), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(31), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
54: Copy {
|
|
dest: StatePartIndex<BigSlots>(28), // (0x1) SlotDebugData { name: ".1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(33), // (0x1) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
55: Copy {
|
|
dest: StatePartIndex<BigSlots>(91), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(28), // (0x1) SlotDebugData { name: ".1", ty: Bool },
|
|
},
|
|
56: Shl {
|
|
dest: StatePartIndex<BigSlots>(92), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(91), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
rhs: 1,
|
|
},
|
|
57: Or {
|
|
dest: StatePartIndex<BigSlots>(93), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(27), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(92), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
58: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(94), // (0x3) SlotDebugData { name: "", ty: UInt<4> },
|
|
src: StatePartIndex<BigSlots>(93), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
dest_width: 4,
|
|
},
|
|
59: Copy {
|
|
dest: StatePartIndex<BigSlots>(95), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(98), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
60: Copy {
|
|
dest: StatePartIndex<BigSlots>(96), // (0x1) SlotDebugData { name: ".1.0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(27), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
},
|
|
61: Copy {
|
|
dest: StatePartIndex<BigSlots>(97), // (0x1) SlotDebugData { name: ".1.1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(28), // (0x1) SlotDebugData { name: ".1", ty: Bool },
|
|
},
|
|
62: Copy {
|
|
dest: StatePartIndex<BigSlots>(99), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(97), // (0x1) SlotDebugData { name: ".1.1", ty: Bool },
|
|
},
|
|
63: Shl {
|
|
dest: StatePartIndex<BigSlots>(100), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(99), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
rhs: 1,
|
|
},
|
|
64: Or {
|
|
dest: StatePartIndex<BigSlots>(101), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(96), // (0x1) SlotDebugData { name: ".1.0", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(100), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
65: Shl {
|
|
dest: StatePartIndex<BigSlots>(102), // (0x6) SlotDebugData { name: "", ty: UInt<3> },
|
|
lhs: StatePartIndex<BigSlots>(101), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: 1,
|
|
},
|
|
66: Or {
|
|
dest: StatePartIndex<BigSlots>(103), // (0x7) SlotDebugData { name: "", ty: UInt<3> },
|
|
lhs: StatePartIndex<BigSlots>(95), // (0x1) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(102), // (0x6) SlotDebugData { name: "", ty: UInt<3> },
|
|
},
|
|
67: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(104), // (0x7) SlotDebugData { name: "", ty: UInt<3> },
|
|
src: StatePartIndex<BigSlots>(103), // (0x7) SlotDebugData { name: "", ty: UInt<3> },
|
|
dest_width: 3,
|
|
},
|
|
68: Copy {
|
|
dest: StatePartIndex<BigSlots>(105), // (0x7) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
src: StatePartIndex<BigSlots>(104), // (0x7) SlotDebugData { name: "", ty: UInt<3> },
|
|
},
|
|
69: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(39), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
src: StatePartIndex<BigSlots>(29), // (0x3e) SlotDebugData { name: "", ty: UInt<6> },
|
|
start: 2,
|
|
len: 4,
|
|
},
|
|
70: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(40), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(39), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
start: 0,
|
|
len: 2,
|
|
},
|
|
71: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(41), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(40), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 0,
|
|
len: 1,
|
|
},
|
|
72: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(42), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(40), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 1,
|
|
len: 1,
|
|
},
|
|
73: Copy {
|
|
dest: StatePartIndex<BigSlots>(37), // (0x1) SlotDebugData { name: "[0]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(41), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
74: Copy {
|
|
dest: StatePartIndex<BigSlots>(38), // (0x1) SlotDebugData { name: "[1]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(42), // (0x1) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
75: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(43), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(39), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
start: 2,
|
|
len: 2,
|
|
},
|
|
76: CastToSInt {
|
|
dest: StatePartIndex<BigSlots>(44), // (-0x1) SlotDebugData { name: "", ty: SInt<2> },
|
|
src: StatePartIndex<BigSlots>(43), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
dest_width: 2,
|
|
},
|
|
77: Copy {
|
|
dest: StatePartIndex<BigSlots>(34), // (0x1) SlotDebugData { name: ".a[0]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(37), // (0x1) SlotDebugData { name: "[0]", ty: UInt<1> },
|
|
},
|
|
78: Copy {
|
|
dest: StatePartIndex<BigSlots>(35), // (0x1) SlotDebugData { name: ".a[1]", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(38), // (0x1) SlotDebugData { name: "[1]", ty: UInt<1> },
|
|
},
|
|
79: Copy {
|
|
dest: StatePartIndex<BigSlots>(36), // (-0x1) SlotDebugData { name: ".b", ty: SInt<2> },
|
|
src: StatePartIndex<BigSlots>(44), // (-0x1) SlotDebugData { name: "", ty: SInt<2> },
|
|
},
|
|
80: Shl {
|
|
dest: StatePartIndex<BigSlots>(106), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(35), // (0x1) SlotDebugData { name: ".a[1]", ty: UInt<1> },
|
|
rhs: 1,
|
|
},
|
|
81: Or {
|
|
dest: StatePartIndex<BigSlots>(107), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
lhs: StatePartIndex<BigSlots>(34), // (0x1) SlotDebugData { name: ".a[0]", ty: UInt<1> },
|
|
rhs: StatePartIndex<BigSlots>(106), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
82: CastToUInt {
|
|
dest: StatePartIndex<BigSlots>(108), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(36), // (-0x1) SlotDebugData { name: ".b", ty: SInt<2> },
|
|
dest_width: 2,
|
|
},
|
|
83: Shl {
|
|
dest: StatePartIndex<BigSlots>(109), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(108), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: 2,
|
|
},
|
|
84: Or {
|
|
dest: StatePartIndex<BigSlots>(110), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
lhs: StatePartIndex<BigSlots>(107), // (0x3) SlotDebugData { name: "", ty: UInt<2> },
|
|
rhs: StatePartIndex<BigSlots>(109), // (0xc) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:11:1
|
|
85: AndBigWithSmallImmediate {
|
|
dest: StatePartIndex<SmallSlots>(6), // (0x2 2) SlotDebugData { name: "", ty: Enum {A, B, C} },
|
|
lhs: StatePartIndex<BigSlots>(23), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
rhs: 0x3,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:19:1
|
|
86: BranchIfSmallNeImmediate {
|
|
target: 89,
|
|
lhs: StatePartIndex<SmallSlots>(6), // (0x2 2) SlotDebugData { name: "", ty: Enum {A, B, C} },
|
|
rhs: 0x0,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:20:1
|
|
87: Copy {
|
|
dest: StatePartIndex<BigSlots>(5), // (0x2) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::which_out", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(45), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:21:1
|
|
88: Copy {
|
|
dest: StatePartIndex<BigSlots>(6), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_out", ty: UInt<4> },
|
|
src: StatePartIndex<BigSlots>(90), // (0x0) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:19:1
|
|
89: BranchIfSmallNeImmediate {
|
|
target: 93,
|
|
lhs: StatePartIndex<SmallSlots>(6), // (0x2 2) SlotDebugData { name: "", ty: Enum {A, B, C} },
|
|
rhs: 0x1,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:22:1
|
|
90: Copy {
|
|
dest: StatePartIndex<BigSlots>(5), // (0x2) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::which_out", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(47), // (0x1) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:23:1
|
|
91: Copy {
|
|
dest: StatePartIndex<BigSlots>(6), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_out", ty: UInt<4> },
|
|
src: StatePartIndex<BigSlots>(94), // (0x3) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:24:1
|
|
92: Copy {
|
|
dest: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
src: StatePartIndex<BigSlots>(105), // (0x7) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:19:1
|
|
93: BranchIfSmallNeImmediate {
|
|
target: 96,
|
|
lhs: StatePartIndex<SmallSlots>(6), // (0x2 2) SlotDebugData { name: "", ty: Enum {A, B, C} },
|
|
rhs: 0x2,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:25:1
|
|
94: Copy {
|
|
dest: StatePartIndex<BigSlots>(5), // (0x2) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::which_out", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(70), // (0x2) SlotDebugData { name: "", ty: UInt<2> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:26:1
|
|
95: Copy {
|
|
dest: StatePartIndex<BigSlots>(6), // (0xf) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::data_out", ty: UInt<4> },
|
|
src: StatePartIndex<BigSlots>(110), // (0xf) SlotDebugData { name: "", ty: UInt<4> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:11:1
|
|
96: IsNonZeroDestIsSmall {
|
|
dest: StatePartIndex<SmallSlots>(5), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(1), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::cd.rst", ty: SyncReset },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
97: Const {
|
|
dest: StatePartIndex<BigSlots>(25), // (0x0) SlotDebugData { name: "", ty: UInt<6> },
|
|
value: 0x0,
|
|
},
|
|
98: Copy {
|
|
dest: StatePartIndex<BigSlots>(26), // (0x0) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(25), // (0x0) SlotDebugData { name: "", ty: UInt<6> },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:12:1
|
|
99: BranchIfZero {
|
|
target: 107,
|
|
value: StatePartIndex<BigSlots>(2), // (0x1) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::en", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:13:1
|
|
100: BranchIfZero {
|
|
target: 102,
|
|
value: StatePartIndex<BigSlots>(46), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:14:1
|
|
101: Copy {
|
|
dest: StatePartIndex<BigSlots>(24), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg$next", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(26), // (0x0) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:13:1
|
|
102: BranchIfNonZero {
|
|
target: 107,
|
|
value: StatePartIndex<BigSlots>(46), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:15:1
|
|
103: BranchIfZero {
|
|
target: 105,
|
|
value: StatePartIndex<BigSlots>(48), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:16:1
|
|
104: Copy {
|
|
dest: StatePartIndex<BigSlots>(24), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg$next", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(65), // (0xd) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:15:1
|
|
105: BranchIfNonZero {
|
|
target: 107,
|
|
value: StatePartIndex<BigSlots>(48), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:17:1
|
|
106: Copy {
|
|
dest: StatePartIndex<BigSlots>(24), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg$next", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(87), // (0x3e) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:11:1
|
|
107: IsNonZeroDestIsSmall {
|
|
dest: StatePartIndex<SmallSlots>(4), // (0x1 1) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(0), // (0x1) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::cd.clk", ty: Clock },
|
|
},
|
|
108: AndSmall {
|
|
dest: StatePartIndex<SmallSlots>(3), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
lhs: StatePartIndex<SmallSlots>(4), // (0x1 1) SlotDebugData { name: "", ty: Bool },
|
|
rhs: StatePartIndex<SmallSlots>(2), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:10:1
|
|
109: Copy {
|
|
dest: StatePartIndex<BigSlots>(15), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b2_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
src: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
110: Copy {
|
|
dest: StatePartIndex<BigSlots>(18), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
src: StatePartIndex<BigSlots>(15), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b2_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
},
|
|
111: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(19), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(18), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
start: 1,
|
|
len: 2,
|
|
},
|
|
112: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(20), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(19), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 0,
|
|
len: 1,
|
|
},
|
|
113: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(21), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(19), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 1,
|
|
len: 1,
|
|
},
|
|
114: Copy {
|
|
dest: StatePartIndex<BigSlots>(22), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(21), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
115: Copy {
|
|
dest: StatePartIndex<BigSlots>(16), // (0x0) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(20), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
116: Copy {
|
|
dest: StatePartIndex<BigSlots>(17), // (0x0) SlotDebugData { name: ".1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(22), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:9:1
|
|
117: AndBigWithSmallImmediate {
|
|
dest: StatePartIndex<SmallSlots>(1), // (0x0 0) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome} },
|
|
lhs: StatePartIndex<BigSlots>(15), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b2_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
rhs: 0x1,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
118: Copy {
|
|
dest: StatePartIndex<BigSlots>(10), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
src: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
},
|
|
119: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(11), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
src: StatePartIndex<BigSlots>(10), // (0x0) SlotDebugData { name: "", ty: UInt<3> },
|
|
start: 1,
|
|
len: 2,
|
|
},
|
|
120: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(12), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(11), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 0,
|
|
len: 1,
|
|
},
|
|
121: SliceInt {
|
|
dest: StatePartIndex<BigSlots>(13), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(11), // (0x0) SlotDebugData { name: "", ty: UInt<2> },
|
|
start: 1,
|
|
len: 1,
|
|
},
|
|
122: Copy {
|
|
dest: StatePartIndex<BigSlots>(14), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(13), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
123: Copy {
|
|
dest: StatePartIndex<BigSlots>(8), // (0x0) SlotDebugData { name: ".0", ty: UInt<1> },
|
|
src: StatePartIndex<BigSlots>(12), // (0x0) SlotDebugData { name: "", ty: UInt<1> },
|
|
},
|
|
124: Copy {
|
|
dest: StatePartIndex<BigSlots>(9), // (0x0) SlotDebugData { name: ".1", ty: Bool },
|
|
src: StatePartIndex<BigSlots>(14), // (0x0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:8:1
|
|
125: AndBigWithSmallImmediate {
|
|
dest: StatePartIndex<SmallSlots>(0), // (0x0 0) SlotDebugData { name: "", ty: Enum {HdlNone, HdlSome} },
|
|
lhs: StatePartIndex<BigSlots>(7), // (0x0) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::b_out", ty: Enum {HdlNone, HdlSome(Bundle {0: UInt<1>, 1: Bool})} },
|
|
rhs: 0x1,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:11:1
|
|
126: BranchIfSmallZero {
|
|
target: 131,
|
|
value: StatePartIndex<SmallSlots>(3), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
127: BranchIfSmallNonZero {
|
|
target: 130,
|
|
value: StatePartIndex<SmallSlots>(5), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
},
|
|
128: Copy {
|
|
dest: StatePartIndex<BigSlots>(23), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(24), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg$next", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
129: Branch {
|
|
target: 131,
|
|
},
|
|
130: Copy {
|
|
dest: StatePartIndex<BigSlots>(23), // (0x3e) SlotDebugData { name: "InstantiatedModule(enums: enums).enums::the_reg", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
src: StatePartIndex<BigSlots>(26), // (0x0) SlotDebugData { name: "", ty: Enum {A, B(Bundle {0: UInt<1>, 1: Bool}), C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>})} },
|
|
},
|
|
131: XorSmallImmediate {
|
|
dest: StatePartIndex<SmallSlots>(2), // (0x0 0) SlotDebugData { name: "", ty: Bool },
|
|
lhs: StatePartIndex<SmallSlots>(4), // (0x1 1) SlotDebugData { name: "", ty: Bool },
|
|
rhs: 0x1,
|
|
},
|
|
// at: module-XXXXXXXXXX.rs:1:1
|
|
132: Return,
|
|
],
|
|
..
|
|
},
|
|
pc: 132,
|
|
memory_write_log: [],
|
|
memories: StatePart {
|
|
value: [],
|
|
},
|
|
small_slots: StatePart {
|
|
value: [
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
1,
|
|
0,
|
|
2,
|
|
],
|
|
},
|
|
big_slots: StatePart {
|
|
value: [
|
|
1,
|
|
0,
|
|
1,
|
|
2,
|
|
15,
|
|
2,
|
|
15,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
62,
|
|
62,
|
|
0,
|
|
0,
|
|
1,
|
|
1,
|
|
62,
|
|
3,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
-1,
|
|
1,
|
|
1,
|
|
15,
|
|
3,
|
|
1,
|
|
1,
|
|
3,
|
|
-1,
|
|
0,
|
|
0,
|
|
1,
|
|
0,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
2,
|
|
3,
|
|
12,
|
|
13,
|
|
13,
|
|
13,
|
|
2,
|
|
1,
|
|
1,
|
|
-1,
|
|
2,
|
|
1,
|
|
1,
|
|
-1,
|
|
1,
|
|
1,
|
|
1,
|
|
3,
|
|
-1,
|
|
2,
|
|
3,
|
|
3,
|
|
12,
|
|
15,
|
|
60,
|
|
62,
|
|
62,
|
|
62,
|
|
0,
|
|
0,
|
|
0,
|
|
1,
|
|
2,
|
|
3,
|
|
3,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
2,
|
|
3,
|
|
6,
|
|
7,
|
|
7,
|
|
7,
|
|
2,
|
|
3,
|
|
3,
|
|
12,
|
|
15,
|
|
],
|
|
},
|
|
},
|
|
io: Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
},
|
|
main_module: SimulationModuleState {
|
|
base_targets: [
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.cd,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.en,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.which_in,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.data_in,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.which_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.data_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.b_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.b2_out,
|
|
],
|
|
uninitialized_ios: {},
|
|
io_targets: {
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.b2_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.b_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.cd,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.cd.clk,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.cd.rst,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.data_in,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.data_out,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.en,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.which_in,
|
|
Instance {
|
|
name: <simulator>::enums,
|
|
instantiated: Module {
|
|
name: enums,
|
|
..
|
|
},
|
|
}.which_out,
|
|
},
|
|
did_initial_settle: true,
|
|
},
|
|
extern_modules: [],
|
|
state_ready_to_run: false,
|
|
trace_decls: TraceModule {
|
|
name: "enums",
|
|
children: [
|
|
TraceModuleIO {
|
|
name: "cd",
|
|
child: TraceBundle {
|
|
name: "cd",
|
|
fields: [
|
|
TraceClock {
|
|
location: TraceScalarId(0),
|
|
name: "clk",
|
|
flow: Source,
|
|
},
|
|
TraceSyncReset {
|
|
location: TraceScalarId(1),
|
|
name: "rst",
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
clk: Clock,
|
|
/* offset = 1 */
|
|
rst: SyncReset,
|
|
},
|
|
flow: Source,
|
|
},
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
clk: Clock,
|
|
/* offset = 1 */
|
|
rst: SyncReset,
|
|
},
|
|
flow: Source,
|
|
},
|
|
TraceModuleIO {
|
|
name: "en",
|
|
child: TraceBool {
|
|
location: TraceScalarId(2),
|
|
name: "en",
|
|
flow: Source,
|
|
},
|
|
ty: Bool,
|
|
flow: Source,
|
|
},
|
|
TraceModuleIO {
|
|
name: "which_in",
|
|
child: TraceUInt {
|
|
location: TraceScalarId(3),
|
|
name: "which_in",
|
|
ty: UInt<2>,
|
|
flow: Source,
|
|
},
|
|
ty: UInt<2>,
|
|
flow: Source,
|
|
},
|
|
TraceModuleIO {
|
|
name: "data_in",
|
|
child: TraceUInt {
|
|
location: TraceScalarId(4),
|
|
name: "data_in",
|
|
ty: UInt<4>,
|
|
flow: Source,
|
|
},
|
|
ty: UInt<4>,
|
|
flow: Source,
|
|
},
|
|
TraceModuleIO {
|
|
name: "which_out",
|
|
child: TraceUInt {
|
|
location: TraceScalarId(5),
|
|
name: "which_out",
|
|
ty: UInt<2>,
|
|
flow: Sink,
|
|
},
|
|
ty: UInt<2>,
|
|
flow: Sink,
|
|
},
|
|
TraceModuleIO {
|
|
name: "data_out",
|
|
child: TraceUInt {
|
|
location: TraceScalarId(6),
|
|
name: "data_out",
|
|
ty: UInt<4>,
|
|
flow: Sink,
|
|
},
|
|
ty: UInt<4>,
|
|
flow: Sink,
|
|
},
|
|
TraceModuleIO {
|
|
name: "b_out",
|
|
child: TraceEnumWithFields {
|
|
name: "b_out",
|
|
discriminant: TraceEnumDiscriminant {
|
|
location: TraceScalarId(7),
|
|
name: "$tag",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
non_empty_fields: [
|
|
TraceBundle {
|
|
name: "HdlSome",
|
|
fields: [
|
|
TraceUInt {
|
|
location: TraceScalarId(8),
|
|
name: "0",
|
|
ty: UInt<1>,
|
|
flow: Source,
|
|
},
|
|
TraceBool {
|
|
location: TraceScalarId(9),
|
|
name: "1",
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
0: UInt<1>,
|
|
/* offset = 1 */
|
|
1: Bool,
|
|
},
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
TraceModuleIO {
|
|
name: "b2_out",
|
|
child: TraceEnumWithFields {
|
|
name: "b2_out",
|
|
discriminant: TraceEnumDiscriminant {
|
|
location: TraceScalarId(10),
|
|
name: "$tag",
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
non_empty_fields: [
|
|
TraceBundle {
|
|
name: "HdlSome",
|
|
fields: [
|
|
TraceUInt {
|
|
location: TraceScalarId(11),
|
|
name: "0",
|
|
ty: UInt<1>,
|
|
flow: Source,
|
|
},
|
|
TraceBool {
|
|
location: TraceScalarId(12),
|
|
name: "1",
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
0: UInt<1>,
|
|
/* offset = 1 */
|
|
1: Bool,
|
|
},
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
flow: Sink,
|
|
},
|
|
TraceReg {
|
|
name: "the_reg",
|
|
child: TraceEnumWithFields {
|
|
name: "the_reg",
|
|
discriminant: TraceEnumDiscriminant {
|
|
location: TraceScalarId(13),
|
|
name: "$tag",
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
flow: Duplex,
|
|
},
|
|
non_empty_fields: [
|
|
TraceBundle {
|
|
name: "B",
|
|
fields: [
|
|
TraceUInt {
|
|
location: TraceScalarId(14),
|
|
name: "0",
|
|
ty: UInt<1>,
|
|
flow: Source,
|
|
},
|
|
TraceBool {
|
|
location: TraceScalarId(15),
|
|
name: "1",
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
0: UInt<1>,
|
|
/* offset = 1 */
|
|
1: Bool,
|
|
},
|
|
flow: Source,
|
|
},
|
|
TraceBundle {
|
|
name: "C",
|
|
fields: [
|
|
TraceArray {
|
|
name: "a",
|
|
elements: [
|
|
TraceUInt {
|
|
location: TraceScalarId(16),
|
|
name: "[0]",
|
|
ty: UInt<1>,
|
|
flow: Source,
|
|
},
|
|
TraceUInt {
|
|
location: TraceScalarId(17),
|
|
name: "[1]",
|
|
ty: UInt<1>,
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Array<UInt<1>, 2>,
|
|
flow: Source,
|
|
},
|
|
TraceSInt {
|
|
location: TraceScalarId(18),
|
|
name: "b",
|
|
ty: SInt<2>,
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Bundle {
|
|
/* offset = 0 */
|
|
a: Array<UInt<1>, 2>,
|
|
/* offset = 2 */
|
|
b: SInt<2>,
|
|
},
|
|
flow: Source,
|
|
},
|
|
],
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
flow: Duplex,
|
|
},
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
],
|
|
},
|
|
traces: [
|
|
SimTrace {
|
|
id: TraceScalarId(0),
|
|
kind: BigClock {
|
|
index: StatePartIndex<BigSlots>(0),
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(1),
|
|
kind: BigSyncReset {
|
|
index: StatePartIndex<BigSlots>(1),
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(2),
|
|
kind: BigBool {
|
|
index: StatePartIndex<BigSlots>(2),
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(3),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(3),
|
|
ty: UInt<2>,
|
|
},
|
|
state: 0x2,
|
|
last_state: 0x2,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(4),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(4),
|
|
ty: UInt<4>,
|
|
},
|
|
state: 0xf,
|
|
last_state: 0xf,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(5),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(5),
|
|
ty: UInt<2>,
|
|
},
|
|
state: 0x2,
|
|
last_state: 0x2,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(6),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(6),
|
|
ty: UInt<4>,
|
|
},
|
|
state: 0xf,
|
|
last_state: 0xf,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(7),
|
|
kind: EnumDiscriminant {
|
|
index: StatePartIndex<SmallSlots>(0),
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(8),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(8),
|
|
ty: UInt<1>,
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(9),
|
|
kind: BigBool {
|
|
index: StatePartIndex<BigSlots>(9),
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(10),
|
|
kind: EnumDiscriminant {
|
|
index: StatePartIndex<SmallSlots>(1),
|
|
ty: Enum {
|
|
HdlNone,
|
|
HdlSome(Bundle {0: UInt<1>, 1: Bool}),
|
|
},
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(11),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(16),
|
|
ty: UInt<1>,
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(12),
|
|
kind: BigBool {
|
|
index: StatePartIndex<BigSlots>(17),
|
|
},
|
|
state: 0x0,
|
|
last_state: 0x0,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(13),
|
|
kind: EnumDiscriminant {
|
|
index: StatePartIndex<SmallSlots>(6),
|
|
ty: Enum {
|
|
A,
|
|
B(Bundle {0: UInt<1>, 1: Bool}),
|
|
C(Bundle {a: Array<UInt<1>, 2>, b: SInt<2>}),
|
|
},
|
|
},
|
|
state: 0x2,
|
|
last_state: 0x2,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(14),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(27),
|
|
ty: UInt<1>,
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(15),
|
|
kind: BigBool {
|
|
index: StatePartIndex<BigSlots>(28),
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(16),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(34),
|
|
ty: UInt<1>,
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(17),
|
|
kind: BigUInt {
|
|
index: StatePartIndex<BigSlots>(35),
|
|
ty: UInt<1>,
|
|
},
|
|
state: 0x1,
|
|
last_state: 0x1,
|
|
},
|
|
SimTrace {
|
|
id: TraceScalarId(18),
|
|
kind: BigSInt {
|
|
index: StatePartIndex<BigSlots>(36),
|
|
ty: SInt<2>,
|
|
},
|
|
state: 0x3,
|
|
last_state: 0x3,
|
|
},
|
|
],
|
|
trace_memories: {},
|
|
trace_writers: [
|
|
Running(
|
|
VcdWriter {
|
|
finished_init: true,
|
|
timescale: 1 ps,
|
|
..
|
|
},
|
|
),
|
|
],
|
|
instant: 16 μs,
|
|
clocks_triggered: [
|
|
StatePartIndex<SmallSlots>(3),
|
|
],
|
|
..
|
|
} |