Line split page
dashboard | hierarchy | modlist | groups | tests | asserts
Go back

73 // Glue logic between rv_plic_reg_top and others 74 1/1 assign cc_id = irq_id_o; Tests: T1 T3 T4  75 76 always_comb begin 77 1/1 claim = '0; Tests: T1 T3 T4  78 1/1 for (int i = 0 ; i < NumTarget ; i++) begin Tests: T1 T3 T4  79 2/2 if (claim_re[i]) claim[claim_id[i]] = 1'b1; Tests: T1 T3 T4  | T1 T3 T4  MISSING_ELSE 80 end 81 end 82 always_comb begin 83 1/1 complete = '0; Tests: T1 T3 T4  84 1/1 for (int i = 0 ; i < NumTarget ; i++) begin Tests: T1 T3 T4  85 2/2 if (complete_we[i]) complete[complete_id[i]] = 1'b1; Tests: T1 T3 T4  | T1 T3 T4  MISSING_ELSE 86 end 87 end 88 89 //`ASSERT_PULSE(claimPulse, claim_re[i]) 90 //`ASSERT_PULSE(completePulse, complete_we[i]) 91 92 `ASSERT(onehot0Claim, $onehot0(claim_re)) 93 94 `ASSERT(onehot0Complete, $onehot0(complete_we)) 95 96 ////////////// 97 // Priority // 98 ////////////// 99 1/1 assign prio[0] = reg2hw.prio0.q; Tests: T251  100 1/1 assign prio[1] = reg2hw.prio1.q; Tests: T120 T121 T311  101 1/1 assign prio[2] = reg2hw.prio2.q; Tests: T120 T121 T311  102 1/1 assign prio[3] = reg2hw.prio3.q; Tests: T120 T121 T311  103 1/1 assign prio[4] = reg2hw.prio4.q; Tests: T120 T121 T311  104 1/1 assign prio[5] = reg2hw.prio5.q; Tests: T120 T121 T311  105 1/1 assign prio[6] = reg2hw.prio6.q; Tests: T120 T121 T311  106 1/1 assign prio[7] = reg2hw.prio7.q; Tests: T120 T121 T311  107 1/1 assign prio[8] = reg2hw.prio8.q; Tests: T120 T121 T311  108 1/1 assign prio[9] = reg2hw.prio9.q; Tests: T120 T121 T311  109 1/1 assign prio[10] = reg2hw.prio10.q; Tests: T24 T311 T122  110 1/1 assign prio[11] = reg2hw.prio11.q; Tests: T24 T311 T122  111 1/1 assign prio[12] = reg2hw.prio12.q; Tests: T24 T311 T122  112 1/1 assign prio[13] = reg2hw.prio13.q; Tests: T24 T311 T122  113 1/1 assign prio[14] = reg2hw.prio14.q; Tests: T24 T311 T122  114 1/1 assign prio[15] = reg2hw.prio15.q; Tests: T24 T311 T122  115 1/1 assign prio[16] = reg2hw.prio16.q; Tests: T24 T311 T122  116 1/1 assign prio[17] = reg2hw.prio17.q; Tests: T24 T311 T122  117 1/1 assign prio[18] = reg2hw.prio18.q; Tests: T24 T311 T122  118 1/1 assign prio[19] = reg2hw.prio19.q; Tests: T23 T311 T60  119 1/1 assign prio[20] = reg2hw.prio20.q; Tests: T23 T311 T60  120 1/1 assign prio[21] = reg2hw.prio21.q; Tests: T23 T311 T60  121 1/1 assign prio[22] = reg2hw.prio22.q; Tests: T23 T311 T60  122 1/1 assign prio[23] = reg2hw.prio23.q; Tests: T23 T311 T60  123 1/1 assign prio[24] = reg2hw.prio24.q; Tests: T23 T311 T60  124 1/1 assign prio[25] = reg2hw.prio25.q; Tests: T23 T311 T60  125 1/1 assign prio[26] = reg2hw.prio26.q; Tests: T23 T311 T60  126 1/1 assign prio[27] = reg2hw.prio27.q; Tests: T23 T311 T60  127 1/1 assign prio[28] = reg2hw.prio28.q; Tests: T311 T34 T61  128 1/1 assign prio[29] = reg2hw.prio29.q; Tests: T311 T34 T61  129 1/1 assign prio[30] = reg2hw.prio30.q; Tests: T311 T34 T61  130 1/1 assign prio[31] = reg2hw.prio31.q; Tests: T311 T34 T61  131 1/1 assign prio[32] = reg2hw.prio32.q; Tests: T311 T34 T61  132 1/1 assign prio[33] = reg2hw.prio33.q; Tests: T311 T34 T61  133 1/1 assign prio[34] = reg2hw.prio34.q; Tests: T311 T34 T61  134 1/1 assign prio[35] = reg2hw.prio35.q; Tests: T311 T34 T61  135 1/1 assign prio[36] = reg2hw.prio36.q; Tests: T311 T34 T61  136 1/1 assign prio[37] = reg2hw.prio37.q; Tests: T4 T311 T168  137 1/1 assign prio[38] = reg2hw.prio38.q; Tests: T4 T311 T168  138 1/1 assign prio[39] = reg2hw.prio39.q; Tests: T4 T311 T168  139 1/1 assign prio[40] = reg2hw.prio40.q; Tests: T4 T311 T168  140 1/1 assign prio[41] = reg2hw.prio41.q; Tests: T4 T311 T168  141 1/1 assign prio[42] = reg2hw.prio42.q; Tests: T4 T311 T168  142 1/1 assign prio[43] = reg2hw.prio43.q; Tests: T4 T311 T168  143 1/1 assign prio[44] = reg2hw.prio44.q; Tests: T4 T311 T168  144 1/1 assign prio[45] = reg2hw.prio45.q; Tests: T4 T311 T168  145 1/1 assign prio[46] = reg2hw.prio46.q; Tests: T4 T311 T168  146 1/1 assign prio[47] = reg2hw.prio47.q; Tests: T4 T311 T168  147 1/1 assign prio[48] = reg2hw.prio48.q; Tests: T4 T311 T168  148 1/1 assign prio[49] = reg2hw.prio49.q; Tests: T4 T311 T168  149 1/1 assign prio[50] = reg2hw.prio50.q; Tests: T4 T311 T168  150 1/1 assign prio[51] = reg2hw.prio51.q; Tests: T4 T311 T168  151 1/1 assign prio[52] = reg2hw.prio52.q; Tests: T4 T311 T168  152 1/1 assign prio[53] = reg2hw.prio53.q; Tests: T4 T311 T168  153 1/1 assign prio[54] = reg2hw.prio54.q; Tests: T4 T311 T168  154 1/1 assign prio[55] = reg2hw.prio55.q; Tests: T4 T311 T168  155 1/1 assign prio[56] = reg2hw.prio56.q; Tests: T4 T311 T168  156 1/1 assign prio[57] = reg2hw.prio57.q; Tests: T4 T311 T168  157 1/1 assign prio[58] = reg2hw.prio58.q; Tests: T4 T311 T168  158 1/1 assign prio[59] = reg2hw.prio59.q; Tests: T4 T311 T168  159 1/1 assign prio[60] = reg2hw.prio60.q; Tests: T4 T311 T168  160 1/1 assign prio[61] = reg2hw.prio61.q; Tests: T4 T311 T168  161 1/1 assign prio[62] = reg2hw.prio62.q; Tests: T4 T311 T168  162 1/1 assign prio[63] = reg2hw.prio63.q; Tests: T4 T311 T168  163 1/1 assign prio[64] = reg2hw.prio64.q; Tests: T4 T311 T168  164 1/1 assign prio[65] = reg2hw.prio65.q; Tests: T4 T311 T168  165 1/1 assign prio[66] = reg2hw.prio66.q; Tests: T4 T311 T168  166 1/1 assign prio[67] = reg2hw.prio67.q; Tests: T4 T311 T168  167 1/1 assign prio[68] = reg2hw.prio68.q; Tests: T4 T311 T168  168 1/1 assign prio[69] = reg2hw.prio69.q; Tests: T3 T4 T11  169 1/1 assign prio[70] = reg2hw.prio70.q; Tests: T11 T311 T168  170 1/1 assign prio[71] = reg2hw.prio71.q; Tests: T11 T311 T168  171 1/1 assign prio[72] = reg2hw.prio72.q; Tests: T3 T11 T8  172 1/1 assign prio[73] = reg2hw.prio73.q; Tests: T3 T11 T8  173 1/1 assign prio[74] = reg2hw.prio74.q; Tests: T11 T311 T168  174 1/1 assign prio[75] = reg2hw.prio75.q; Tests: T311 T168 T251  175 1/1 assign prio[76] = reg2hw.prio76.q; Tests: T311 T168 T251  176 1/1 assign prio[77] = reg2hw.prio77.q; Tests: T54 T311 T55  177 1/1 assign prio[78] = reg2hw.prio78.q; Tests: T54 T311 T55  178 1/1 assign prio[79] = reg2hw.prio79.q; Tests: T311 T168 T251  179 1/1 assign prio[80] = reg2hw.prio80.q; Tests: T54 T311 T55  180 1/1 assign prio[81] = reg2hw.prio81.q; Tests: T54 T311 T55  181 1/1 assign prio[82] = reg2hw.prio82.q; Tests: T54 T311 T55  182 1/1 assign prio[83] = reg2hw.prio83.q; Tests: T54 T311 T55  183 1/1 assign prio[84] = reg2hw.prio84.q; Tests: T54 T311 T55  184 1/1 assign prio[85] = reg2hw.prio85.q; Tests: T311 T168 T251  185 1/1 assign prio[86] = reg2hw.prio86.q; Tests: T53 T54 T311  186 1/1 assign prio[87] = reg2hw.prio87.q; Tests: T53 T311 T168  187 1/1 assign prio[88] = reg2hw.prio88.q; Tests: T311 T168 T251  188 1/1 assign prio[89] = reg2hw.prio89.q; Tests: T53 T311 T168  189 1/1 assign prio[90] = reg2hw.prio90.q; Tests: T53 T311 T168  190 1/1 assign prio[91] = reg2hw.prio91.q; Tests: T53 T311 T168  191 1/1 assign prio[92] = reg2hw.prio92.q; Tests: T56 T311 T57  192 1/1 assign prio[93] = reg2hw.prio93.q; Tests: T56 T311 T57  193 1/1 assign prio[94] = reg2hw.prio94.q; Tests: T311 T168 T251  194 1/1 assign prio[95] = reg2hw.prio95.q; Tests: T56 T311 T57  195 1/1 assign prio[96] = reg2hw.prio96.q; Tests: T56 T311 T57  196 1/1 assign prio[97] = reg2hw.prio97.q; Tests: T56 T311 T57  197 1/1 assign prio[98] = reg2hw.prio98.q; Tests: T56 T311 T57  198 1/1 assign prio[99] = reg2hw.prio99.q; Tests: T56 T311 T57  199 1/1 assign prio[100] = reg2hw.prio100.q; Tests: T311 T168 T251  200 1/1 assign prio[101] = reg2hw.prio101.q; Tests: T56 T311 T57  201 1/1 assign prio[102] = reg2hw.prio102.q; Tests: T311 T312 T168  202 1/1 assign prio[103] = reg2hw.prio103.q; Tests: T311 T168 T251  203 1/1 assign prio[104] = reg2hw.prio104.q; Tests: T311 T312 T168  204 1/1 assign prio[105] = reg2hw.prio105.q; Tests: T311 T312 T168  205 1/1 assign prio[106] = reg2hw.prio106.q; Tests: T311 T312 T168  206 1/1 assign prio[107] = reg2hw.prio107.q; Tests: T58 T311 T59  207 1/1 assign prio[108] = reg2hw.prio108.q; Tests: T58 T311 T59  208 1/1 assign prio[109] = reg2hw.prio109.q; Tests: T311 T168 T251  209 1/1 assign prio[110] = reg2hw.prio110.q; Tests: T58 T311 T59  210 1/1 assign prio[111] = reg2hw.prio111.q; Tests: T58 T311 T59  211 1/1 assign prio[112] = reg2hw.prio112.q; Tests: T58 T311 T59  212 1/1 assign prio[113] = reg2hw.prio113.q; Tests: T58 T311 T59  213 1/1 assign prio[114] = reg2hw.prio114.q; Tests: T58 T311 T59  214 1/1 assign prio[115] = reg2hw.prio115.q; Tests: T311 T168 T251  215 1/1 assign prio[116] = reg2hw.prio116.q; Tests: T58 T311 T59  216 1/1 assign prio[117] = reg2hw.prio117.q; Tests: T311 T168 T251  217 1/1 assign prio[118] = reg2hw.prio118.q; Tests: T311 T168 T251  218 1/1 assign prio[119] = reg2hw.prio119.q; Tests: T311 T168 T251  219 1/1 assign prio[120] = reg2hw.prio120.q; Tests: T311 T168 T251  220 1/1 assign prio[121] = reg2hw.prio121.q; Tests: T311 T168 T251  221 1/1 assign prio[122] = reg2hw.prio122.q; Tests: T27 T311 T126  222 1/1 assign prio[123] = reg2hw.prio123.q; Tests: T27 T311 T126  223 1/1 assign prio[124] = reg2hw.prio124.q; Tests: T311 T168 T251  224 1/1 assign prio[125] = reg2hw.prio125.q; Tests: T311 T168 T251  225 1/1 assign prio[126] = reg2hw.prio126.q; Tests: T311 T168 T251  226 1/1 assign prio[127] = reg2hw.prio127.q; Tests: T39 T75 T76  227 1/1 assign prio[128] = reg2hw.prio128.q; Tests: T39 T75 T76  228 1/1 assign prio[129] = reg2hw.prio129.q; Tests: T39 T75 T76  229 1/1 assign prio[130] = reg2hw.prio130.q; Tests: T39 T75 T76  230 1/1 assign prio[131] = reg2hw.prio131.q; Tests: T3 T8 T311  231 1/1 assign prio[132] = reg2hw.prio132.q; Tests: T3 T8 T311  232 1/1 assign prio[133] = reg2hw.prio133.q; Tests: T311 T168 T251  233 1/1 assign prio[134] = reg2hw.prio134.q; Tests: T311 T168 T251  234 1/1 assign prio[135] = reg2hw.prio135.q; Tests: T311 T168 T251  235 1/1 assign prio[136] = reg2hw.prio136.q; Tests: T311 T168 T251  236 1/1 assign prio[137] = reg2hw.prio137.q; Tests: T311 T168 T251  237 1/1 assign prio[138] = reg2hw.prio138.q; Tests: T311 T168 T251  238 1/1 assign prio[139] = reg2hw.prio139.q; Tests: T311 T168 T251  239 1/1 assign prio[140] = reg2hw.prio140.q; Tests: T311 T168 T251  240 1/1 assign prio[141] = reg2hw.prio141.q; Tests: T311 T168 T251  241 1/1 assign prio[142] = reg2hw.prio142.q; Tests: T311 T168 T251  242 1/1 assign prio[143] = reg2hw.prio143.q; Tests: T311 T168 T251  243 1/1 assign prio[144] = reg2hw.prio144.q; Tests: T311 T168 T251  244 1/1 assign prio[145] = reg2hw.prio145.q; Tests: T311 T168 T251  245 1/1 assign prio[146] = reg2hw.prio146.q; Tests: T311 T168 T251  246 1/1 assign prio[147] = reg2hw.prio147.q; Tests: T311 T168 T251  247 1/1 assign prio[148] = reg2hw.prio148.q; Tests: T311 T168 T251  248 1/1 assign prio[149] = reg2hw.prio149.q; Tests: T311 T168 T251  249 1/1 assign prio[150] = reg2hw.prio150.q; Tests: T311 T168 T251  250 1/1 assign prio[151] = reg2hw.prio151.q; Tests: T311 T168 T251  251 1/1 assign prio[152] = reg2hw.prio152.q; Tests: T311 T168 T251  252 1/1 assign prio[153] = reg2hw.prio153.q; Tests: T1 T22 T19  253 1/1 assign prio[154] = reg2hw.prio154.q; Tests: T63 T311 T213  254 1/1 assign prio[155] = reg2hw.prio155.q; Tests: T311 T129 T168  255 1/1 assign prio[156] = reg2hw.prio156.q; Tests: T39 T75 T76  256 1/1 assign prio[157] = reg2hw.prio157.q; Tests: T39 T75 T76  257 1/1 assign prio[158] = reg2hw.prio158.q; Tests: T161 T311 T162  258 1/1 assign prio[159] = reg2hw.prio159.q; Tests: T311 T168 T251  259 1/1 assign prio[160] = reg2hw.prio160.q; Tests: T178 T311 T313  260 1/1 assign prio[161] = reg2hw.prio161.q; Tests: T178 T311 T313  261 1/1 assign prio[162] = reg2hw.prio162.q; Tests: T178 T311 T313  262 1/1 assign prio[163] = reg2hw.prio163.q; Tests: T178 T311 T313  263 1/1 assign prio[164] = reg2hw.prio164.q; Tests: T178 T311 T313  264 1/1 assign prio[165] = reg2hw.prio165.q; Tests: T311 T168 T251  265 1/1 assign prio[166] = reg2hw.prio166.q; Tests: T314 T311 T315  266 1/1 assign prio[167] = reg2hw.prio167.q; Tests: T314 T311 T315  267 1/1 assign prio[168] = reg2hw.prio168.q; Tests: T311 T168 T251  268 1/1 assign prio[169] = reg2hw.prio169.q; Tests: T311 T168 T251  269 1/1 assign prio[170] = reg2hw.prio170.q; Tests: T311 T168 T251  270 1/1 assign prio[171] = reg2hw.prio171.q; Tests: T311 T168 T251  271 1/1 assign prio[172] = reg2hw.prio172.q; Tests: T147 T163 T311  272 1/1 assign prio[173] = reg2hw.prio173.q; Tests: T311 T168 T251  273 1/1 assign prio[174] = reg2hw.prio174.q; Tests: T311 T168 T251  274 1/1 assign prio[175] = reg2hw.prio175.q; Tests: T316 T311 T168  275 1/1 assign prio[176] = reg2hw.prio176.q; Tests: T311 T168 T251  276 1/1 assign prio[177] = reg2hw.prio177.q; Tests: T311 T168 T251  277 1/1 assign prio[178] = reg2hw.prio178.q; Tests: T311 T168 T251  278 1/1 assign prio[179] = reg2hw.prio179.q; Tests: T311 T9 T168  279 1/1 assign prio[180] = reg2hw.prio180.q; Tests: T311 T168 T251  280 1/1 assign prio[181] = reg2hw.prio181.q; Tests: T311 T168 T251  281 1/1 assign prio[182] = reg2hw.prio182.q; Tests: T316 T311 T168  282 1/1 assign prio[183] = reg2hw.prio183.q; Tests: T311 T168 T251  283 1/1 assign prio[184] = reg2hw.prio184.q; Tests: T316 T311 T168  284 1/1 assign prio[185] = reg2hw.prio185.q; Tests: T311 T168 T251  285 286 ////////////////////// 287 // Interrupt Enable // 288 ////////////////////// 289 for (genvar s = 0; s < 186; s++) begin : gen_ie0 290 186/186 assign ie[0][s] = reg2hw.ie0[s].q; Tests: T251  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T120 T121 T311  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T24 T311 T122  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T23 T311 T60  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T311 T34 T61  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T4 T311 T168  | T3 T4 T11  | T11 T311 T168  | T11 T311 T168  | T3 T11 T8  | T3 T11 T8  | T11 T311 T168  | T311 T168 T251  | T311 T168 T251  | T54 T311 T55  | T54 T311 T55  | T311 T168 T251  | T54 T311 T55  | T54 T311 T55  | T54 T311 T55  | T54 T311 T55  | T54 T311 T55  | T311 T168 T251  | T53 T54 T311  | T53 T311 T168  | T311 T168 T251  | T53 T311 T168  | T53 T311 T168  | T53 T311 T168  | T56 T311 T57  | T56 T311 T57  | T311 T168 T251  | T56 T311 T57  | T56 T311 T57  | T56 T311 T57  | T56 T311 T57  | T56 T311 T57  | T311 T168 T251  | T56 T311 T57  | T311 T312 T168  | T311 T168 T251  | T311 T312 T168  | T311 T312 T168  | T311 T312 T168  | T58 T311 T59  | T58 T311 T59  | T311 T168 T251  | T58 T311 T59  | T58 T311 T59  | T58 T311 T59  | T58 T311 T59  | T58 T311 T59  | T311 T168 T251  | T58 T311 T59  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T27 T311 T126  | T27 T311 T126  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T39 T75 T76  | T39 T75 T76  | T39 T75 T76  | T39 T75 T76  | T3 T8 T311  | T3 T8 T311  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T1 T22 T19  | T63 T311 T213  | T311 T129 T168  | T39 T75 T76  | T39 T75 T76  | T161 T311 T162  | T311 T168 T251  | T178 T311 T313  | T178 T311 T313  | T178 T311 T313  | T178 T311 T313  | T178 T311 T313  | T311 T168 T251  | T314 T311 T315  | T314 T311 T315  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T147 T163 T311  | T311 T168 T251  | T311 T168 T251  | T316 T311 T168  | T311 T168 T251  | T311 T168 T251  | T311 T168 T251  | T311 T9 T168  | T311 T168 T251  | T311 T168 T251  | T316 T311 T168  | T311 T168 T251  | T316 T311 T168  | T311 T168 T251  291 end 292 293 //////////////////////// 294 // THRESHOLD register // 295 //////////////////////// 296 0/1 ==> assign threshold[0] = reg2hw.threshold0.q; 297 298 ///////////////// 299 // CC register // 300 ///////////////// 301 1/1 assign claim_re[0] = reg2hw.cc0.re; Tests: T1 T3 T4  302 1/1 assign claim_id[0] = irq_id_o[0]; Tests: T1 T3 T4  303 1/1 assign complete_we[0] = reg2hw.cc0.qe; Tests: T1 T3 T4  304 1/1 assign complete_id[0] = reg2hw.cc0.q; Tests: T1 T3 T4  305 1/1 assign hw2reg.cc0.d = cc_id[0]; Tests: T1 T3 T4  306 307 /////////////////// 308 // MSIP register // 309 /////////////////// 310 1/1 assign msip_o[0] = reg2hw.msip0.q; Tests: T251 T252  311 312 //////// 313 // IP // 314 //////// 315 for (genvar s = 0; s < 186; s++) begin : gen_ip 316 assign hw2reg.ip[s].de = 1'b1; // Always write 317 185/186 ==> assign hw2reg.ip[s].d = ip[s]; Tests: T120 T121 T317  | T120 T121 T317  | T120 T121 T317  | T120 T121 T317  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T120 T121 T317  | T24 T122 T123  | T24 T122 T123  | T24 T122 T123  | T24 T122 T123  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T24 T122 T123  | T23 T60 T318  | T23 T60 T318  | T23 T60 T318  | T23 T60 T318  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T23 T60 T318  | T34 T61 T318  | T34 T61 T318  | T34 T61 T318  | T34 T61 T318  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T34 T61 T318  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T4 T311 T320  | T3 T205 T168  | T168 T169  | T168 T169  | T168 T169  | T168 T169  | T11 T168 T43  | T168 T169  | T168 T169  | T54 T311 T55  | T54 T311 T55  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T53 T54 T311  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T56 T311 T57  | T56 T311 T57  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T56 T311 T57  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T58 T311 T59  | T58 T311 T59  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T58 T311 T59  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T27 T126 T168  | T168 T169  | T115 T116 T117  | T168 T169  | T168 T169  | T39 T172 T65  | T172 T92 T93  | T76 T311 T320  | T75 T172 T311  | T168 T169  | T168 T169  | T168 T169  | T168 T169  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T318 T319  | T1 T22 T19  | T63 T213 T318  | T311 T129 T320  | T28 T322 T289  | T172 T65 T235  | T161 T162 T168  | T168 T169  | T178 T311 T313  | T178 T311 T313  | T311 T323 T320  | T311 T323 T320  | T178 T311 T313  | T311 T320 T321  | T314 T311 T315  | T311 T320 T321  | T311 T320 T321  | T168 T169  | T168 T169  | T168 T169  | T147 T163 T135  | T168 T169  | T311 T320 T321  | T316 T311 T320  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T311 T320 T321  | T316 T311 T320  | T311 T320 T321  | T316 T311 T320  | T311 T320 T321  318 end 319 320 ////////////// 321 // Gateways // 322 ////////////// 323 324 // Synchronize all incoming interrupt requests. 325 logic [NumSrc-1:0] intr_src_synced; 326 prim_flop_2sync #( 327 .Width(NumSrc) 328 ) u_prim_flop_2sync ( 329 .clk_i, 330 .rst_ni, 331 .d_i(intr_src_i), 332 .q_o(intr_src_synced) 333 ); 334 335 rv_plic_gateway #( 336 .N_SOURCE (NumSrc) 337 ) u_gateway ( 338 .clk_i, 339 .rst_ni, 340 341 .src_i (intr_src_synced), 342 .le_i (LevelEdgeTrig), 343 344 .claim_i (claim), 345 .complete_i (complete), 346 347 .ip_o (ip) 348 ); 349 350 /////////////////////////////////// 351 // Target interrupt notification // 352 /////////////////////////////////// 353 for (genvar i = 0 ; i < NumTarget ; i++) begin : gen_target 354 rv_plic_target #( 355 .N_SOURCE (NumSrc), 356 .MAX_PRIO (MAX_PRIO) 357 ) u_target ( 358 .clk_i, 359 .rst_ni, 360 361 .ip_i (ip), 362 .ie_i (ie[i]), 363 364 .prio_i (prio), 365 .threshold_i (threshold[i]), 366 367 .irq_o (irq_o[i]), 368 .irq_id_o (irq_id_o[i]) 369 370 ); 371 end 372 373 //////////// 374 // Alerts // 375 //////////// 376 377 logic [NumAlerts-1:0] alert_test, alerts; 378 379 1/1 assign alert_test = { Tests: T1 T3 T4 
0% 10% 20% 30% 40% 50% 60% 70% 80% 90% 100%