mirror of
https://github.com/Silicon1602/srdl2sv.git
synced 2025-01-06 19:58:39 +00:00
Dennis
6359883c27
The software is now able to create most interrupt combinations of Section 9.9 of the SystemRDL 2.0 LRM. It supports stickybit/non-stickybit interrupts, it support posedge, negedge, bothedge, and level interrupts, and it is able to generate all surrounding logic. This commit also fixes a reset-bug that caused registers that were reset to 0 to be not reset (because 'if not reset_value' will return True if the 'reset_value' is 0).
57 lines
1.6 KiB
Plaintext
57 lines
1.6 KiB
Plaintext
addrmap interrupts {
|
|
signal { activelow; async; field_reset;} field_reset_n;
|
|
|
|
reg {
|
|
field {sw=rw; hw=rw; intr; } intr1 [0:0] = 0;
|
|
field {sw=rw; hw=rw; bothedge intr; } intr2 [1:1] = 0;
|
|
field {sw=rw; hw=rw; negedge intr; } intr3 [2:2] = 0;
|
|
field {sw=rw; hw=rw; posedge intr; } intr4 [3:3] = 0;
|
|
field {sw=rw; hw=rw; } intr5 [4:4] = 0;
|
|
field {sw=rw; hw=rw; nonsticky intr;} intr6 [5:5] = 0;
|
|
} itrs_reg;
|
|
|
|
reg {
|
|
field {sw=rw; hw=r;} intr1 [0:0];
|
|
field {sw=rw; hw=r;} intr2 [1:1];
|
|
} itrs_mask;
|
|
|
|
reg {
|
|
field {sw=rw; hw=r;} intr5 [1:1];
|
|
} itrs_enable;
|
|
|
|
reg {
|
|
field {sw=rw; hw=r;} intr6 [1:1];
|
|
} itrs_next_assign;
|
|
|
|
itrs_reg.intr1->mask = itrs_mask.intr1;
|
|
itrs_reg.intr2->mask = itrs_mask.intr2;
|
|
itrs_reg.intr5->enable = itrs_enable.intr5;
|
|
itrs_reg.intr5->next = itrs_next_assign.intr6;
|
|
|
|
|
|
// HALT REGISTERS
|
|
reg {
|
|
field {sw=rw; hw=rw; intr;} intr1 [0:0];
|
|
field {sw=rw; hw=rw; intr;} intr2 [1:1];
|
|
field {sw=rw; hw=rw; intr;} intr3 [2:2];
|
|
field {sw=rw; hw=rw; } intr4 [3:3];
|
|
field {sw=rw; hw=rw; intr;} intr5 [4:4];
|
|
} itrs_halteable_reg;
|
|
|
|
reg {
|
|
field {sw=rw; hw=r;} intr1 [0:0];
|
|
field {sw=rw; hw=r;} intr2 [1:1];
|
|
} itrs_halt;
|
|
|
|
itrs_halteable_reg.intr1->haltmask = itrs_halt.intr1;
|
|
itrs_halteable_reg.intr2->haltmask = itrs_halt.intr2;
|
|
|
|
// USE INTERRUPT
|
|
reg {
|
|
field {sw=rw; hw=rw;} itrs_reg_next [0:0];
|
|
field {sw=rw; hw=rw;} itrs_halteable_next [1:1];
|
|
} itrs_next;
|
|
|
|
itrs_next.itrs_reg_next->next = itrs_reg->intr;
|
|
};
|