From f47aa372d76b59d988cab59099c60e253f130c0f Mon Sep 17 00:00:00 2001 From: waleed-lm Date: Thu, 8 Oct 2020 13:26:24 +0500 Subject: [PATCH] Read fixed --- el2_ifu_iccm_mem.fir | 963 +++++++++--------- el2_ifu_iccm_mem.v | 472 ++++----- src/main/scala/ifu/el2_ifu_iccm_mem.scala | 5 +- .../classes/ifu/el2_ifu_iccm_mem.class | Bin 93588 -> 93647 bytes target/scala-2.12/classes/ifu/ifu_iccm$.class | Bin 3884 -> 3884 bytes .../ifu/ifu_iccm$delayedInit$body.class | Bin 743 -> 743 bytes 6 files changed, 723 insertions(+), 717 deletions(-) diff --git a/el2_ifu_iccm_mem.fir b/el2_ifu_iccm_mem.fir index 047ef878..fa36e90b 100644 --- a/el2_ifu_iccm_mem.fir +++ b/el2_ifu_iccm_mem.fir @@ -79,501 +79,506 @@ circuit el2_ifu_iccm_mem : node iccm_clken_2 = or(_T_51, io.clk_override) @[el2_ifu_iccm_mem.scala 36:87] node _T_52 = or(wren_bank_3, rden_bank_3) @[el2_ifu_iccm_mem.scala 36:72] node iccm_clken_3 = or(_T_52, io.clk_override) @[el2_ifu_iccm_mem.scala 36:87] - node _T_53 = bits(wren_bank_0, 0, 0) @[el2_ifu_iccm_mem.scala 38:69] - node _T_54 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 38:92] - node _T_55 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 39:23] - node _T_56 = eq(_T_55, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 39:41] - node _T_57 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 39:62] - node _T_58 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:112] - node _T_59 = mux(_T_56, _T_57, _T_58) @[el2_ifu_iccm_mem.scala 39:8] - node addr_bank_0 = mux(_T_53, _T_54, _T_59) @[el2_ifu_iccm_mem.scala 38:55] - node _T_60 = bits(wren_bank_1, 0, 0) @[el2_ifu_iccm_mem.scala 38:69] - node _T_61 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 38:92] - node _T_62 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 39:23] - node _T_63 = eq(_T_62, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 39:41] - node _T_64 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 39:62] - node _T_65 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:112] - node _T_66 = mux(_T_63, _T_64, _T_65) @[el2_ifu_iccm_mem.scala 39:8] - node addr_bank_1 = mux(_T_60, _T_61, _T_66) @[el2_ifu_iccm_mem.scala 38:55] - node _T_67 = bits(wren_bank_2, 0, 0) @[el2_ifu_iccm_mem.scala 38:69] - node _T_68 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 38:92] - node _T_69 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 39:23] - node _T_70 = eq(_T_69, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 39:41] - node _T_71 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 39:62] - node _T_72 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:112] - node _T_73 = mux(_T_70, _T_71, _T_72) @[el2_ifu_iccm_mem.scala 39:8] - node addr_bank_2 = mux(_T_67, _T_68, _T_73) @[el2_ifu_iccm_mem.scala 38:55] - node _T_74 = bits(wren_bank_3, 0, 0) @[el2_ifu_iccm_mem.scala 38:69] - node _T_75 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 38:92] - node _T_76 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 39:23] - node _T_77 = eq(_T_76, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 39:41] - node _T_78 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 39:62] - node _T_79 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:112] - node _T_80 = mux(_T_77, _T_78, _T_79) @[el2_ifu_iccm_mem.scala 39:8] - node addr_bank_3 = mux(_T_74, _T_75, _T_80) @[el2_ifu_iccm_mem.scala 38:55] - cmem _T_81 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 42:51] - cmem _T_82 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 42:51] - cmem _T_83 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 42:51] - cmem _T_84 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 42:51] - node _T_85 = and(iccm_clken_0, wren_bank_0) @[el2_ifu_iccm_mem.scala 46:68] - node _T_86 = and(iccm_clken_1, wren_bank_1) @[el2_ifu_iccm_mem.scala 46:68] - node _T_87 = and(iccm_clken_2, wren_bank_2) @[el2_ifu_iccm_mem.scala 46:68] - node _T_88 = and(iccm_clken_3, wren_bank_3) @[el2_ifu_iccm_mem.scala 46:68] - wire write_vec : UInt<1>[4] @[el2_ifu_iccm_mem.scala 46:51] - write_vec[0] <= _T_85 @[el2_ifu_iccm_mem.scala 46:51] - write_vec[1] <= _T_86 @[el2_ifu_iccm_mem.scala 46:51] - write_vec[2] <= _T_87 @[el2_ifu_iccm_mem.scala 46:51] - write_vec[3] <= _T_88 @[el2_ifu_iccm_mem.scala 46:51] - node _T_89 = eq(wren_bank_0, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 47:72] - node _T_90 = and(iccm_clken_0, _T_89) @[el2_ifu_iccm_mem.scala 47:70] - node _T_91 = eq(wren_bank_1, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 47:72] - node _T_92 = and(iccm_clken_1, _T_91) @[el2_ifu_iccm_mem.scala 47:70] - node _T_93 = eq(wren_bank_2, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 47:72] - node _T_94 = and(iccm_clken_2, _T_93) @[el2_ifu_iccm_mem.scala 47:70] - node _T_95 = eq(wren_bank_3, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 47:72] - node _T_96 = and(iccm_clken_3, _T_95) @[el2_ifu_iccm_mem.scala 47:70] - wire read_enable : UInt<1>[4] @[el2_ifu_iccm_mem.scala 47:53] - read_enable[0] <= _T_90 @[el2_ifu_iccm_mem.scala 47:53] - read_enable[1] <= _T_92 @[el2_ifu_iccm_mem.scala 47:53] - read_enable[2] <= _T_94 @[el2_ifu_iccm_mem.scala 47:53] - read_enable[3] <= _T_96 @[el2_ifu_iccm_mem.scala 47:53] - wire iccm_bank_dout : UInt<39>[4] @[el2_ifu_iccm_mem.scala 49:28] - when write_vec[0] : @[el2_ifu_iccm_mem.scala 53:54] - infer mport _T_97 = _T_81[addr_bank_0], clock @[el2_ifu_iccm_mem.scala 53:66] - _T_97 <= iccm_bank_wr_data[0] @[el2_ifu_iccm_mem.scala 53:81] - skip @[el2_ifu_iccm_mem.scala 53:54] - when write_vec[1] : @[el2_ifu_iccm_mem.scala 53:54] - infer mport _T_98 = _T_82[addr_bank_1], clock @[el2_ifu_iccm_mem.scala 53:66] - _T_98 <= iccm_bank_wr_data[1] @[el2_ifu_iccm_mem.scala 53:81] - skip @[el2_ifu_iccm_mem.scala 53:54] - when write_vec[2] : @[el2_ifu_iccm_mem.scala 53:54] - infer mport _T_99 = _T_83[addr_bank_2], clock @[el2_ifu_iccm_mem.scala 53:66] - _T_99 <= iccm_bank_wr_data[2] @[el2_ifu_iccm_mem.scala 53:81] - skip @[el2_ifu_iccm_mem.scala 53:54] - when write_vec[3] : @[el2_ifu_iccm_mem.scala 53:54] - infer mport _T_100 = _T_84[addr_bank_3], clock @[el2_ifu_iccm_mem.scala 53:66] - _T_100 <= iccm_bank_wr_data[3] @[el2_ifu_iccm_mem.scala 53:81] - skip @[el2_ifu_iccm_mem.scala 53:54] - read mport _T_101 = _T_81[addr_bank_0], clock @[el2_ifu_iccm_mem.scala 55:80] - reg _T_102 : UInt, clock @[el2_ifu_iccm_mem.scala 55:63] - _T_102 <= _T_101 @[el2_ifu_iccm_mem.scala 55:63] - iccm_bank_dout[0] <= _T_102 @[el2_ifu_iccm_mem.scala 55:53] - read mport _T_103 = _T_82[addr_bank_1], clock @[el2_ifu_iccm_mem.scala 55:80] - reg _T_104 : UInt, clock @[el2_ifu_iccm_mem.scala 55:63] - _T_104 <= _T_103 @[el2_ifu_iccm_mem.scala 55:63] - iccm_bank_dout[1] <= _T_104 @[el2_ifu_iccm_mem.scala 55:53] - read mport _T_105 = _T_83[addr_bank_2], clock @[el2_ifu_iccm_mem.scala 55:80] - reg _T_106 : UInt, clock @[el2_ifu_iccm_mem.scala 55:63] - _T_106 <= _T_105 @[el2_ifu_iccm_mem.scala 55:63] - iccm_bank_dout[2] <= _T_106 @[el2_ifu_iccm_mem.scala 55:53] - read mport _T_107 = _T_84[addr_bank_3], clock @[el2_ifu_iccm_mem.scala 55:80] - reg _T_108 : UInt, clock @[el2_ifu_iccm_mem.scala 55:63] - _T_108 <= _T_107 @[el2_ifu_iccm_mem.scala 55:63] - iccm_bank_dout[3] <= _T_108 @[el2_ifu_iccm_mem.scala 55:53] - io.iccm_bank_addr[0] <= addr_bank_0 @[el2_ifu_iccm_mem.scala 60:21] - io.iccm_bank_addr[1] <= addr_bank_1 @[el2_ifu_iccm_mem.scala 60:21] - io.iccm_bank_addr[2] <= addr_bank_2 @[el2_ifu_iccm_mem.scala 60:21] - io.iccm_bank_addr[3] <= addr_bank_3 @[el2_ifu_iccm_mem.scala 60:21] + wire addr_bank : UInt<12>[4] @[el2_ifu_iccm_mem.scala 38:23] + node _T_53 = bits(wren_bank_0, 0, 0) @[el2_ifu_iccm_mem.scala 39:68] + node _T_54 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:91] + node _T_55 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 40:23] + node _T_56 = eq(_T_55, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 40:41] + node _T_57 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 40:62] + node _T_58 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 40:112] + node _T_59 = mux(_T_56, _T_57, _T_58) @[el2_ifu_iccm_mem.scala 40:8] + node _T_60 = mux(_T_53, _T_54, _T_59) @[el2_ifu_iccm_mem.scala 39:54] + addr_bank[0] <= _T_60 @[el2_ifu_iccm_mem.scala 39:48] + node _T_61 = bits(wren_bank_1, 0, 0) @[el2_ifu_iccm_mem.scala 39:68] + node _T_62 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:91] + node _T_63 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 40:23] + node _T_64 = eq(_T_63, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 40:41] + node _T_65 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 40:62] + node _T_66 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 40:112] + node _T_67 = mux(_T_64, _T_65, _T_66) @[el2_ifu_iccm_mem.scala 40:8] + node _T_68 = mux(_T_61, _T_62, _T_67) @[el2_ifu_iccm_mem.scala 39:54] + addr_bank[1] <= _T_68 @[el2_ifu_iccm_mem.scala 39:48] + node _T_69 = bits(wren_bank_2, 0, 0) @[el2_ifu_iccm_mem.scala 39:68] + node _T_70 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:91] + node _T_71 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 40:23] + node _T_72 = eq(_T_71, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 40:41] + node _T_73 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 40:62] + node _T_74 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 40:112] + node _T_75 = mux(_T_72, _T_73, _T_74) @[el2_ifu_iccm_mem.scala 40:8] + node _T_76 = mux(_T_69, _T_70, _T_75) @[el2_ifu_iccm_mem.scala 39:54] + addr_bank[2] <= _T_76 @[el2_ifu_iccm_mem.scala 39:48] + node _T_77 = bits(wren_bank_3, 0, 0) @[el2_ifu_iccm_mem.scala 39:68] + node _T_78 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 39:91] + node _T_79 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 40:23] + node _T_80 = eq(_T_79, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 40:41] + node _T_81 = bits(addr_bank_inc, 14, 3) @[el2_ifu_iccm_mem.scala 40:62] + node _T_82 = bits(io.iccm_rw_addr, 14, 3) @[el2_ifu_iccm_mem.scala 40:112] + node _T_83 = mux(_T_80, _T_81, _T_82) @[el2_ifu_iccm_mem.scala 40:8] + node _T_84 = mux(_T_77, _T_78, _T_83) @[el2_ifu_iccm_mem.scala 39:54] + addr_bank[3] <= _T_84 @[el2_ifu_iccm_mem.scala 39:48] + cmem _T_85 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 43:51] + cmem _T_86 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 43:51] + cmem _T_87 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 43:51] + cmem _T_88 : UInt<39>[4096] @[el2_ifu_iccm_mem.scala 43:51] + node _T_89 = and(iccm_clken_0, wren_bank_0) @[el2_ifu_iccm_mem.scala 47:68] + node _T_90 = and(iccm_clken_1, wren_bank_1) @[el2_ifu_iccm_mem.scala 47:68] + node _T_91 = and(iccm_clken_2, wren_bank_2) @[el2_ifu_iccm_mem.scala 47:68] + node _T_92 = and(iccm_clken_3, wren_bank_3) @[el2_ifu_iccm_mem.scala 47:68] + wire write_vec : UInt<1>[4] @[el2_ifu_iccm_mem.scala 47:51] + write_vec[0] <= _T_89 @[el2_ifu_iccm_mem.scala 47:51] + write_vec[1] <= _T_90 @[el2_ifu_iccm_mem.scala 47:51] + write_vec[2] <= _T_91 @[el2_ifu_iccm_mem.scala 47:51] + write_vec[3] <= _T_92 @[el2_ifu_iccm_mem.scala 47:51] + node _T_93 = eq(wren_bank_0, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 48:72] + node _T_94 = and(iccm_clken_0, _T_93) @[el2_ifu_iccm_mem.scala 48:70] + node _T_95 = eq(wren_bank_1, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 48:72] + node _T_96 = and(iccm_clken_1, _T_95) @[el2_ifu_iccm_mem.scala 48:70] + node _T_97 = eq(wren_bank_2, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 48:72] + node _T_98 = and(iccm_clken_2, _T_97) @[el2_ifu_iccm_mem.scala 48:70] + node _T_99 = eq(wren_bank_3, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 48:72] + node _T_100 = and(iccm_clken_3, _T_99) @[el2_ifu_iccm_mem.scala 48:70] + wire read_enable : UInt<1>[4] @[el2_ifu_iccm_mem.scala 48:53] + read_enable[0] <= _T_94 @[el2_ifu_iccm_mem.scala 48:53] + read_enable[1] <= _T_96 @[el2_ifu_iccm_mem.scala 48:53] + read_enable[2] <= _T_98 @[el2_ifu_iccm_mem.scala 48:53] + read_enable[3] <= _T_100 @[el2_ifu_iccm_mem.scala 48:53] + wire iccm_bank_dout : UInt<39>[4] @[el2_ifu_iccm_mem.scala 50:28] + when write_vec[0] : @[el2_ifu_iccm_mem.scala 54:54] + infer mport _T_101 = _T_85[addr_bank[0]], clock @[el2_ifu_iccm_mem.scala 54:66] + _T_101 <= iccm_bank_wr_data[0] @[el2_ifu_iccm_mem.scala 54:81] + skip @[el2_ifu_iccm_mem.scala 54:54] + when write_vec[1] : @[el2_ifu_iccm_mem.scala 54:54] + infer mport _T_102 = _T_86[addr_bank[1]], clock @[el2_ifu_iccm_mem.scala 54:66] + _T_102 <= iccm_bank_wr_data[1] @[el2_ifu_iccm_mem.scala 54:81] + skip @[el2_ifu_iccm_mem.scala 54:54] + when write_vec[2] : @[el2_ifu_iccm_mem.scala 54:54] + infer mport _T_103 = _T_87[addr_bank[2]], clock @[el2_ifu_iccm_mem.scala 54:66] + _T_103 <= iccm_bank_wr_data[2] @[el2_ifu_iccm_mem.scala 54:81] + skip @[el2_ifu_iccm_mem.scala 54:54] + when write_vec[3] : @[el2_ifu_iccm_mem.scala 54:54] + infer mport _T_104 = _T_88[addr_bank[3]], clock @[el2_ifu_iccm_mem.scala 54:66] + _T_104 <= iccm_bank_wr_data[3] @[el2_ifu_iccm_mem.scala 54:81] + skip @[el2_ifu_iccm_mem.scala 54:54] + read mport _T_105 = _T_85[addr_bank[0]], clock @[el2_ifu_iccm_mem.scala 56:80] + reg _T_106 : UInt, clock @[el2_ifu_iccm_mem.scala 56:63] + _T_106 <= _T_105 @[el2_ifu_iccm_mem.scala 56:63] + iccm_bank_dout[0] <= _T_106 @[el2_ifu_iccm_mem.scala 56:53] + read mport _T_107 = _T_86[addr_bank[1]], clock @[el2_ifu_iccm_mem.scala 56:80] + reg _T_108 : UInt, clock @[el2_ifu_iccm_mem.scala 56:63] + _T_108 <= _T_107 @[el2_ifu_iccm_mem.scala 56:63] + iccm_bank_dout[1] <= _T_108 @[el2_ifu_iccm_mem.scala 56:53] + read mport _T_109 = _T_87[addr_bank[2]], clock @[el2_ifu_iccm_mem.scala 56:80] + reg _T_110 : UInt, clock @[el2_ifu_iccm_mem.scala 56:63] + _T_110 <= _T_109 @[el2_ifu_iccm_mem.scala 56:63] + iccm_bank_dout[2] <= _T_110 @[el2_ifu_iccm_mem.scala 56:53] + read mport _T_111 = _T_88[addr_bank[3]], clock @[el2_ifu_iccm_mem.scala 56:80] + reg _T_112 : UInt, clock @[el2_ifu_iccm_mem.scala 56:63] + _T_112 <= _T_111 @[el2_ifu_iccm_mem.scala 56:63] + iccm_bank_dout[3] <= _T_112 @[el2_ifu_iccm_mem.scala 56:53] + io.iccm_bank_addr[0] <= addr_bank[0] @[el2_ifu_iccm_mem.scala 61:21] + io.iccm_bank_addr[1] <= addr_bank[1] @[el2_ifu_iccm_mem.scala 61:21] + io.iccm_bank_addr[2] <= addr_bank[2] @[el2_ifu_iccm_mem.scala 61:21] + io.iccm_bank_addr[3] <= addr_bank[3] @[el2_ifu_iccm_mem.scala 61:21] wire redundant_valid : UInt<2> redundant_valid <= UInt<1>("h00") - wire redundant_address : UInt<14>[2] @[el2_ifu_iccm_mem.scala 66:31] - redundant_address[0] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 67:21] - redundant_address[1] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 67:21] - node _T_109 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 69:67] - node _T_110 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 69:90] - node _T_111 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 69:128] - node _T_112 = eq(_T_110, _T_111) @[el2_ifu_iccm_mem.scala 69:105] - node _T_113 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 69:163] - node _T_114 = eq(_T_113, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 69:169] - node _T_115 = and(_T_112, _T_114) @[el2_ifu_iccm_mem.scala 69:145] - node _T_116 = and(_T_109, _T_115) @[el2_ifu_iccm_mem.scala 69:71] - node _T_117 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 70:22] - node _T_118 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:60] - node _T_119 = eq(_T_117, _T_118) @[el2_ifu_iccm_mem.scala 70:37] - node _T_120 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 70:93] - node _T_121 = eq(_T_120, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 70:99] - node _T_122 = and(_T_119, _T_121) @[el2_ifu_iccm_mem.scala 70:77] - node _T_123 = or(_T_116, _T_122) @[el2_ifu_iccm_mem.scala 69:179] - node _T_124 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 69:67] - node _T_125 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 69:90] - node _T_126 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 69:128] - node _T_127 = eq(_T_125, _T_126) @[el2_ifu_iccm_mem.scala 69:105] - node _T_128 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 69:163] - node _T_129 = eq(_T_128, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 69:169] - node _T_130 = and(_T_127, _T_129) @[el2_ifu_iccm_mem.scala 69:145] - node _T_131 = and(_T_124, _T_130) @[el2_ifu_iccm_mem.scala 69:71] - node _T_132 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 70:22] - node _T_133 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:60] - node _T_134 = eq(_T_132, _T_133) @[el2_ifu_iccm_mem.scala 70:37] - node _T_135 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 70:93] - node _T_136 = eq(_T_135, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 70:99] - node _T_137 = and(_T_134, _T_136) @[el2_ifu_iccm_mem.scala 70:77] - node _T_138 = or(_T_131, _T_137) @[el2_ifu_iccm_mem.scala 69:179] - node _T_139 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 69:67] - node _T_140 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 69:90] - node _T_141 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 69:128] - node _T_142 = eq(_T_140, _T_141) @[el2_ifu_iccm_mem.scala 69:105] - node _T_143 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 69:163] - node _T_144 = eq(_T_143, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 69:169] - node _T_145 = and(_T_142, _T_144) @[el2_ifu_iccm_mem.scala 69:145] - node _T_146 = and(_T_139, _T_145) @[el2_ifu_iccm_mem.scala 69:71] - node _T_147 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 70:22] - node _T_148 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:60] - node _T_149 = eq(_T_147, _T_148) @[el2_ifu_iccm_mem.scala 70:37] - node _T_150 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 70:93] - node _T_151 = eq(_T_150, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 70:99] - node _T_152 = and(_T_149, _T_151) @[el2_ifu_iccm_mem.scala 70:77] - node _T_153 = or(_T_146, _T_152) @[el2_ifu_iccm_mem.scala 69:179] - node _T_154 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 69:67] - node _T_155 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 69:90] - node _T_156 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 69:128] - node _T_157 = eq(_T_155, _T_156) @[el2_ifu_iccm_mem.scala 69:105] - node _T_158 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 69:163] - node _T_159 = eq(_T_158, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 69:169] - node _T_160 = and(_T_157, _T_159) @[el2_ifu_iccm_mem.scala 69:145] - node _T_161 = and(_T_154, _T_160) @[el2_ifu_iccm_mem.scala 69:71] - node _T_162 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 70:22] - node _T_163 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:60] - node _T_164 = eq(_T_162, _T_163) @[el2_ifu_iccm_mem.scala 70:37] - node _T_165 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 70:93] - node _T_166 = eq(_T_165, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 70:99] - node _T_167 = and(_T_164, _T_166) @[el2_ifu_iccm_mem.scala 70:77] - node _T_168 = or(_T_161, _T_167) @[el2_ifu_iccm_mem.scala 69:179] - node _T_169 = cat(_T_168, _T_153) @[Cat.scala 29:58] - node _T_170 = cat(_T_169, _T_138) @[Cat.scala 29:58] - node sel_red1 = cat(_T_170, _T_123) @[Cat.scala 29:58] - node _T_171 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 71:67] - node _T_172 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 71:90] - node _T_173 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 71:128] - node _T_174 = eq(_T_172, _T_173) @[el2_ifu_iccm_mem.scala 71:105] - node _T_175 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 71:163] - node _T_176 = eq(_T_175, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 71:169] - node _T_177 = and(_T_174, _T_176) @[el2_ifu_iccm_mem.scala 71:145] - node _T_178 = and(_T_171, _T_177) @[el2_ifu_iccm_mem.scala 71:71] - node _T_179 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 72:22] - node _T_180 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:60] - node _T_181 = eq(_T_179, _T_180) @[el2_ifu_iccm_mem.scala 72:37] - node _T_182 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 72:93] - node _T_183 = eq(_T_182, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 72:99] - node _T_184 = and(_T_181, _T_183) @[el2_ifu_iccm_mem.scala 72:77] - node _T_185 = or(_T_178, _T_184) @[el2_ifu_iccm_mem.scala 71:179] - node _T_186 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 71:67] - node _T_187 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 71:90] - node _T_188 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 71:128] - node _T_189 = eq(_T_187, _T_188) @[el2_ifu_iccm_mem.scala 71:105] - node _T_190 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 71:163] - node _T_191 = eq(_T_190, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 71:169] - node _T_192 = and(_T_189, _T_191) @[el2_ifu_iccm_mem.scala 71:145] - node _T_193 = and(_T_186, _T_192) @[el2_ifu_iccm_mem.scala 71:71] - node _T_194 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 72:22] - node _T_195 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:60] - node _T_196 = eq(_T_194, _T_195) @[el2_ifu_iccm_mem.scala 72:37] - node _T_197 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 72:93] - node _T_198 = eq(_T_197, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 72:99] - node _T_199 = and(_T_196, _T_198) @[el2_ifu_iccm_mem.scala 72:77] - node _T_200 = or(_T_193, _T_199) @[el2_ifu_iccm_mem.scala 71:179] - node _T_201 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 71:67] - node _T_202 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 71:90] - node _T_203 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 71:128] - node _T_204 = eq(_T_202, _T_203) @[el2_ifu_iccm_mem.scala 71:105] - node _T_205 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 71:163] - node _T_206 = eq(_T_205, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 71:169] - node _T_207 = and(_T_204, _T_206) @[el2_ifu_iccm_mem.scala 71:145] - node _T_208 = and(_T_201, _T_207) @[el2_ifu_iccm_mem.scala 71:71] - node _T_209 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 72:22] - node _T_210 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:60] - node _T_211 = eq(_T_209, _T_210) @[el2_ifu_iccm_mem.scala 72:37] - node _T_212 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 72:93] - node _T_213 = eq(_T_212, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 72:99] - node _T_214 = and(_T_211, _T_213) @[el2_ifu_iccm_mem.scala 72:77] - node _T_215 = or(_T_208, _T_214) @[el2_ifu_iccm_mem.scala 71:179] - node _T_216 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 71:67] - node _T_217 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 71:90] - node _T_218 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 71:128] - node _T_219 = eq(_T_217, _T_218) @[el2_ifu_iccm_mem.scala 71:105] - node _T_220 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 71:163] - node _T_221 = eq(_T_220, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 71:169] - node _T_222 = and(_T_219, _T_221) @[el2_ifu_iccm_mem.scala 71:145] - node _T_223 = and(_T_216, _T_222) @[el2_ifu_iccm_mem.scala 71:71] - node _T_224 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 72:22] - node _T_225 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:60] - node _T_226 = eq(_T_224, _T_225) @[el2_ifu_iccm_mem.scala 72:37] - node _T_227 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 72:93] - node _T_228 = eq(_T_227, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 72:99] - node _T_229 = and(_T_226, _T_228) @[el2_ifu_iccm_mem.scala 72:77] - node _T_230 = or(_T_223, _T_229) @[el2_ifu_iccm_mem.scala 71:179] - node _T_231 = cat(_T_230, _T_215) @[Cat.scala 29:58] - node _T_232 = cat(_T_231, _T_200) @[Cat.scala 29:58] - node sel_red0 = cat(_T_232, _T_185) @[Cat.scala 29:58] - reg sel_red0_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 74:27] - sel_red0_q <= sel_red0 @[el2_ifu_iccm_mem.scala 74:27] - reg sel_red1_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 75:27] - sel_red1_q <= sel_red1 @[el2_ifu_iccm_mem.scala 75:27] - wire redundant_data : UInt<39>[2] @[el2_ifu_iccm_mem.scala 76:28] - redundant_data[0] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 77:18] - redundant_data[1] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 77:18] - node _T_233 = bits(sel_red1_q, 0, 0) @[el2_ifu_iccm_mem.scala 79:47] - node _T_234 = bits(_T_233, 0, 0) @[el2_ifu_iccm_mem.scala 79:51] - node _T_235 = bits(sel_red0_q, 0, 0) @[el2_ifu_iccm_mem.scala 80:47] - node _T_236 = bits(_T_235, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] - node _T_237 = bits(sel_red0_q, 0, 0) @[el2_ifu_iccm_mem.scala 81:47] - node _T_238 = not(_T_237) @[el2_ifu_iccm_mem.scala 81:36] - node _T_239 = bits(sel_red1_q, 0, 0) @[el2_ifu_iccm_mem.scala 81:64] - node _T_240 = not(_T_239) @[el2_ifu_iccm_mem.scala 81:53] - node _T_241 = and(_T_238, _T_240) @[el2_ifu_iccm_mem.scala 81:51] - node _T_242 = bits(_T_241, 0, 0) @[el2_ifu_iccm_mem.scala 81:69] - node _T_243 = mux(_T_234, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_244 = mux(_T_236, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_245 = mux(_T_242, iccm_bank_dout[0], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_246 = or(_T_243, _T_244) @[Mux.scala 27:72] - node _T_247 = or(_T_246, _T_245) @[Mux.scala 27:72] + wire redundant_address : UInt<14>[2] @[el2_ifu_iccm_mem.scala 67:31] + redundant_address[0] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 68:21] + redundant_address[1] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 68:21] + node _T_113 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 70:67] + node _T_114 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 70:90] + node _T_115 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:128] + node _T_116 = eq(_T_114, _T_115) @[el2_ifu_iccm_mem.scala 70:105] + node _T_117 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 70:163] + node _T_118 = eq(_T_117, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 70:169] + node _T_119 = and(_T_116, _T_118) @[el2_ifu_iccm_mem.scala 70:145] + node _T_120 = and(_T_113, _T_119) @[el2_ifu_iccm_mem.scala 70:71] + node _T_121 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 71:22] + node _T_122 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 71:60] + node _T_123 = eq(_T_121, _T_122) @[el2_ifu_iccm_mem.scala 71:37] + node _T_124 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 71:93] + node _T_125 = eq(_T_124, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 71:99] + node _T_126 = and(_T_123, _T_125) @[el2_ifu_iccm_mem.scala 71:77] + node _T_127 = or(_T_120, _T_126) @[el2_ifu_iccm_mem.scala 70:179] + node _T_128 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 70:67] + node _T_129 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 70:90] + node _T_130 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:128] + node _T_131 = eq(_T_129, _T_130) @[el2_ifu_iccm_mem.scala 70:105] + node _T_132 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 70:163] + node _T_133 = eq(_T_132, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 70:169] + node _T_134 = and(_T_131, _T_133) @[el2_ifu_iccm_mem.scala 70:145] + node _T_135 = and(_T_128, _T_134) @[el2_ifu_iccm_mem.scala 70:71] + node _T_136 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 71:22] + node _T_137 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 71:60] + node _T_138 = eq(_T_136, _T_137) @[el2_ifu_iccm_mem.scala 71:37] + node _T_139 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 71:93] + node _T_140 = eq(_T_139, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 71:99] + node _T_141 = and(_T_138, _T_140) @[el2_ifu_iccm_mem.scala 71:77] + node _T_142 = or(_T_135, _T_141) @[el2_ifu_iccm_mem.scala 70:179] + node _T_143 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 70:67] + node _T_144 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 70:90] + node _T_145 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:128] + node _T_146 = eq(_T_144, _T_145) @[el2_ifu_iccm_mem.scala 70:105] + node _T_147 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 70:163] + node _T_148 = eq(_T_147, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 70:169] + node _T_149 = and(_T_146, _T_148) @[el2_ifu_iccm_mem.scala 70:145] + node _T_150 = and(_T_143, _T_149) @[el2_ifu_iccm_mem.scala 70:71] + node _T_151 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 71:22] + node _T_152 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 71:60] + node _T_153 = eq(_T_151, _T_152) @[el2_ifu_iccm_mem.scala 71:37] + node _T_154 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 71:93] + node _T_155 = eq(_T_154, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 71:99] + node _T_156 = and(_T_153, _T_155) @[el2_ifu_iccm_mem.scala 71:77] + node _T_157 = or(_T_150, _T_156) @[el2_ifu_iccm_mem.scala 70:179] + node _T_158 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 70:67] + node _T_159 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 70:90] + node _T_160 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 70:128] + node _T_161 = eq(_T_159, _T_160) @[el2_ifu_iccm_mem.scala 70:105] + node _T_162 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 70:163] + node _T_163 = eq(_T_162, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 70:169] + node _T_164 = and(_T_161, _T_163) @[el2_ifu_iccm_mem.scala 70:145] + node _T_165 = and(_T_158, _T_164) @[el2_ifu_iccm_mem.scala 70:71] + node _T_166 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 71:22] + node _T_167 = bits(redundant_address[1], 13, 0) @[el2_ifu_iccm_mem.scala 71:60] + node _T_168 = eq(_T_166, _T_167) @[el2_ifu_iccm_mem.scala 71:37] + node _T_169 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 71:93] + node _T_170 = eq(_T_169, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 71:99] + node _T_171 = and(_T_168, _T_170) @[el2_ifu_iccm_mem.scala 71:77] + node _T_172 = or(_T_165, _T_171) @[el2_ifu_iccm_mem.scala 70:179] + node _T_173 = cat(_T_172, _T_157) @[Cat.scala 29:58] + node _T_174 = cat(_T_173, _T_142) @[Cat.scala 29:58] + node sel_red1 = cat(_T_174, _T_127) @[Cat.scala 29:58] + node _T_175 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 72:67] + node _T_176 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 72:90] + node _T_177 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:128] + node _T_178 = eq(_T_176, _T_177) @[el2_ifu_iccm_mem.scala 72:105] + node _T_179 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 72:163] + node _T_180 = eq(_T_179, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 72:169] + node _T_181 = and(_T_178, _T_180) @[el2_ifu_iccm_mem.scala 72:145] + node _T_182 = and(_T_175, _T_181) @[el2_ifu_iccm_mem.scala 72:71] + node _T_183 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 73:22] + node _T_184 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 73:60] + node _T_185 = eq(_T_183, _T_184) @[el2_ifu_iccm_mem.scala 73:37] + node _T_186 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 73:93] + node _T_187 = eq(_T_186, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 73:99] + node _T_188 = and(_T_185, _T_187) @[el2_ifu_iccm_mem.scala 73:77] + node _T_189 = or(_T_182, _T_188) @[el2_ifu_iccm_mem.scala 72:179] + node _T_190 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 72:67] + node _T_191 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 72:90] + node _T_192 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:128] + node _T_193 = eq(_T_191, _T_192) @[el2_ifu_iccm_mem.scala 72:105] + node _T_194 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 72:163] + node _T_195 = eq(_T_194, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 72:169] + node _T_196 = and(_T_193, _T_195) @[el2_ifu_iccm_mem.scala 72:145] + node _T_197 = and(_T_190, _T_196) @[el2_ifu_iccm_mem.scala 72:71] + node _T_198 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 73:22] + node _T_199 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 73:60] + node _T_200 = eq(_T_198, _T_199) @[el2_ifu_iccm_mem.scala 73:37] + node _T_201 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 73:93] + node _T_202 = eq(_T_201, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 73:99] + node _T_203 = and(_T_200, _T_202) @[el2_ifu_iccm_mem.scala 73:77] + node _T_204 = or(_T_197, _T_203) @[el2_ifu_iccm_mem.scala 72:179] + node _T_205 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 72:67] + node _T_206 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 72:90] + node _T_207 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:128] + node _T_208 = eq(_T_206, _T_207) @[el2_ifu_iccm_mem.scala 72:105] + node _T_209 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 72:163] + node _T_210 = eq(_T_209, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 72:169] + node _T_211 = and(_T_208, _T_210) @[el2_ifu_iccm_mem.scala 72:145] + node _T_212 = and(_T_205, _T_211) @[el2_ifu_iccm_mem.scala 72:71] + node _T_213 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 73:22] + node _T_214 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 73:60] + node _T_215 = eq(_T_213, _T_214) @[el2_ifu_iccm_mem.scala 73:37] + node _T_216 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 73:93] + node _T_217 = eq(_T_216, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 73:99] + node _T_218 = and(_T_215, _T_217) @[el2_ifu_iccm_mem.scala 73:77] + node _T_219 = or(_T_212, _T_218) @[el2_ifu_iccm_mem.scala 72:179] + node _T_220 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 72:67] + node _T_221 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 72:90] + node _T_222 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 72:128] + node _T_223 = eq(_T_221, _T_222) @[el2_ifu_iccm_mem.scala 72:105] + node _T_224 = bits(io.iccm_rw_addr, 2, 1) @[el2_ifu_iccm_mem.scala 72:163] + node _T_225 = eq(_T_224, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 72:169] + node _T_226 = and(_T_223, _T_225) @[el2_ifu_iccm_mem.scala 72:145] + node _T_227 = and(_T_220, _T_226) @[el2_ifu_iccm_mem.scala 72:71] + node _T_228 = bits(addr_bank_inc, 14, 1) @[el2_ifu_iccm_mem.scala 73:22] + node _T_229 = bits(redundant_address[0], 13, 0) @[el2_ifu_iccm_mem.scala 73:60] + node _T_230 = eq(_T_228, _T_229) @[el2_ifu_iccm_mem.scala 73:37] + node _T_231 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 73:93] + node _T_232 = eq(_T_231, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 73:99] + node _T_233 = and(_T_230, _T_232) @[el2_ifu_iccm_mem.scala 73:77] + node _T_234 = or(_T_227, _T_233) @[el2_ifu_iccm_mem.scala 72:179] + node _T_235 = cat(_T_234, _T_219) @[Cat.scala 29:58] + node _T_236 = cat(_T_235, _T_204) @[Cat.scala 29:58] + node sel_red0 = cat(_T_236, _T_189) @[Cat.scala 29:58] + reg sel_red0_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 75:27] + sel_red0_q <= sel_red0 @[el2_ifu_iccm_mem.scala 75:27] + reg sel_red1_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 76:27] + sel_red1_q <= sel_red1 @[el2_ifu_iccm_mem.scala 76:27] + wire redundant_data : UInt<39>[2] @[el2_ifu_iccm_mem.scala 77:28] + redundant_data[0] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 78:18] + redundant_data[1] <= UInt<1>("h00") @[el2_ifu_iccm_mem.scala 78:18] + node _T_237 = bits(sel_red1_q, 0, 0) @[el2_ifu_iccm_mem.scala 80:47] + node _T_238 = bits(_T_237, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] + node _T_239 = bits(sel_red0_q, 0, 0) @[el2_ifu_iccm_mem.scala 81:47] + node _T_240 = bits(_T_239, 0, 0) @[el2_ifu_iccm_mem.scala 81:51] + node _T_241 = bits(sel_red0_q, 0, 0) @[el2_ifu_iccm_mem.scala 82:47] + node _T_242 = not(_T_241) @[el2_ifu_iccm_mem.scala 82:36] + node _T_243 = bits(sel_red1_q, 0, 0) @[el2_ifu_iccm_mem.scala 82:64] + node _T_244 = not(_T_243) @[el2_ifu_iccm_mem.scala 82:53] + node _T_245 = and(_T_242, _T_244) @[el2_ifu_iccm_mem.scala 82:51] + node _T_246 = bits(_T_245, 0, 0) @[el2_ifu_iccm_mem.scala 82:69] + node _T_247 = mux(_T_238, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_248 = mux(_T_240, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_249 = mux(_T_246, iccm_bank_dout[0], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_250 = or(_T_247, _T_248) @[Mux.scala 27:72] + node _T_251 = or(_T_250, _T_249) @[Mux.scala 27:72] wire iccm_bank_dout_fn_0 : UInt<39> @[Mux.scala 27:72] - iccm_bank_dout_fn_0 <= _T_247 @[Mux.scala 27:72] - node _T_248 = bits(sel_red1_q, 1, 1) @[el2_ifu_iccm_mem.scala 79:47] - node _T_249 = bits(_T_248, 0, 0) @[el2_ifu_iccm_mem.scala 79:51] - node _T_250 = bits(sel_red0_q, 1, 1) @[el2_ifu_iccm_mem.scala 80:47] - node _T_251 = bits(_T_250, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] - node _T_252 = bits(sel_red0_q, 1, 1) @[el2_ifu_iccm_mem.scala 81:47] - node _T_253 = not(_T_252) @[el2_ifu_iccm_mem.scala 81:36] - node _T_254 = bits(sel_red1_q, 1, 1) @[el2_ifu_iccm_mem.scala 81:64] - node _T_255 = not(_T_254) @[el2_ifu_iccm_mem.scala 81:53] - node _T_256 = and(_T_253, _T_255) @[el2_ifu_iccm_mem.scala 81:51] - node _T_257 = bits(_T_256, 0, 0) @[el2_ifu_iccm_mem.scala 81:69] - node _T_258 = mux(_T_249, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_259 = mux(_T_251, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_260 = mux(_T_257, iccm_bank_dout[1], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_261 = or(_T_258, _T_259) @[Mux.scala 27:72] - node _T_262 = or(_T_261, _T_260) @[Mux.scala 27:72] + iccm_bank_dout_fn_0 <= _T_251 @[Mux.scala 27:72] + node _T_252 = bits(sel_red1_q, 1, 1) @[el2_ifu_iccm_mem.scala 80:47] + node _T_253 = bits(_T_252, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] + node _T_254 = bits(sel_red0_q, 1, 1) @[el2_ifu_iccm_mem.scala 81:47] + node _T_255 = bits(_T_254, 0, 0) @[el2_ifu_iccm_mem.scala 81:51] + node _T_256 = bits(sel_red0_q, 1, 1) @[el2_ifu_iccm_mem.scala 82:47] + node _T_257 = not(_T_256) @[el2_ifu_iccm_mem.scala 82:36] + node _T_258 = bits(sel_red1_q, 1, 1) @[el2_ifu_iccm_mem.scala 82:64] + node _T_259 = not(_T_258) @[el2_ifu_iccm_mem.scala 82:53] + node _T_260 = and(_T_257, _T_259) @[el2_ifu_iccm_mem.scala 82:51] + node _T_261 = bits(_T_260, 0, 0) @[el2_ifu_iccm_mem.scala 82:69] + node _T_262 = mux(_T_253, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_263 = mux(_T_255, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_264 = mux(_T_261, iccm_bank_dout[1], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_265 = or(_T_262, _T_263) @[Mux.scala 27:72] + node _T_266 = or(_T_265, _T_264) @[Mux.scala 27:72] wire iccm_bank_dout_fn_1 : UInt<39> @[Mux.scala 27:72] - iccm_bank_dout_fn_1 <= _T_262 @[Mux.scala 27:72] - node _T_263 = bits(sel_red1_q, 2, 2) @[el2_ifu_iccm_mem.scala 79:47] - node _T_264 = bits(_T_263, 0, 0) @[el2_ifu_iccm_mem.scala 79:51] - node _T_265 = bits(sel_red0_q, 2, 2) @[el2_ifu_iccm_mem.scala 80:47] - node _T_266 = bits(_T_265, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] - node _T_267 = bits(sel_red0_q, 2, 2) @[el2_ifu_iccm_mem.scala 81:47] - node _T_268 = not(_T_267) @[el2_ifu_iccm_mem.scala 81:36] - node _T_269 = bits(sel_red1_q, 2, 2) @[el2_ifu_iccm_mem.scala 81:64] - node _T_270 = not(_T_269) @[el2_ifu_iccm_mem.scala 81:53] - node _T_271 = and(_T_268, _T_270) @[el2_ifu_iccm_mem.scala 81:51] - node _T_272 = bits(_T_271, 0, 0) @[el2_ifu_iccm_mem.scala 81:69] - node _T_273 = mux(_T_264, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_274 = mux(_T_266, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_275 = mux(_T_272, iccm_bank_dout[2], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_276 = or(_T_273, _T_274) @[Mux.scala 27:72] - node _T_277 = or(_T_276, _T_275) @[Mux.scala 27:72] + iccm_bank_dout_fn_1 <= _T_266 @[Mux.scala 27:72] + node _T_267 = bits(sel_red1_q, 2, 2) @[el2_ifu_iccm_mem.scala 80:47] + node _T_268 = bits(_T_267, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] + node _T_269 = bits(sel_red0_q, 2, 2) @[el2_ifu_iccm_mem.scala 81:47] + node _T_270 = bits(_T_269, 0, 0) @[el2_ifu_iccm_mem.scala 81:51] + node _T_271 = bits(sel_red0_q, 2, 2) @[el2_ifu_iccm_mem.scala 82:47] + node _T_272 = not(_T_271) @[el2_ifu_iccm_mem.scala 82:36] + node _T_273 = bits(sel_red1_q, 2, 2) @[el2_ifu_iccm_mem.scala 82:64] + node _T_274 = not(_T_273) @[el2_ifu_iccm_mem.scala 82:53] + node _T_275 = and(_T_272, _T_274) @[el2_ifu_iccm_mem.scala 82:51] + node _T_276 = bits(_T_275, 0, 0) @[el2_ifu_iccm_mem.scala 82:69] + node _T_277 = mux(_T_268, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_278 = mux(_T_270, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_279 = mux(_T_276, iccm_bank_dout[2], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_280 = or(_T_277, _T_278) @[Mux.scala 27:72] + node _T_281 = or(_T_280, _T_279) @[Mux.scala 27:72] wire iccm_bank_dout_fn_2 : UInt<39> @[Mux.scala 27:72] - iccm_bank_dout_fn_2 <= _T_277 @[Mux.scala 27:72] - node _T_278 = bits(sel_red1_q, 3, 3) @[el2_ifu_iccm_mem.scala 79:47] - node _T_279 = bits(_T_278, 0, 0) @[el2_ifu_iccm_mem.scala 79:51] - node _T_280 = bits(sel_red0_q, 3, 3) @[el2_ifu_iccm_mem.scala 80:47] - node _T_281 = bits(_T_280, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] - node _T_282 = bits(sel_red0_q, 3, 3) @[el2_ifu_iccm_mem.scala 81:47] - node _T_283 = not(_T_282) @[el2_ifu_iccm_mem.scala 81:36] - node _T_284 = bits(sel_red1_q, 3, 3) @[el2_ifu_iccm_mem.scala 81:64] - node _T_285 = not(_T_284) @[el2_ifu_iccm_mem.scala 81:53] - node _T_286 = and(_T_283, _T_285) @[el2_ifu_iccm_mem.scala 81:51] - node _T_287 = bits(_T_286, 0, 0) @[el2_ifu_iccm_mem.scala 81:69] - node _T_288 = mux(_T_279, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_289 = mux(_T_281, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_290 = mux(_T_287, iccm_bank_dout[3], UInt<1>("h00")) @[Mux.scala 27:72] - node _T_291 = or(_T_288, _T_289) @[Mux.scala 27:72] - node _T_292 = or(_T_291, _T_290) @[Mux.scala 27:72] + iccm_bank_dout_fn_2 <= _T_281 @[Mux.scala 27:72] + node _T_282 = bits(sel_red1_q, 3, 3) @[el2_ifu_iccm_mem.scala 80:47] + node _T_283 = bits(_T_282, 0, 0) @[el2_ifu_iccm_mem.scala 80:51] + node _T_284 = bits(sel_red0_q, 3, 3) @[el2_ifu_iccm_mem.scala 81:47] + node _T_285 = bits(_T_284, 0, 0) @[el2_ifu_iccm_mem.scala 81:51] + node _T_286 = bits(sel_red0_q, 3, 3) @[el2_ifu_iccm_mem.scala 82:47] + node _T_287 = not(_T_286) @[el2_ifu_iccm_mem.scala 82:36] + node _T_288 = bits(sel_red1_q, 3, 3) @[el2_ifu_iccm_mem.scala 82:64] + node _T_289 = not(_T_288) @[el2_ifu_iccm_mem.scala 82:53] + node _T_290 = and(_T_287, _T_289) @[el2_ifu_iccm_mem.scala 82:51] + node _T_291 = bits(_T_290, 0, 0) @[el2_ifu_iccm_mem.scala 82:69] + node _T_292 = mux(_T_283, redundant_data[1], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_293 = mux(_T_285, redundant_data[0], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_294 = mux(_T_291, iccm_bank_dout[3], UInt<1>("h00")) @[Mux.scala 27:72] + node _T_295 = or(_T_292, _T_293) @[Mux.scala 27:72] + node _T_296 = or(_T_295, _T_294) @[Mux.scala 27:72] wire iccm_bank_dout_fn_3 : UInt<39> @[Mux.scala 27:72] - iccm_bank_dout_fn_3 <= _T_292 @[Mux.scala 27:72] + iccm_bank_dout_fn_3 <= _T_296 @[Mux.scala 27:72] wire redundant_lru : UInt<1> redundant_lru <= UInt<1>("h00") - node _T_293 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 83:20] - node r0_addr_en = and(_T_293, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 83:35] - node r1_addr_en = and(redundant_lru, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 84:35] - node _T_294 = orr(sel_red0) @[el2_ifu_iccm_mem.scala 85:63] - node _T_295 = orr(sel_red1) @[el2_ifu_iccm_mem.scala 85:78] - node _T_296 = or(_T_294, _T_295) @[el2_ifu_iccm_mem.scala 85:67] - node _T_297 = and(_T_296, io.iccm_rden) @[el2_ifu_iccm_mem.scala 85:83] - node _T_298 = and(_T_297, io.iccm_correction_state) @[el2_ifu_iccm_mem.scala 85:98] - node redundant_lru_en = or(io.iccm_buf_correct_ecc, _T_298) @[el2_ifu_iccm_mem.scala 85:50] - node _T_299 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 86:55] - node _T_300 = orr(sel_red0) @[el2_ifu_iccm_mem.scala 86:84] - node _T_301 = mux(_T_300, UInt<1>("h01"), UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 86:74] - node redundant_lru_in = mux(io.iccm_buf_correct_ecc, _T_299, _T_301) @[el2_ifu_iccm_mem.scala 86:29] - reg _T_302 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + node _T_297 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 84:20] + node r0_addr_en = and(_T_297, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 84:35] + node r1_addr_en = and(redundant_lru, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 85:35] + node _T_298 = orr(sel_red0) @[el2_ifu_iccm_mem.scala 86:63] + node _T_299 = orr(sel_red1) @[el2_ifu_iccm_mem.scala 86:78] + node _T_300 = or(_T_298, _T_299) @[el2_ifu_iccm_mem.scala 86:67] + node _T_301 = and(_T_300, io.iccm_rden) @[el2_ifu_iccm_mem.scala 86:83] + node _T_302 = and(_T_301, io.iccm_correction_state) @[el2_ifu_iccm_mem.scala 86:98] + node redundant_lru_en = or(io.iccm_buf_correct_ecc, _T_302) @[el2_ifu_iccm_mem.scala 86:50] + node _T_303 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 87:55] + node _T_304 = orr(sel_red0) @[el2_ifu_iccm_mem.scala 87:84] + node _T_305 = mux(_T_304, UInt<1>("h01"), UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 87:74] + node redundant_lru_in = mux(io.iccm_buf_correct_ecc, _T_303, _T_305) @[el2_ifu_iccm_mem.scala 87:29] + reg _T_306 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] when redundant_lru_en : @[Reg.scala 28:19] - _T_302 <= redundant_lru_in @[Reg.scala 28:23] + _T_306 <= redundant_lru_in @[Reg.scala 28:23] skip @[Reg.scala 28:19] - redundant_lru <= _T_302 @[el2_ifu_iccm_mem.scala 87:17] - node _T_303 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 88:52] - reg _T_304 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + redundant_lru <= _T_306 @[el2_ifu_iccm_mem.scala 88:17] + node _T_307 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 89:52] + reg _T_308 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] when r0_addr_en : @[Reg.scala 28:19] - _T_304 <= _T_303 @[Reg.scala 28:23] + _T_308 <= _T_307 @[Reg.scala 28:23] skip @[Reg.scala 28:19] - redundant_address[0] <= _T_304 @[el2_ifu_iccm_mem.scala 88:24] - node _T_305 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 89:52] - node _T_306 = bits(r1_addr_en, 0, 0) @[el2_ifu_iccm_mem.scala 89:85] - reg _T_307 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] - when _T_306 : @[Reg.scala 28:19] - _T_307 <= _T_305 @[Reg.scala 28:23] + redundant_address[0] <= _T_308 @[el2_ifu_iccm_mem.scala 89:24] + node _T_309 = bits(io.iccm_rw_addr, 14, 1) @[el2_ifu_iccm_mem.scala 90:52] + node _T_310 = bits(r1_addr_en, 0, 0) @[el2_ifu_iccm_mem.scala 90:85] + reg _T_311 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + when _T_310 : @[Reg.scala 28:19] + _T_311 <= _T_309 @[Reg.scala 28:23] skip @[Reg.scala 28:19] - redundant_address[1] <= _T_307 @[el2_ifu_iccm_mem.scala 89:24] - node _T_308 = bits(r1_addr_en, 0, 0) @[el2_ifu_iccm_mem.scala 90:57] - reg _T_309 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] - when _T_308 : @[Reg.scala 28:19] - _T_309 <= UInt<1>("h01") @[Reg.scala 28:23] + redundant_address[1] <= _T_311 @[el2_ifu_iccm_mem.scala 90:24] + node _T_312 = bits(r1_addr_en, 0, 0) @[el2_ifu_iccm_mem.scala 91:57] + reg _T_313 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + when _T_312 : @[Reg.scala 28:19] + _T_313 <= UInt<1>("h01") @[Reg.scala 28:23] skip @[Reg.scala 28:19] - reg _T_310 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + reg _T_314 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] when r0_addr_en : @[Reg.scala 28:19] - _T_310 <= UInt<1>("h01") @[Reg.scala 28:23] + _T_314 <= UInt<1>("h01") @[Reg.scala 28:23] skip @[Reg.scala 28:19] - node _T_311 = cat(_T_309, _T_310) @[Cat.scala 29:58] - redundant_valid <= _T_311 @[el2_ifu_iccm_mem.scala 90:19] - node _T_312 = bits(io.iccm_rw_addr, 14, 2) @[el2_ifu_iccm_mem.scala 92:45] - node _T_313 = bits(redundant_address[0], 13, 1) @[el2_ifu_iccm_mem.scala 92:85] - node _T_314 = eq(_T_312, _T_313) @[el2_ifu_iccm_mem.scala 92:61] - node _T_315 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 93:22] - node _T_316 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 93:48] - node _T_317 = and(_T_315, _T_316) @[el2_ifu_iccm_mem.scala 93:26] - node _T_318 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 93:70] - node _T_319 = eq(_T_318, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 93:75] - node _T_320 = or(_T_317, _T_319) @[el2_ifu_iccm_mem.scala 93:52] - node _T_321 = and(_T_314, _T_320) @[el2_ifu_iccm_mem.scala 92:102] - node _T_322 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 93:101] - node _T_323 = and(_T_321, _T_322) @[el2_ifu_iccm_mem.scala 93:84] - node _T_324 = and(_T_323, io.iccm_wren) @[el2_ifu_iccm_mem.scala 93:105] - node _T_325 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 94:6] - node _T_326 = and(_T_325, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 94:21] - node redundant_data0_en = or(_T_324, _T_326) @[el2_ifu_iccm_mem.scala 93:121] - node _T_327 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 95:49] - node _T_328 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 95:73] - node _T_329 = and(_T_327, _T_328) @[el2_ifu_iccm_mem.scala 95:52] - node _T_330 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 95:100] - node _T_331 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 95:122] - node _T_332 = eq(_T_331, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 95:127] - node _T_333 = and(_T_330, _T_332) @[el2_ifu_iccm_mem.scala 95:104] - node _T_334 = or(_T_329, _T_333) @[el2_ifu_iccm_mem.scala 95:78] - node _T_335 = bits(_T_334, 0, 0) @[el2_ifu_iccm_mem.scala 95:137] - node _T_336 = bits(io.iccm_wr_data, 77, 39) @[el2_ifu_iccm_mem.scala 96:20] - node _T_337 = bits(io.iccm_wr_data, 38, 0) @[el2_ifu_iccm_mem.scala 96:44] - node redundant_data0_in = mux(_T_335, _T_336, _T_337) @[el2_ifu_iccm_mem.scala 95:31] - node _T_338 = bits(redundant_data0_en, 0, 0) @[el2_ifu_iccm_mem.scala 97:78] - reg _T_339 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] - when _T_338 : @[Reg.scala 28:19] - _T_339 <= redundant_data0_in @[Reg.scala 28:23] + node _T_315 = cat(_T_313, _T_314) @[Cat.scala 29:58] + redundant_valid <= _T_315 @[el2_ifu_iccm_mem.scala 91:19] + node _T_316 = bits(io.iccm_rw_addr, 14, 2) @[el2_ifu_iccm_mem.scala 93:45] + node _T_317 = bits(redundant_address[0], 13, 1) @[el2_ifu_iccm_mem.scala 93:85] + node _T_318 = eq(_T_316, _T_317) @[el2_ifu_iccm_mem.scala 93:61] + node _T_319 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 94:22] + node _T_320 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 94:48] + node _T_321 = and(_T_319, _T_320) @[el2_ifu_iccm_mem.scala 94:26] + node _T_322 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 94:70] + node _T_323 = eq(_T_322, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 94:75] + node _T_324 = or(_T_321, _T_323) @[el2_ifu_iccm_mem.scala 94:52] + node _T_325 = and(_T_318, _T_324) @[el2_ifu_iccm_mem.scala 93:102] + node _T_326 = bits(redundant_valid, 0, 0) @[el2_ifu_iccm_mem.scala 94:101] + node _T_327 = and(_T_325, _T_326) @[el2_ifu_iccm_mem.scala 94:84] + node _T_328 = and(_T_327, io.iccm_wren) @[el2_ifu_iccm_mem.scala 94:105] + node _T_329 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 95:6] + node _T_330 = and(_T_329, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 95:21] + node redundant_data0_en = or(_T_328, _T_330) @[el2_ifu_iccm_mem.scala 94:121] + node _T_331 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 96:49] + node _T_332 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 96:73] + node _T_333 = and(_T_331, _T_332) @[el2_ifu_iccm_mem.scala 96:52] + node _T_334 = bits(redundant_address[0], 0, 0) @[el2_ifu_iccm_mem.scala 96:100] + node _T_335 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 96:122] + node _T_336 = eq(_T_335, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 96:127] + node _T_337 = and(_T_334, _T_336) @[el2_ifu_iccm_mem.scala 96:104] + node _T_338 = or(_T_333, _T_337) @[el2_ifu_iccm_mem.scala 96:78] + node _T_339 = bits(_T_338, 0, 0) @[el2_ifu_iccm_mem.scala 96:137] + node _T_340 = bits(io.iccm_wr_data, 77, 39) @[el2_ifu_iccm_mem.scala 97:20] + node _T_341 = bits(io.iccm_wr_data, 38, 0) @[el2_ifu_iccm_mem.scala 97:44] + node redundant_data0_in = mux(_T_339, _T_340, _T_341) @[el2_ifu_iccm_mem.scala 96:31] + node _T_342 = bits(redundant_data0_en, 0, 0) @[el2_ifu_iccm_mem.scala 98:78] + reg _T_343 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + when _T_342 : @[Reg.scala 28:19] + _T_343 <= redundant_data0_in @[Reg.scala 28:23] skip @[Reg.scala 28:19] - redundant_data[0] <= _T_339 @[el2_ifu_iccm_mem.scala 97:21] - node _T_340 = bits(io.iccm_rw_addr, 14, 2) @[el2_ifu_iccm_mem.scala 99:45] - node _T_341 = bits(redundant_address[1], 13, 1) @[el2_ifu_iccm_mem.scala 99:85] - node _T_342 = eq(_T_340, _T_341) @[el2_ifu_iccm_mem.scala 99:61] - node _T_343 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 100:22] - node _T_344 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 100:48] - node _T_345 = and(_T_343, _T_344) @[el2_ifu_iccm_mem.scala 100:26] - node _T_346 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 100:70] - node _T_347 = eq(_T_346, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 100:75] - node _T_348 = or(_T_345, _T_347) @[el2_ifu_iccm_mem.scala 100:52] - node _T_349 = and(_T_342, _T_348) @[el2_ifu_iccm_mem.scala 99:102] - node _T_350 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 100:101] - node _T_351 = and(_T_349, _T_350) @[el2_ifu_iccm_mem.scala 100:84] - node _T_352 = and(_T_351, io.iccm_wren) @[el2_ifu_iccm_mem.scala 100:105] - node _T_353 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 101:6] - node _T_354 = and(_T_353, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 101:21] - node redundant_data1_en = or(_T_352, _T_354) @[el2_ifu_iccm_mem.scala 100:121] - node _T_355 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 102:49] - node _T_356 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 102:73] - node _T_357 = and(_T_355, _T_356) @[el2_ifu_iccm_mem.scala 102:52] - node _T_358 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 102:100] - node _T_359 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 102:122] - node _T_360 = eq(_T_359, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 102:127] - node _T_361 = and(_T_358, _T_360) @[el2_ifu_iccm_mem.scala 102:104] - node _T_362 = or(_T_357, _T_361) @[el2_ifu_iccm_mem.scala 102:78] - node _T_363 = bits(_T_362, 0, 0) @[el2_ifu_iccm_mem.scala 102:137] - node _T_364 = bits(io.iccm_wr_data, 77, 39) @[el2_ifu_iccm_mem.scala 103:20] - node _T_365 = bits(io.iccm_wr_data, 38, 0) @[el2_ifu_iccm_mem.scala 103:44] - node redundant_data1_in = mux(_T_363, _T_364, _T_365) @[el2_ifu_iccm_mem.scala 102:31] - node _T_366 = bits(redundant_data1_en, 0, 0) @[el2_ifu_iccm_mem.scala 104:78] - reg _T_367 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] - when _T_366 : @[Reg.scala 28:19] - _T_367 <= redundant_data1_in @[Reg.scala 28:23] + redundant_data[0] <= _T_343 @[el2_ifu_iccm_mem.scala 98:21] + node _T_344 = bits(io.iccm_rw_addr, 14, 2) @[el2_ifu_iccm_mem.scala 100:45] + node _T_345 = bits(redundant_address[1], 13, 1) @[el2_ifu_iccm_mem.scala 100:85] + node _T_346 = eq(_T_344, _T_345) @[el2_ifu_iccm_mem.scala 100:61] + node _T_347 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 101:22] + node _T_348 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 101:48] + node _T_349 = and(_T_347, _T_348) @[el2_ifu_iccm_mem.scala 101:26] + node _T_350 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 101:70] + node _T_351 = eq(_T_350, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 101:75] + node _T_352 = or(_T_349, _T_351) @[el2_ifu_iccm_mem.scala 101:52] + node _T_353 = and(_T_346, _T_352) @[el2_ifu_iccm_mem.scala 100:102] + node _T_354 = bits(redundant_valid, 1, 1) @[el2_ifu_iccm_mem.scala 101:101] + node _T_355 = and(_T_353, _T_354) @[el2_ifu_iccm_mem.scala 101:84] + node _T_356 = and(_T_355, io.iccm_wren) @[el2_ifu_iccm_mem.scala 101:105] + node _T_357 = eq(redundant_lru, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 102:6] + node _T_358 = and(_T_357, io.iccm_buf_correct_ecc) @[el2_ifu_iccm_mem.scala 102:21] + node redundant_data1_en = or(_T_356, _T_358) @[el2_ifu_iccm_mem.scala 101:121] + node _T_359 = bits(io.iccm_rw_addr, 1, 1) @[el2_ifu_iccm_mem.scala 103:49] + node _T_360 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 103:73] + node _T_361 = and(_T_359, _T_360) @[el2_ifu_iccm_mem.scala 103:52] + node _T_362 = bits(redundant_address[1], 0, 0) @[el2_ifu_iccm_mem.scala 103:100] + node _T_363 = bits(io.iccm_wr_size, 1, 0) @[el2_ifu_iccm_mem.scala 103:122] + node _T_364 = eq(_T_363, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 103:127] + node _T_365 = and(_T_362, _T_364) @[el2_ifu_iccm_mem.scala 103:104] + node _T_366 = or(_T_361, _T_365) @[el2_ifu_iccm_mem.scala 103:78] + node _T_367 = bits(_T_366, 0, 0) @[el2_ifu_iccm_mem.scala 103:137] + node _T_368 = bits(io.iccm_wr_data, 77, 39) @[el2_ifu_iccm_mem.scala 104:20] + node _T_369 = bits(io.iccm_wr_data, 38, 0) @[el2_ifu_iccm_mem.scala 104:44] + node redundant_data1_in = mux(_T_367, _T_368, _T_369) @[el2_ifu_iccm_mem.scala 103:31] + node _T_370 = bits(redundant_data1_en, 0, 0) @[el2_ifu_iccm_mem.scala 105:78] + reg _T_371 : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[Reg.scala 27:20] + when _T_370 : @[Reg.scala 28:19] + _T_371 <= redundant_data1_in @[Reg.scala 28:23] skip @[Reg.scala 28:19] - redundant_data[1] <= _T_367 @[el2_ifu_iccm_mem.scala 104:21] - node _T_368 = bits(io.iccm_rw_addr, 2, 0) @[el2_ifu_iccm_mem.scala 106:50] - reg iccm_rd_addr_lo_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 106:34] - iccm_rd_addr_lo_q <= _T_368 @[el2_ifu_iccm_mem.scala 106:34] - node _T_369 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 107:48] - reg iccm_rd_addr_hi_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 107:34] - iccm_rd_addr_hi_q <= _T_369 @[el2_ifu_iccm_mem.scala 107:34] - node _T_370 = eq(iccm_rd_addr_hi_q, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 109:86] - node _T_371 = bits(iccm_bank_dout_fn_0, 31, 0) @[el2_ifu_iccm_mem.scala 109:115] - node _T_372 = eq(iccm_rd_addr_hi_q, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 109:86] - node _T_373 = bits(iccm_bank_dout_fn_1, 31, 0) @[el2_ifu_iccm_mem.scala 109:115] - node _T_374 = eq(iccm_rd_addr_hi_q, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 109:86] - node _T_375 = bits(iccm_bank_dout_fn_2, 31, 0) @[el2_ifu_iccm_mem.scala 109:115] - node _T_376 = eq(iccm_rd_addr_hi_q, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 109:86] - node _T_377 = bits(iccm_bank_dout_fn_3, 31, 0) @[el2_ifu_iccm_mem.scala 109:115] - node _T_378 = mux(_T_370, _T_371, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_379 = mux(_T_372, _T_373, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_380 = mux(_T_374, _T_375, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_381 = mux(_T_376, _T_377, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_382 = or(_T_378, _T_379) @[Mux.scala 27:72] - node _T_383 = or(_T_382, _T_380) @[Mux.scala 27:72] - node _T_384 = or(_T_383, _T_381) @[Mux.scala 27:72] - wire _T_385 : UInt<32> @[Mux.scala 27:72] - _T_385 <= _T_384 @[Mux.scala 27:72] - node _T_386 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 110:59] - node _T_387 = eq(_T_386, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 110:77] - node _T_388 = bits(iccm_bank_dout_fn_0, 31, 0) @[el2_ifu_iccm_mem.scala 110:106] - node _T_389 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 110:59] - node _T_390 = eq(_T_389, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 110:77] - node _T_391 = bits(iccm_bank_dout_fn_1, 31, 0) @[el2_ifu_iccm_mem.scala 110:106] - node _T_392 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 110:59] - node _T_393 = eq(_T_392, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 110:77] - node _T_394 = bits(iccm_bank_dout_fn_2, 31, 0) @[el2_ifu_iccm_mem.scala 110:106] - node _T_395 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 110:59] - node _T_396 = eq(_T_395, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 110:77] - node _T_397 = bits(iccm_bank_dout_fn_3, 31, 0) @[el2_ifu_iccm_mem.scala 110:106] - node _T_398 = mux(_T_387, _T_388, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_399 = mux(_T_390, _T_391, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_400 = mux(_T_393, _T_394, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_401 = mux(_T_396, _T_397, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_402 = or(_T_398, _T_399) @[Mux.scala 27:72] - node _T_403 = or(_T_402, _T_400) @[Mux.scala 27:72] - node _T_404 = or(_T_403, _T_401) @[Mux.scala 27:72] - wire _T_405 : UInt<32> @[Mux.scala 27:72] - _T_405 <= _T_404 @[Mux.scala 27:72] - node iccm_rd_data_pre = cat(_T_385, _T_405) @[Cat.scala 29:58] - node _T_406 = bits(iccm_rd_addr_lo_q, 0, 0) @[el2_ifu_iccm_mem.scala 111:43] - node _T_407 = bits(_T_406, 0, 0) @[el2_ifu_iccm_mem.scala 111:53] - node _T_408 = mux(UInt<1>("h00"), UInt<16>("h0ffff"), UInt<16>("h00")) @[Bitwise.scala 72:12] - node _T_409 = bits(iccm_rd_data_pre, 63, 16) @[el2_ifu_iccm_mem.scala 111:89] - node _T_410 = cat(_T_408, _T_409) @[Cat.scala 29:58] - node _T_411 = mux(_T_407, _T_410, iccm_rd_data_pre) @[el2_ifu_iccm_mem.scala 111:25] - io.iccm_rd_data <= _T_411 @[el2_ifu_iccm_mem.scala 111:19] - node _T_412 = eq(iccm_rd_addr_hi_q, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 112:85] - node _T_413 = eq(iccm_rd_addr_hi_q, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 112:85] - node _T_414 = eq(iccm_rd_addr_hi_q, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 112:85] - node _T_415 = eq(iccm_rd_addr_hi_q, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 112:85] - node _T_416 = mux(_T_412, iccm_bank_dout_fn_0, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_417 = mux(_T_413, iccm_bank_dout_fn_1, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_418 = mux(_T_414, iccm_bank_dout_fn_2, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_419 = mux(_T_415, iccm_bank_dout_fn_3, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_420 = or(_T_416, _T_417) @[Mux.scala 27:72] - node _T_421 = or(_T_420, _T_418) @[Mux.scala 27:72] - node _T_422 = or(_T_421, _T_419) @[Mux.scala 27:72] - wire _T_423 : UInt<39> @[Mux.scala 27:72] - _T_423 <= _T_422 @[Mux.scala 27:72] - node _T_424 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 113:61] - node _T_425 = eq(_T_424, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 113:79] - node _T_426 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 113:61] - node _T_427 = eq(_T_426, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 113:79] - node _T_428 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 113:61] - node _T_429 = eq(_T_428, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 113:79] - node _T_430 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 113:61] - node _T_431 = eq(_T_430, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 113:79] - node _T_432 = mux(_T_425, iccm_bank_dout_fn_0, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_433 = mux(_T_427, iccm_bank_dout_fn_1, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_434 = mux(_T_429, iccm_bank_dout_fn_2, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_435 = mux(_T_431, iccm_bank_dout_fn_3, UInt<1>("h00")) @[Mux.scala 27:72] - node _T_436 = or(_T_432, _T_433) @[Mux.scala 27:72] - node _T_437 = or(_T_436, _T_434) @[Mux.scala 27:72] - node _T_438 = or(_T_437, _T_435) @[Mux.scala 27:72] - wire _T_439 : UInt<39> @[Mux.scala 27:72] - _T_439 <= _T_438 @[Mux.scala 27:72] - node _T_440 = cat(_T_423, _T_439) @[Cat.scala 29:58] - io.iccm_rd_data_ecc <= _T_440 @[el2_ifu_iccm_mem.scala 112:23] + redundant_data[1] <= _T_371 @[el2_ifu_iccm_mem.scala 105:21] + node _T_372 = bits(io.iccm_rw_addr, 2, 0) @[el2_ifu_iccm_mem.scala 107:50] + reg iccm_rd_addr_lo_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 107:34] + iccm_rd_addr_lo_q <= _T_372 @[el2_ifu_iccm_mem.scala 107:34] + node _T_373 = bits(addr_bank_inc, 2, 1) @[el2_ifu_iccm_mem.scala 108:48] + reg iccm_rd_addr_hi_q : UInt, clock with : (reset => (reset, UInt<1>("h00"))) @[el2_ifu_iccm_mem.scala 108:34] + iccm_rd_addr_hi_q <= _T_373 @[el2_ifu_iccm_mem.scala 108:34] + node _T_374 = eq(iccm_rd_addr_hi_q, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 110:86] + node _T_375 = bits(iccm_bank_dout_fn_0, 31, 0) @[el2_ifu_iccm_mem.scala 110:115] + node _T_376 = eq(iccm_rd_addr_hi_q, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 110:86] + node _T_377 = bits(iccm_bank_dout_fn_1, 31, 0) @[el2_ifu_iccm_mem.scala 110:115] + node _T_378 = eq(iccm_rd_addr_hi_q, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 110:86] + node _T_379 = bits(iccm_bank_dout_fn_2, 31, 0) @[el2_ifu_iccm_mem.scala 110:115] + node _T_380 = eq(iccm_rd_addr_hi_q, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 110:86] + node _T_381 = bits(iccm_bank_dout_fn_3, 31, 0) @[el2_ifu_iccm_mem.scala 110:115] + node _T_382 = mux(_T_374, _T_375, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_383 = mux(_T_376, _T_377, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_384 = mux(_T_378, _T_379, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_385 = mux(_T_380, _T_381, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_386 = or(_T_382, _T_383) @[Mux.scala 27:72] + node _T_387 = or(_T_386, _T_384) @[Mux.scala 27:72] + node _T_388 = or(_T_387, _T_385) @[Mux.scala 27:72] + wire _T_389 : UInt<32> @[Mux.scala 27:72] + _T_389 <= _T_388 @[Mux.scala 27:72] + node _T_390 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 111:59] + node _T_391 = eq(_T_390, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 111:77] + node _T_392 = bits(iccm_bank_dout_fn_0, 31, 0) @[el2_ifu_iccm_mem.scala 111:106] + node _T_393 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 111:59] + node _T_394 = eq(_T_393, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 111:77] + node _T_395 = bits(iccm_bank_dout_fn_1, 31, 0) @[el2_ifu_iccm_mem.scala 111:106] + node _T_396 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 111:59] + node _T_397 = eq(_T_396, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 111:77] + node _T_398 = bits(iccm_bank_dout_fn_2, 31, 0) @[el2_ifu_iccm_mem.scala 111:106] + node _T_399 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 111:59] + node _T_400 = eq(_T_399, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 111:77] + node _T_401 = bits(iccm_bank_dout_fn_3, 31, 0) @[el2_ifu_iccm_mem.scala 111:106] + node _T_402 = mux(_T_391, _T_392, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_403 = mux(_T_394, _T_395, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_404 = mux(_T_397, _T_398, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_405 = mux(_T_400, _T_401, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_406 = or(_T_402, _T_403) @[Mux.scala 27:72] + node _T_407 = or(_T_406, _T_404) @[Mux.scala 27:72] + node _T_408 = or(_T_407, _T_405) @[Mux.scala 27:72] + wire _T_409 : UInt<32> @[Mux.scala 27:72] + _T_409 <= _T_408 @[Mux.scala 27:72] + node iccm_rd_data_pre = cat(_T_389, _T_409) @[Cat.scala 29:58] + node _T_410 = bits(iccm_rd_addr_lo_q, 0, 0) @[el2_ifu_iccm_mem.scala 112:43] + node _T_411 = bits(_T_410, 0, 0) @[el2_ifu_iccm_mem.scala 112:53] + node _T_412 = mux(UInt<1>("h00"), UInt<16>("h0ffff"), UInt<16>("h00")) @[Bitwise.scala 72:12] + node _T_413 = bits(iccm_rd_data_pre, 63, 16) @[el2_ifu_iccm_mem.scala 112:89] + node _T_414 = cat(_T_412, _T_413) @[Cat.scala 29:58] + node _T_415 = mux(_T_411, _T_414, iccm_rd_data_pre) @[el2_ifu_iccm_mem.scala 112:25] + io.iccm_rd_data <= _T_415 @[el2_ifu_iccm_mem.scala 112:19] + node _T_416 = eq(iccm_rd_addr_hi_q, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 113:85] + node _T_417 = eq(iccm_rd_addr_hi_q, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 113:85] + node _T_418 = eq(iccm_rd_addr_hi_q, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 113:85] + node _T_419 = eq(iccm_rd_addr_hi_q, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 113:85] + node _T_420 = mux(_T_416, iccm_bank_dout_fn_0, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_421 = mux(_T_417, iccm_bank_dout_fn_1, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_422 = mux(_T_418, iccm_bank_dout_fn_2, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_423 = mux(_T_419, iccm_bank_dout_fn_3, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_424 = or(_T_420, _T_421) @[Mux.scala 27:72] + node _T_425 = or(_T_424, _T_422) @[Mux.scala 27:72] + node _T_426 = or(_T_425, _T_423) @[Mux.scala 27:72] + wire _T_427 : UInt<39> @[Mux.scala 27:72] + _T_427 <= _T_426 @[Mux.scala 27:72] + node _T_428 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 114:61] + node _T_429 = eq(_T_428, UInt<1>("h00")) @[el2_ifu_iccm_mem.scala 114:79] + node _T_430 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 114:61] + node _T_431 = eq(_T_430, UInt<1>("h01")) @[el2_ifu_iccm_mem.scala 114:79] + node _T_432 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 114:61] + node _T_433 = eq(_T_432, UInt<2>("h02")) @[el2_ifu_iccm_mem.scala 114:79] + node _T_434 = bits(iccm_rd_addr_lo_q, 1, 0) @[el2_ifu_iccm_mem.scala 114:61] + node _T_435 = eq(_T_434, UInt<2>("h03")) @[el2_ifu_iccm_mem.scala 114:79] + node _T_436 = mux(_T_429, iccm_bank_dout_fn_0, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_437 = mux(_T_431, iccm_bank_dout_fn_1, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_438 = mux(_T_433, iccm_bank_dout_fn_2, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_439 = mux(_T_435, iccm_bank_dout_fn_3, UInt<1>("h00")) @[Mux.scala 27:72] + node _T_440 = or(_T_436, _T_437) @[Mux.scala 27:72] + node _T_441 = or(_T_440, _T_438) @[Mux.scala 27:72] + node _T_442 = or(_T_441, _T_439) @[Mux.scala 27:72] + wire _T_443 : UInt<39> @[Mux.scala 27:72] + _T_443 <= _T_442 @[Mux.scala 27:72] + node _T_444 = cat(_T_427, _T_443) @[Cat.scala 29:58] + io.iccm_rd_data_ecc <= _T_444 @[el2_ifu_iccm_mem.scala 113:23] diff --git a/el2_ifu_iccm_mem.v b/el2_ifu_iccm_mem.v index 36c3963b..32eb450c 100644 --- a/el2_ifu_iccm_mem.v +++ b/el2_ifu_iccm_mem.v @@ -40,34 +40,34 @@ module el2_ifu_iccm_mem( reg [31:0] _RAND_17; reg [31:0] _RAND_18; `endif // RANDOMIZE_REG_INIT - reg [38:0] _T_81 [0:4095]; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_81__T_101_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_81__T_101_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_81__T_97_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_81__T_97_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_81__T_97_mask; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_81__T_97_en; // @[el2_ifu_iccm_mem.scala 42:51] - reg [38:0] _T_82 [0:4095]; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_82__T_103_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_82__T_103_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_82__T_98_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_82__T_98_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_82__T_98_mask; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_82__T_98_en; // @[el2_ifu_iccm_mem.scala 42:51] - reg [38:0] _T_83 [0:4095]; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_83__T_105_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_83__T_105_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_83__T_99_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_83__T_99_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_83__T_99_mask; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_83__T_99_en; // @[el2_ifu_iccm_mem.scala 42:51] - reg [38:0] _T_84 [0:4095]; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_84__T_107_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_84__T_107_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire [38:0] _T_84__T_100_data; // @[el2_ifu_iccm_mem.scala 42:51] - wire [11:0] _T_84__T_100_addr; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_84__T_100_mask; // @[el2_ifu_iccm_mem.scala 42:51] - wire _T_84__T_100_en; // @[el2_ifu_iccm_mem.scala 42:51] + reg [38:0] _T_85 [0:4095]; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_85__T_105_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_85__T_105_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_85__T_101_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_85__T_101_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_85__T_101_mask; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_85__T_101_en; // @[el2_ifu_iccm_mem.scala 43:51] + reg [38:0] _T_86 [0:4095]; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_86__T_107_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_86__T_107_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_86__T_102_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_86__T_102_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_86__T_102_mask; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_86__T_102_en; // @[el2_ifu_iccm_mem.scala 43:51] + reg [38:0] _T_87 [0:4095]; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_87__T_109_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_87__T_109_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_87__T_103_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_87__T_103_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_87__T_103_mask; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_87__T_103_en; // @[el2_ifu_iccm_mem.scala 43:51] + reg [38:0] _T_88 [0:4095]; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_88__T_111_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_88__T_111_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire [38:0] _T_88__T_104_data; // @[el2_ifu_iccm_mem.scala 43:51] + wire [11:0] _T_88__T_104_addr; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_88__T_104_mask; // @[el2_ifu_iccm_mem.scala 43:51] + wire _T_88__T_104_en; // @[el2_ifu_iccm_mem.scala 43:51] wire _T_1 = io_iccm_wr_size[1:0] == 2'h3; // @[el2_ifu_iccm_mem.scala 24:43] wire [1:0] addr_inc = _T_1 ? 2'h2 : 2'h1; // @[el2_ifu_iccm_mem.scala 24:21] wire [14:0] _GEN_27 = {{13'd0}, addr_inc}; // @[el2_ifu_iccm_mem.scala 25:54] @@ -106,193 +106,193 @@ module el2_ifu_iccm_mem( wire iccm_clken_2 = _T_51 | io_clk_override; // @[el2_ifu_iccm_mem.scala 36:87] wire _T_52 = wren_bank_3 | rden_bank_3; // @[el2_ifu_iccm_mem.scala 36:72] wire iccm_clken_3 = _T_52 | io_clk_override; // @[el2_ifu_iccm_mem.scala 36:87] - wire [11:0] _T_59 = _T_12 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 39:8] - wire [11:0] _T_66 = _T_17 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 39:8] - wire [11:0] _T_73 = _T_22 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 39:8] - wire [11:0] _T_80 = _T_27 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 39:8] - reg [38:0] iccm_bank_dout_0; // @[el2_ifu_iccm_mem.scala 55:63] - reg [38:0] iccm_bank_dout_1; // @[el2_ifu_iccm_mem.scala 55:63] - reg [38:0] iccm_bank_dout_2; // @[el2_ifu_iccm_mem.scala 55:63] - reg [38:0] iccm_bank_dout_3; // @[el2_ifu_iccm_mem.scala 55:63] - reg _T_309; // @[Reg.scala 27:20] - reg _T_310; // @[Reg.scala 27:20] - wire [1:0] redundant_valid = {_T_309,_T_310}; // @[Cat.scala 29:58] + wire [11:0] _T_59 = _T_12 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 40:8] + wire [11:0] _T_67 = _T_17 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 40:8] + wire [11:0] _T_75 = _T_22 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 40:8] + wire [11:0] _T_83 = _T_27 ? addr_bank_inc[14:3] : io_iccm_rw_addr[14:3]; // @[el2_ifu_iccm_mem.scala 40:8] + reg [38:0] iccm_bank_dout_0; // @[el2_ifu_iccm_mem.scala 56:63] + reg [38:0] iccm_bank_dout_1; // @[el2_ifu_iccm_mem.scala 56:63] + reg [38:0] iccm_bank_dout_2; // @[el2_ifu_iccm_mem.scala 56:63] + reg [38:0] iccm_bank_dout_3; // @[el2_ifu_iccm_mem.scala 56:63] + reg _T_313; // @[Reg.scala 27:20] + reg _T_314; // @[Reg.scala 27:20] + wire [1:0] redundant_valid = {_T_313,_T_314}; // @[Cat.scala 29:58] reg [13:0] redundant_address_1; // @[Reg.scala 27:20] - wire _T_112 = io_iccm_rw_addr[14:1] == redundant_address_1; // @[el2_ifu_iccm_mem.scala 69:105] - wire _T_115 = _T_112 & _T_10; // @[el2_ifu_iccm_mem.scala 69:145] - wire _T_116 = redundant_valid[1] & _T_115; // @[el2_ifu_iccm_mem.scala 69:71] - wire _T_119 = addr_bank_inc[14:1] == redundant_address_1; // @[el2_ifu_iccm_mem.scala 70:37] - wire _T_122 = _T_119 & _T_12; // @[el2_ifu_iccm_mem.scala 70:77] - wire _T_123 = _T_116 | _T_122; // @[el2_ifu_iccm_mem.scala 69:179] - wire _T_130 = _T_112 & _T_15; // @[el2_ifu_iccm_mem.scala 69:145] - wire _T_131 = redundant_valid[1] & _T_130; // @[el2_ifu_iccm_mem.scala 69:71] - wire _T_137 = _T_119 & _T_17; // @[el2_ifu_iccm_mem.scala 70:77] - wire _T_138 = _T_131 | _T_137; // @[el2_ifu_iccm_mem.scala 69:179] - wire _T_145 = _T_112 & _T_20; // @[el2_ifu_iccm_mem.scala 69:145] - wire _T_146 = redundant_valid[1] & _T_145; // @[el2_ifu_iccm_mem.scala 69:71] - wire _T_152 = _T_119 & _T_22; // @[el2_ifu_iccm_mem.scala 70:77] - wire _T_153 = _T_146 | _T_152; // @[el2_ifu_iccm_mem.scala 69:179] - wire _T_160 = _T_112 & _T_25; // @[el2_ifu_iccm_mem.scala 69:145] - wire _T_161 = redundant_valid[1] & _T_160; // @[el2_ifu_iccm_mem.scala 69:71] - wire _T_167 = _T_119 & _T_27; // @[el2_ifu_iccm_mem.scala 70:77] - wire _T_168 = _T_161 | _T_167; // @[el2_ifu_iccm_mem.scala 69:179] - wire [3:0] sel_red1 = {_T_168,_T_153,_T_138,_T_123}; // @[Cat.scala 29:58] + wire _T_116 = io_iccm_rw_addr[14:1] == redundant_address_1; // @[el2_ifu_iccm_mem.scala 70:105] + wire _T_119 = _T_116 & _T_10; // @[el2_ifu_iccm_mem.scala 70:145] + wire _T_120 = redundant_valid[1] & _T_119; // @[el2_ifu_iccm_mem.scala 70:71] + wire _T_123 = addr_bank_inc[14:1] == redundant_address_1; // @[el2_ifu_iccm_mem.scala 71:37] + wire _T_126 = _T_123 & _T_12; // @[el2_ifu_iccm_mem.scala 71:77] + wire _T_127 = _T_120 | _T_126; // @[el2_ifu_iccm_mem.scala 70:179] + wire _T_134 = _T_116 & _T_15; // @[el2_ifu_iccm_mem.scala 70:145] + wire _T_135 = redundant_valid[1] & _T_134; // @[el2_ifu_iccm_mem.scala 70:71] + wire _T_141 = _T_123 & _T_17; // @[el2_ifu_iccm_mem.scala 71:77] + wire _T_142 = _T_135 | _T_141; // @[el2_ifu_iccm_mem.scala 70:179] + wire _T_149 = _T_116 & _T_20; // @[el2_ifu_iccm_mem.scala 70:145] + wire _T_150 = redundant_valid[1] & _T_149; // @[el2_ifu_iccm_mem.scala 70:71] + wire _T_156 = _T_123 & _T_22; // @[el2_ifu_iccm_mem.scala 71:77] + wire _T_157 = _T_150 | _T_156; // @[el2_ifu_iccm_mem.scala 70:179] + wire _T_164 = _T_116 & _T_25; // @[el2_ifu_iccm_mem.scala 70:145] + wire _T_165 = redundant_valid[1] & _T_164; // @[el2_ifu_iccm_mem.scala 70:71] + wire _T_171 = _T_123 & _T_27; // @[el2_ifu_iccm_mem.scala 71:77] + wire _T_172 = _T_165 | _T_171; // @[el2_ifu_iccm_mem.scala 70:179] + wire [3:0] sel_red1 = {_T_172,_T_157,_T_142,_T_127}; // @[Cat.scala 29:58] reg [13:0] redundant_address_0; // @[Reg.scala 27:20] - wire _T_174 = io_iccm_rw_addr[14:1] == redundant_address_0; // @[el2_ifu_iccm_mem.scala 71:105] - wire _T_177 = _T_174 & _T_10; // @[el2_ifu_iccm_mem.scala 71:145] - wire _T_178 = redundant_valid[0] & _T_177; // @[el2_ifu_iccm_mem.scala 71:71] - wire _T_181 = addr_bank_inc[14:1] == redundant_address_0; // @[el2_ifu_iccm_mem.scala 72:37] - wire _T_184 = _T_181 & _T_12; // @[el2_ifu_iccm_mem.scala 72:77] - wire _T_185 = _T_178 | _T_184; // @[el2_ifu_iccm_mem.scala 71:179] - wire _T_192 = _T_174 & _T_15; // @[el2_ifu_iccm_mem.scala 71:145] - wire _T_193 = redundant_valid[0] & _T_192; // @[el2_ifu_iccm_mem.scala 71:71] - wire _T_199 = _T_181 & _T_17; // @[el2_ifu_iccm_mem.scala 72:77] - wire _T_200 = _T_193 | _T_199; // @[el2_ifu_iccm_mem.scala 71:179] - wire _T_207 = _T_174 & _T_20; // @[el2_ifu_iccm_mem.scala 71:145] - wire _T_208 = redundant_valid[0] & _T_207; // @[el2_ifu_iccm_mem.scala 71:71] - wire _T_214 = _T_181 & _T_22; // @[el2_ifu_iccm_mem.scala 72:77] - wire _T_215 = _T_208 | _T_214; // @[el2_ifu_iccm_mem.scala 71:179] - wire _T_222 = _T_174 & _T_25; // @[el2_ifu_iccm_mem.scala 71:145] - wire _T_223 = redundant_valid[0] & _T_222; // @[el2_ifu_iccm_mem.scala 71:71] - wire _T_229 = _T_181 & _T_27; // @[el2_ifu_iccm_mem.scala 72:77] - wire _T_230 = _T_223 | _T_229; // @[el2_ifu_iccm_mem.scala 71:179] - wire [3:0] sel_red0 = {_T_230,_T_215,_T_200,_T_185}; // @[Cat.scala 29:58] - reg [3:0] sel_red0_q; // @[el2_ifu_iccm_mem.scala 74:27] - reg [3:0] sel_red1_q; // @[el2_ifu_iccm_mem.scala 75:27] - wire _T_238 = ~sel_red0_q[0]; // @[el2_ifu_iccm_mem.scala 81:36] - wire _T_240 = ~sel_red1_q[0]; // @[el2_ifu_iccm_mem.scala 81:53] - wire _T_241 = _T_238 & _T_240; // @[el2_ifu_iccm_mem.scala 81:51] + wire _T_178 = io_iccm_rw_addr[14:1] == redundant_address_0; // @[el2_ifu_iccm_mem.scala 72:105] + wire _T_181 = _T_178 & _T_10; // @[el2_ifu_iccm_mem.scala 72:145] + wire _T_182 = redundant_valid[0] & _T_181; // @[el2_ifu_iccm_mem.scala 72:71] + wire _T_185 = addr_bank_inc[14:1] == redundant_address_0; // @[el2_ifu_iccm_mem.scala 73:37] + wire _T_188 = _T_185 & _T_12; // @[el2_ifu_iccm_mem.scala 73:77] + wire _T_189 = _T_182 | _T_188; // @[el2_ifu_iccm_mem.scala 72:179] + wire _T_196 = _T_178 & _T_15; // @[el2_ifu_iccm_mem.scala 72:145] + wire _T_197 = redundant_valid[0] & _T_196; // @[el2_ifu_iccm_mem.scala 72:71] + wire _T_203 = _T_185 & _T_17; // @[el2_ifu_iccm_mem.scala 73:77] + wire _T_204 = _T_197 | _T_203; // @[el2_ifu_iccm_mem.scala 72:179] + wire _T_211 = _T_178 & _T_20; // @[el2_ifu_iccm_mem.scala 72:145] + wire _T_212 = redundant_valid[0] & _T_211; // @[el2_ifu_iccm_mem.scala 72:71] + wire _T_218 = _T_185 & _T_22; // @[el2_ifu_iccm_mem.scala 73:77] + wire _T_219 = _T_212 | _T_218; // @[el2_ifu_iccm_mem.scala 72:179] + wire _T_226 = _T_178 & _T_25; // @[el2_ifu_iccm_mem.scala 72:145] + wire _T_227 = redundant_valid[0] & _T_226; // @[el2_ifu_iccm_mem.scala 72:71] + wire _T_233 = _T_185 & _T_27; // @[el2_ifu_iccm_mem.scala 73:77] + wire _T_234 = _T_227 | _T_233; // @[el2_ifu_iccm_mem.scala 72:179] + wire [3:0] sel_red0 = {_T_234,_T_219,_T_204,_T_189}; // @[Cat.scala 29:58] + reg [3:0] sel_red0_q; // @[el2_ifu_iccm_mem.scala 75:27] + reg [3:0] sel_red1_q; // @[el2_ifu_iccm_mem.scala 76:27] + wire _T_242 = ~sel_red0_q[0]; // @[el2_ifu_iccm_mem.scala 82:36] + wire _T_244 = ~sel_red1_q[0]; // @[el2_ifu_iccm_mem.scala 82:53] + wire _T_245 = _T_242 & _T_244; // @[el2_ifu_iccm_mem.scala 82:51] reg [38:0] redundant_data_1; // @[Reg.scala 27:20] - wire [38:0] _T_243 = sel_red1_q[0] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_247 = sel_red1_q[0] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] reg [38:0] redundant_data_0; // @[Reg.scala 27:20] - wire [38:0] _T_244 = sel_red0_q[0] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_245 = _T_241 ? iccm_bank_dout_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_246 = _T_243 | _T_244; // @[Mux.scala 27:72] - wire [38:0] iccm_bank_dout_fn_0 = _T_246 | _T_245; // @[Mux.scala 27:72] - wire _T_253 = ~sel_red0_q[1]; // @[el2_ifu_iccm_mem.scala 81:36] - wire _T_255 = ~sel_red1_q[1]; // @[el2_ifu_iccm_mem.scala 81:53] - wire _T_256 = _T_253 & _T_255; // @[el2_ifu_iccm_mem.scala 81:51] - wire [38:0] _T_258 = sel_red1_q[1] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_259 = sel_red0_q[1] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_260 = _T_256 ? iccm_bank_dout_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_261 = _T_258 | _T_259; // @[Mux.scala 27:72] - wire [38:0] iccm_bank_dout_fn_1 = _T_261 | _T_260; // @[Mux.scala 27:72] - wire _T_268 = ~sel_red0_q[2]; // @[el2_ifu_iccm_mem.scala 81:36] - wire _T_270 = ~sel_red1_q[2]; // @[el2_ifu_iccm_mem.scala 81:53] - wire _T_271 = _T_268 & _T_270; // @[el2_ifu_iccm_mem.scala 81:51] - wire [38:0] _T_273 = sel_red1_q[2] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_274 = sel_red0_q[2] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_275 = _T_271 ? iccm_bank_dout_2 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_276 = _T_273 | _T_274; // @[Mux.scala 27:72] - wire [38:0] iccm_bank_dout_fn_2 = _T_276 | _T_275; // @[Mux.scala 27:72] - wire _T_283 = ~sel_red0_q[3]; // @[el2_ifu_iccm_mem.scala 81:36] - wire _T_285 = ~sel_red1_q[3]; // @[el2_ifu_iccm_mem.scala 81:53] - wire _T_286 = _T_283 & _T_285; // @[el2_ifu_iccm_mem.scala 81:51] - wire [38:0] _T_288 = sel_red1_q[3] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_289 = sel_red0_q[3] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_290 = _T_286 ? iccm_bank_dout_3 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_291 = _T_288 | _T_289; // @[Mux.scala 27:72] - wire [38:0] iccm_bank_dout_fn_3 = _T_291 | _T_290; // @[Mux.scala 27:72] + wire [38:0] _T_248 = sel_red0_q[0] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_249 = _T_245 ? iccm_bank_dout_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_250 = _T_247 | _T_248; // @[Mux.scala 27:72] + wire [38:0] iccm_bank_dout_fn_0 = _T_250 | _T_249; // @[Mux.scala 27:72] + wire _T_257 = ~sel_red0_q[1]; // @[el2_ifu_iccm_mem.scala 82:36] + wire _T_259 = ~sel_red1_q[1]; // @[el2_ifu_iccm_mem.scala 82:53] + wire _T_260 = _T_257 & _T_259; // @[el2_ifu_iccm_mem.scala 82:51] + wire [38:0] _T_262 = sel_red1_q[1] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_263 = sel_red0_q[1] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_264 = _T_260 ? iccm_bank_dout_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_265 = _T_262 | _T_263; // @[Mux.scala 27:72] + wire [38:0] iccm_bank_dout_fn_1 = _T_265 | _T_264; // @[Mux.scala 27:72] + wire _T_272 = ~sel_red0_q[2]; // @[el2_ifu_iccm_mem.scala 82:36] + wire _T_274 = ~sel_red1_q[2]; // @[el2_ifu_iccm_mem.scala 82:53] + wire _T_275 = _T_272 & _T_274; // @[el2_ifu_iccm_mem.scala 82:51] + wire [38:0] _T_277 = sel_red1_q[2] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_278 = sel_red0_q[2] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_279 = _T_275 ? iccm_bank_dout_2 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_280 = _T_277 | _T_278; // @[Mux.scala 27:72] + wire [38:0] iccm_bank_dout_fn_2 = _T_280 | _T_279; // @[Mux.scala 27:72] + wire _T_287 = ~sel_red0_q[3]; // @[el2_ifu_iccm_mem.scala 82:36] + wire _T_289 = ~sel_red1_q[3]; // @[el2_ifu_iccm_mem.scala 82:53] + wire _T_290 = _T_287 & _T_289; // @[el2_ifu_iccm_mem.scala 82:51] + wire [38:0] _T_292 = sel_red1_q[3] ? redundant_data_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_293 = sel_red0_q[3] ? redundant_data_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_294 = _T_290 ? iccm_bank_dout_3 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_295 = _T_292 | _T_293; // @[Mux.scala 27:72] + wire [38:0] iccm_bank_dout_fn_3 = _T_295 | _T_294; // @[Mux.scala 27:72] reg redundant_lru; // @[Reg.scala 27:20] - wire _T_293 = ~redundant_lru; // @[el2_ifu_iccm_mem.scala 83:20] - wire r0_addr_en = _T_293 & io_iccm_buf_correct_ecc; // @[el2_ifu_iccm_mem.scala 83:35] - wire r1_addr_en = redundant_lru & io_iccm_buf_correct_ecc; // @[el2_ifu_iccm_mem.scala 84:35] - wire _T_294 = |sel_red0; // @[el2_ifu_iccm_mem.scala 85:63] - wire _T_295 = |sel_red1; // @[el2_ifu_iccm_mem.scala 85:78] - wire _T_296 = _T_294 | _T_295; // @[el2_ifu_iccm_mem.scala 85:67] - wire _T_297 = _T_296 & io_iccm_rden; // @[el2_ifu_iccm_mem.scala 85:83] - wire _T_298 = _T_297 & io_iccm_correction_state; // @[el2_ifu_iccm_mem.scala 85:98] - wire redundant_lru_en = io_iccm_buf_correct_ecc | _T_298; // @[el2_ifu_iccm_mem.scala 85:50] - wire _GEN_23 = r1_addr_en | _T_309; // @[Reg.scala 28:19] - wire _GEN_24 = r0_addr_en | _T_310; // @[Reg.scala 28:19] - wire _T_314 = io_iccm_rw_addr[14:2] == redundant_address_0[13:1]; // @[el2_ifu_iccm_mem.scala 92:61] - wire _T_317 = io_iccm_rw_addr[1] & redundant_address_0[0]; // @[el2_ifu_iccm_mem.scala 93:26] - wire _T_320 = _T_317 | _T_1; // @[el2_ifu_iccm_mem.scala 93:52] - wire _T_321 = _T_314 & _T_320; // @[el2_ifu_iccm_mem.scala 92:102] - wire _T_323 = _T_321 & redundant_valid[0]; // @[el2_ifu_iccm_mem.scala 93:84] - wire _T_324 = _T_323 & io_iccm_wren; // @[el2_ifu_iccm_mem.scala 93:105] - wire redundant_data0_en = _T_324 | r0_addr_en; // @[el2_ifu_iccm_mem.scala 93:121] - wire _T_333 = redundant_address_0[0] & _T_1; // @[el2_ifu_iccm_mem.scala 95:104] - wire _T_334 = _T_317 | _T_333; // @[el2_ifu_iccm_mem.scala 95:78] - wire _T_342 = io_iccm_rw_addr[14:2] == redundant_address_1[13:1]; // @[el2_ifu_iccm_mem.scala 99:61] - wire _T_345 = io_iccm_rw_addr[1] & redundant_address_1[0]; // @[el2_ifu_iccm_mem.scala 100:26] - wire _T_348 = _T_345 | _T_1; // @[el2_ifu_iccm_mem.scala 100:52] - wire _T_349 = _T_342 & _T_348; // @[el2_ifu_iccm_mem.scala 99:102] - wire _T_351 = _T_349 & redundant_valid[1]; // @[el2_ifu_iccm_mem.scala 100:84] - wire _T_352 = _T_351 & io_iccm_wren; // @[el2_ifu_iccm_mem.scala 100:105] - wire redundant_data1_en = _T_352 | r0_addr_en; // @[el2_ifu_iccm_mem.scala 100:121] - wire _T_361 = redundant_address_1[0] & _T_1; // @[el2_ifu_iccm_mem.scala 102:104] - wire _T_362 = _T_345 | _T_361; // @[el2_ifu_iccm_mem.scala 102:78] - reg [2:0] iccm_rd_addr_lo_q; // @[el2_ifu_iccm_mem.scala 106:34] - reg [1:0] iccm_rd_addr_hi_q; // @[el2_ifu_iccm_mem.scala 107:34] - wire _T_370 = iccm_rd_addr_hi_q == 2'h0; // @[el2_ifu_iccm_mem.scala 109:86] - wire _T_372 = iccm_rd_addr_hi_q == 2'h1; // @[el2_ifu_iccm_mem.scala 109:86] - wire _T_374 = iccm_rd_addr_hi_q == 2'h2; // @[el2_ifu_iccm_mem.scala 109:86] - wire _T_376 = iccm_rd_addr_hi_q == 2'h3; // @[el2_ifu_iccm_mem.scala 109:86] - wire [31:0] _T_378 = _T_370 ? iccm_bank_dout_fn_0[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_379 = _T_372 ? iccm_bank_dout_fn_1[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_380 = _T_374 ? iccm_bank_dout_fn_2[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_381 = _T_376 ? iccm_bank_dout_fn_3[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_382 = _T_378 | _T_379; // @[Mux.scala 27:72] - wire [31:0] _T_383 = _T_382 | _T_380; // @[Mux.scala 27:72] - wire [31:0] _T_384 = _T_383 | _T_381; // @[Mux.scala 27:72] - wire _T_387 = iccm_rd_addr_lo_q[1:0] == 2'h0; // @[el2_ifu_iccm_mem.scala 110:77] - wire _T_390 = iccm_rd_addr_lo_q[1:0] == 2'h1; // @[el2_ifu_iccm_mem.scala 110:77] - wire _T_393 = iccm_rd_addr_lo_q[1:0] == 2'h2; // @[el2_ifu_iccm_mem.scala 110:77] - wire _T_396 = iccm_rd_addr_lo_q[1:0] == 2'h3; // @[el2_ifu_iccm_mem.scala 110:77] - wire [31:0] _T_398 = _T_387 ? iccm_bank_dout_fn_0[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_399 = _T_390 ? iccm_bank_dout_fn_1[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_400 = _T_393 ? iccm_bank_dout_fn_2[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_401 = _T_396 ? iccm_bank_dout_fn_3[31:0] : 32'h0; // @[Mux.scala 27:72] - wire [31:0] _T_402 = _T_398 | _T_399; // @[Mux.scala 27:72] - wire [31:0] _T_403 = _T_402 | _T_400; // @[Mux.scala 27:72] - wire [31:0] _T_404 = _T_403 | _T_401; // @[Mux.scala 27:72] - wire [63:0] iccm_rd_data_pre = {_T_384,_T_404}; // @[Cat.scala 29:58] - wire [63:0] _T_410 = {16'h0,iccm_rd_data_pre[63:16]}; // @[Cat.scala 29:58] - wire [38:0] _T_416 = _T_370 ? iccm_bank_dout_fn_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_417 = _T_372 ? iccm_bank_dout_fn_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_418 = _T_374 ? iccm_bank_dout_fn_2 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_419 = _T_376 ? iccm_bank_dout_fn_3 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_420 = _T_416 | _T_417; // @[Mux.scala 27:72] - wire [38:0] _T_421 = _T_420 | _T_418; // @[Mux.scala 27:72] - wire [38:0] _T_422 = _T_421 | _T_419; // @[Mux.scala 27:72] - wire [38:0] _T_432 = _T_387 ? iccm_bank_dout_fn_0 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_433 = _T_390 ? iccm_bank_dout_fn_1 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_434 = _T_393 ? iccm_bank_dout_fn_2 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_435 = _T_396 ? iccm_bank_dout_fn_3 : 39'h0; // @[Mux.scala 27:72] - wire [38:0] _T_436 = _T_432 | _T_433; // @[Mux.scala 27:72] - wire [38:0] _T_437 = _T_436 | _T_434; // @[Mux.scala 27:72] - wire [38:0] _T_438 = _T_437 | _T_435; // @[Mux.scala 27:72] - assign _T_81__T_101_addr = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; - assign _T_81__T_101_data = _T_81[_T_81__T_101_addr]; // @[el2_ifu_iccm_mem.scala 42:51] - assign _T_81__T_97_data = io_iccm_wr_data[38:0]; - assign _T_81__T_97_addr = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; - assign _T_81__T_97_mask = 1'h1; - assign _T_81__T_97_en = iccm_clken_0 & wren_bank_0; - assign _T_82__T_103_addr = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_66; - assign _T_82__T_103_data = _T_82[_T_82__T_103_addr]; // @[el2_ifu_iccm_mem.scala 42:51] - assign _T_82__T_98_data = io_iccm_wr_data[77:39]; - assign _T_82__T_98_addr = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_66; - assign _T_82__T_98_mask = 1'h1; - assign _T_82__T_98_en = iccm_clken_1 & wren_bank_1; - assign _T_83__T_105_addr = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_73; - assign _T_83__T_105_data = _T_83[_T_83__T_105_addr]; // @[el2_ifu_iccm_mem.scala 42:51] - assign _T_83__T_99_data = io_iccm_wr_data[38:0]; - assign _T_83__T_99_addr = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_73; - assign _T_83__T_99_mask = 1'h1; - assign _T_83__T_99_en = iccm_clken_2 & wren_bank_2; - assign _T_84__T_107_addr = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_80; - assign _T_84__T_107_data = _T_84[_T_84__T_107_addr]; // @[el2_ifu_iccm_mem.scala 42:51] - assign _T_84__T_100_data = io_iccm_wr_data[77:39]; - assign _T_84__T_100_addr = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_80; - assign _T_84__T_100_mask = 1'h1; - assign _T_84__T_100_en = iccm_clken_3 & wren_bank_3; - assign io_iccm_rd_data = iccm_rd_addr_lo_q[0] ? _T_410 : iccm_rd_data_pre; // @[el2_ifu_iccm_mem.scala 22:19 el2_ifu_iccm_mem.scala 111:19] - assign io_iccm_rd_data_ecc = {_T_422,_T_438}; // @[el2_ifu_iccm_mem.scala 23:23 el2_ifu_iccm_mem.scala 112:23] - assign io_iccm_bank_addr_0 = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; // @[el2_ifu_iccm_mem.scala 60:21] - assign io_iccm_bank_addr_1 = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_66; // @[el2_ifu_iccm_mem.scala 60:21] - assign io_iccm_bank_addr_2 = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_73; // @[el2_ifu_iccm_mem.scala 60:21] - assign io_iccm_bank_addr_3 = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_80; // @[el2_ifu_iccm_mem.scala 60:21] + wire _T_297 = ~redundant_lru; // @[el2_ifu_iccm_mem.scala 84:20] + wire r0_addr_en = _T_297 & io_iccm_buf_correct_ecc; // @[el2_ifu_iccm_mem.scala 84:35] + wire r1_addr_en = redundant_lru & io_iccm_buf_correct_ecc; // @[el2_ifu_iccm_mem.scala 85:35] + wire _T_298 = |sel_red0; // @[el2_ifu_iccm_mem.scala 86:63] + wire _T_299 = |sel_red1; // @[el2_ifu_iccm_mem.scala 86:78] + wire _T_300 = _T_298 | _T_299; // @[el2_ifu_iccm_mem.scala 86:67] + wire _T_301 = _T_300 & io_iccm_rden; // @[el2_ifu_iccm_mem.scala 86:83] + wire _T_302 = _T_301 & io_iccm_correction_state; // @[el2_ifu_iccm_mem.scala 86:98] + wire redundant_lru_en = io_iccm_buf_correct_ecc | _T_302; // @[el2_ifu_iccm_mem.scala 86:50] + wire _GEN_23 = r1_addr_en | _T_313; // @[Reg.scala 28:19] + wire _GEN_24 = r0_addr_en | _T_314; // @[Reg.scala 28:19] + wire _T_318 = io_iccm_rw_addr[14:2] == redundant_address_0[13:1]; // @[el2_ifu_iccm_mem.scala 93:61] + wire _T_321 = io_iccm_rw_addr[1] & redundant_address_0[0]; // @[el2_ifu_iccm_mem.scala 94:26] + wire _T_324 = _T_321 | _T_1; // @[el2_ifu_iccm_mem.scala 94:52] + wire _T_325 = _T_318 & _T_324; // @[el2_ifu_iccm_mem.scala 93:102] + wire _T_327 = _T_325 & redundant_valid[0]; // @[el2_ifu_iccm_mem.scala 94:84] + wire _T_328 = _T_327 & io_iccm_wren; // @[el2_ifu_iccm_mem.scala 94:105] + wire redundant_data0_en = _T_328 | r0_addr_en; // @[el2_ifu_iccm_mem.scala 94:121] + wire _T_337 = redundant_address_0[0] & _T_1; // @[el2_ifu_iccm_mem.scala 96:104] + wire _T_338 = _T_321 | _T_337; // @[el2_ifu_iccm_mem.scala 96:78] + wire _T_346 = io_iccm_rw_addr[14:2] == redundant_address_1[13:1]; // @[el2_ifu_iccm_mem.scala 100:61] + wire _T_349 = io_iccm_rw_addr[1] & redundant_address_1[0]; // @[el2_ifu_iccm_mem.scala 101:26] + wire _T_352 = _T_349 | _T_1; // @[el2_ifu_iccm_mem.scala 101:52] + wire _T_353 = _T_346 & _T_352; // @[el2_ifu_iccm_mem.scala 100:102] + wire _T_355 = _T_353 & redundant_valid[1]; // @[el2_ifu_iccm_mem.scala 101:84] + wire _T_356 = _T_355 & io_iccm_wren; // @[el2_ifu_iccm_mem.scala 101:105] + wire redundant_data1_en = _T_356 | r0_addr_en; // @[el2_ifu_iccm_mem.scala 101:121] + wire _T_365 = redundant_address_1[0] & _T_1; // @[el2_ifu_iccm_mem.scala 103:104] + wire _T_366 = _T_349 | _T_365; // @[el2_ifu_iccm_mem.scala 103:78] + reg [2:0] iccm_rd_addr_lo_q; // @[el2_ifu_iccm_mem.scala 107:34] + reg [1:0] iccm_rd_addr_hi_q; // @[el2_ifu_iccm_mem.scala 108:34] + wire _T_374 = iccm_rd_addr_hi_q == 2'h0; // @[el2_ifu_iccm_mem.scala 110:86] + wire _T_376 = iccm_rd_addr_hi_q == 2'h1; // @[el2_ifu_iccm_mem.scala 110:86] + wire _T_378 = iccm_rd_addr_hi_q == 2'h2; // @[el2_ifu_iccm_mem.scala 110:86] + wire _T_380 = iccm_rd_addr_hi_q == 2'h3; // @[el2_ifu_iccm_mem.scala 110:86] + wire [31:0] _T_382 = _T_374 ? iccm_bank_dout_fn_0[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_383 = _T_376 ? iccm_bank_dout_fn_1[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_384 = _T_378 ? iccm_bank_dout_fn_2[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_385 = _T_380 ? iccm_bank_dout_fn_3[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_386 = _T_382 | _T_383; // @[Mux.scala 27:72] + wire [31:0] _T_387 = _T_386 | _T_384; // @[Mux.scala 27:72] + wire [31:0] _T_388 = _T_387 | _T_385; // @[Mux.scala 27:72] + wire _T_391 = iccm_rd_addr_lo_q[1:0] == 2'h0; // @[el2_ifu_iccm_mem.scala 111:77] + wire _T_394 = iccm_rd_addr_lo_q[1:0] == 2'h1; // @[el2_ifu_iccm_mem.scala 111:77] + wire _T_397 = iccm_rd_addr_lo_q[1:0] == 2'h2; // @[el2_ifu_iccm_mem.scala 111:77] + wire _T_400 = iccm_rd_addr_lo_q[1:0] == 2'h3; // @[el2_ifu_iccm_mem.scala 111:77] + wire [31:0] _T_402 = _T_391 ? iccm_bank_dout_fn_0[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_403 = _T_394 ? iccm_bank_dout_fn_1[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_404 = _T_397 ? iccm_bank_dout_fn_2[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_405 = _T_400 ? iccm_bank_dout_fn_3[31:0] : 32'h0; // @[Mux.scala 27:72] + wire [31:0] _T_406 = _T_402 | _T_403; // @[Mux.scala 27:72] + wire [31:0] _T_407 = _T_406 | _T_404; // @[Mux.scala 27:72] + wire [31:0] _T_408 = _T_407 | _T_405; // @[Mux.scala 27:72] + wire [63:0] iccm_rd_data_pre = {_T_388,_T_408}; // @[Cat.scala 29:58] + wire [63:0] _T_414 = {16'h0,iccm_rd_data_pre[63:16]}; // @[Cat.scala 29:58] + wire [38:0] _T_420 = _T_374 ? iccm_bank_dout_fn_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_421 = _T_376 ? iccm_bank_dout_fn_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_422 = _T_378 ? iccm_bank_dout_fn_2 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_423 = _T_380 ? iccm_bank_dout_fn_3 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_424 = _T_420 | _T_421; // @[Mux.scala 27:72] + wire [38:0] _T_425 = _T_424 | _T_422; // @[Mux.scala 27:72] + wire [38:0] _T_426 = _T_425 | _T_423; // @[Mux.scala 27:72] + wire [38:0] _T_436 = _T_391 ? iccm_bank_dout_fn_0 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_437 = _T_394 ? iccm_bank_dout_fn_1 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_438 = _T_397 ? iccm_bank_dout_fn_2 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_439 = _T_400 ? iccm_bank_dout_fn_3 : 39'h0; // @[Mux.scala 27:72] + wire [38:0] _T_440 = _T_436 | _T_437; // @[Mux.scala 27:72] + wire [38:0] _T_441 = _T_440 | _T_438; // @[Mux.scala 27:72] + wire [38:0] _T_442 = _T_441 | _T_439; // @[Mux.scala 27:72] + assign _T_85__T_105_addr = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; + assign _T_85__T_105_data = _T_85[_T_85__T_105_addr]; // @[el2_ifu_iccm_mem.scala 43:51] + assign _T_85__T_101_data = io_iccm_wr_data[38:0]; + assign _T_85__T_101_addr = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; + assign _T_85__T_101_mask = 1'h1; + assign _T_85__T_101_en = iccm_clken_0 & wren_bank_0; + assign _T_86__T_107_addr = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_67; + assign _T_86__T_107_data = _T_86[_T_86__T_107_addr]; // @[el2_ifu_iccm_mem.scala 43:51] + assign _T_86__T_102_data = io_iccm_wr_data[77:39]; + assign _T_86__T_102_addr = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_67; + assign _T_86__T_102_mask = 1'h1; + assign _T_86__T_102_en = iccm_clken_1 & wren_bank_1; + assign _T_87__T_109_addr = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_75; + assign _T_87__T_109_data = _T_87[_T_87__T_109_addr]; // @[el2_ifu_iccm_mem.scala 43:51] + assign _T_87__T_103_data = io_iccm_wr_data[38:0]; + assign _T_87__T_103_addr = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_75; + assign _T_87__T_103_mask = 1'h1; + assign _T_87__T_103_en = iccm_clken_2 & wren_bank_2; + assign _T_88__T_111_addr = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_83; + assign _T_88__T_111_data = _T_88[_T_88__T_111_addr]; // @[el2_ifu_iccm_mem.scala 43:51] + assign _T_88__T_104_data = io_iccm_wr_data[77:39]; + assign _T_88__T_104_addr = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_83; + assign _T_88__T_104_mask = 1'h1; + assign _T_88__T_104_en = iccm_clken_3 & wren_bank_3; + assign io_iccm_rd_data = iccm_rd_addr_lo_q[0] ? _T_414 : iccm_rd_data_pre; // @[el2_ifu_iccm_mem.scala 22:19 el2_ifu_iccm_mem.scala 112:19] + assign io_iccm_rd_data_ecc = {_T_426,_T_442}; // @[el2_ifu_iccm_mem.scala 23:23 el2_ifu_iccm_mem.scala 113:23] + assign io_iccm_bank_addr_0 = wren_bank_0 ? io_iccm_rw_addr[14:3] : _T_59; // @[el2_ifu_iccm_mem.scala 61:21] + assign io_iccm_bank_addr_1 = wren_bank_1 ? io_iccm_rw_addr[14:3] : _T_67; // @[el2_ifu_iccm_mem.scala 61:21] + assign io_iccm_bank_addr_2 = wren_bank_2 ? io_iccm_rw_addr[14:3] : _T_75; // @[el2_ifu_iccm_mem.scala 61:21] + assign io_iccm_bank_addr_3 = wren_bank_3 ? io_iccm_rw_addr[14:3] : _T_83; // @[el2_ifu_iccm_mem.scala 61:21] `ifdef RANDOMIZE_GARBAGE_ASSIGN `define RANDOMIZE `endif @@ -330,16 +330,16 @@ initial begin `ifdef RANDOMIZE_MEM_INIT _RAND_0 = {2{`RANDOM}}; for (initvar = 0; initvar < 4096; initvar = initvar+1) - _T_81[initvar] = _RAND_0[38:0]; + _T_85[initvar] = _RAND_0[38:0]; _RAND_1 = {2{`RANDOM}}; for (initvar = 0; initvar < 4096; initvar = initvar+1) - _T_82[initvar] = _RAND_1[38:0]; + _T_86[initvar] = _RAND_1[38:0]; _RAND_2 = {2{`RANDOM}}; for (initvar = 0; initvar < 4096; initvar = initvar+1) - _T_83[initvar] = _RAND_2[38:0]; + _T_87[initvar] = _RAND_2[38:0]; _RAND_3 = {2{`RANDOM}}; for (initvar = 0; initvar < 4096; initvar = initvar+1) - _T_84[initvar] = _RAND_3[38:0]; + _T_88[initvar] = _RAND_3[38:0]; `endif // RANDOMIZE_MEM_INIT `ifdef RANDOMIZE_REG_INIT _RAND_4 = {2{`RANDOM}}; @@ -351,9 +351,9 @@ initial begin _RAND_7 = {2{`RANDOM}}; iccm_bank_dout_3 = _RAND_7[38:0]; _RAND_8 = {1{`RANDOM}}; - _T_309 = _RAND_8[0:0]; + _T_313 = _RAND_8[0:0]; _RAND_9 = {1{`RANDOM}}; - _T_310 = _RAND_9[0:0]; + _T_314 = _RAND_9[0:0]; _RAND_10 = {1{`RANDOM}}; redundant_address_1 = _RAND_10[13:0]; _RAND_11 = {1{`RANDOM}}; @@ -380,31 +380,31 @@ end // initial `endif `endif // SYNTHESIS always @(posedge clock) begin - if(_T_81__T_97_en & _T_81__T_97_mask) begin - _T_81[_T_81__T_97_addr] <= _T_81__T_97_data; // @[el2_ifu_iccm_mem.scala 42:51] + if(_T_85__T_101_en & _T_85__T_101_mask) begin + _T_85[_T_85__T_101_addr] <= _T_85__T_101_data; // @[el2_ifu_iccm_mem.scala 43:51] end - if(_T_82__T_98_en & _T_82__T_98_mask) begin - _T_82[_T_82__T_98_addr] <= _T_82__T_98_data; // @[el2_ifu_iccm_mem.scala 42:51] + if(_T_86__T_102_en & _T_86__T_102_mask) begin + _T_86[_T_86__T_102_addr] <= _T_86__T_102_data; // @[el2_ifu_iccm_mem.scala 43:51] end - if(_T_83__T_99_en & _T_83__T_99_mask) begin - _T_83[_T_83__T_99_addr] <= _T_83__T_99_data; // @[el2_ifu_iccm_mem.scala 42:51] + if(_T_87__T_103_en & _T_87__T_103_mask) begin + _T_87[_T_87__T_103_addr] <= _T_87__T_103_data; // @[el2_ifu_iccm_mem.scala 43:51] end - if(_T_84__T_100_en & _T_84__T_100_mask) begin - _T_84[_T_84__T_100_addr] <= _T_84__T_100_data; // @[el2_ifu_iccm_mem.scala 42:51] + if(_T_88__T_104_en & _T_88__T_104_mask) begin + _T_88[_T_88__T_104_addr] <= _T_88__T_104_data; // @[el2_ifu_iccm_mem.scala 43:51] end - iccm_bank_dout_0 <= _T_81__T_101_data; - iccm_bank_dout_1 <= _T_82__T_103_data; - iccm_bank_dout_2 <= _T_83__T_105_data; - iccm_bank_dout_3 <= _T_84__T_107_data; + iccm_bank_dout_0 <= _T_85__T_105_data; + iccm_bank_dout_1 <= _T_86__T_107_data; + iccm_bank_dout_2 <= _T_87__T_109_data; + iccm_bank_dout_3 <= _T_88__T_111_data; if (reset) begin - _T_309 <= 1'h0; + _T_313 <= 1'h0; end else begin - _T_309 <= _GEN_23; + _T_313 <= _GEN_23; end if (reset) begin - _T_310 <= 1'h0; + _T_314 <= 1'h0; end else begin - _T_310 <= _GEN_24; + _T_314 <= _GEN_24; end if (reset) begin redundant_address_1 <= 14'h0; @@ -429,7 +429,7 @@ end // initial if (reset) begin redundant_data_1 <= 39'h0; end else if (redundant_data1_en) begin - if (_T_362) begin + if (_T_366) begin redundant_data_1 <= iccm_bank_wr_data_1; end else begin redundant_data_1 <= iccm_bank_wr_data_0; @@ -438,7 +438,7 @@ end // initial if (reset) begin redundant_data_0 <= 39'h0; end else if (redundant_data0_en) begin - if (_T_334) begin + if (_T_338) begin redundant_data_0 <= iccm_bank_wr_data_1; end else begin redundant_data_0 <= iccm_bank_wr_data_0; @@ -448,9 +448,9 @@ end // initial redundant_lru <= 1'h0; end else if (redundant_lru_en) begin if (io_iccm_buf_correct_ecc) begin - redundant_lru <= _T_293; + redundant_lru <= _T_297; end else begin - redundant_lru <= _T_294; + redundant_lru <= _T_298; end end if (reset) begin diff --git a/src/main/scala/ifu/el2_ifu_iccm_mem.scala b/src/main/scala/ifu/el2_ifu_iccm_mem.scala index a3de84e4..be9d19c0 100644 --- a/src/main/scala/ifu/el2_ifu_iccm_mem.scala +++ b/src/main/scala/ifu/el2_ifu_iccm_mem.scala @@ -35,8 +35,9 @@ class el2_ifu_iccm_mem extends Module with el2_lib { val rden_bank = (0 until ICCM_NUM_BANKS).map(i=> io.iccm_rden&(io.iccm_rw_addr(ICCM_BANK_HI-1,1)===i.U)|(addr_bank_inc(ICCM_BANK_HI-1,1)===i.U)) val iccm_clken = for(i<- 0 until ICCM_NUM_BANKS) yield wren_bank(i) | rden_bank(i) | io.clk_override - val addr_bank = (0 until ICCM_NUM_BANKS).map(i=> Mux(wren_bank(i).asBool, io.iccm_rw_addr(ICCM_BITS-2, ICCM_BANK_INDEX_LO-1), - Mux((addr_bank_inc(ICCM_BANK_HI-1,1)===i.U),addr_bank_inc(ICCM_BITS-2,ICCM_BANK_INDEX_LO-1),io.iccm_rw_addr(ICCM_BITS-2,ICCM_BANK_INDEX_LO-1)))) + val addr_bank = Wire(Vec(ICCM_NUM_BANKS, UInt((ICCM_BITS-ICCM_BANK_INDEX_LO).W))) + for(i<-0 until ICCM_NUM_BANKS) {addr_bank(i) := Mux(wren_bank(i).asBool, io.iccm_rw_addr(ICCM_BITS-2, ICCM_BANK_INDEX_LO-1), + Mux((addr_bank_inc(ICCM_BANK_HI-1,1)===i.U),addr_bank_inc(ICCM_BITS-2,ICCM_BANK_INDEX_LO-1),io.iccm_rw_addr(ICCM_BITS-2,ICCM_BANK_INDEX_LO-1)))} val iccm_mem = new Array[Mem[UInt]](ICCM_NUM_BANKS) for(i<-0 until ICCM_NUM_BANKS) iccm_mem(i) = Mem(pow(2, ICCM_INDEX_BITS).intValue, UInt(39.W)) diff --git a/target/scala-2.12/classes/ifu/el2_ifu_iccm_mem.class b/target/scala-2.12/classes/ifu/el2_ifu_iccm_mem.class index 10cd941d78749f50b5e5ed831f118de1f8442532..674e199ef1a7cbafd590d6d2854ade855f3217cd 100644 GIT binary patch delta 12259 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 wi^QXzJG=3FUusx`jg!A{`YM6 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 W1n)!=QXpjUwknZ7#6oALg#14tBJO1X diff --git a/target/scala-2.12/classes/ifu/ifu_iccm$.class b/target/scala-2.12/classes/ifu/ifu_iccm$.class index 2828534ad3d4a7dccdbc09aff7dc4f58fce52c56..71d080c01b4d6e3572796e8b7ed1efec0db8318f 100644 GIT binary patch delta 114 zcmZ1@w?=NmbrwdW%{N#i*%(VEEAWU;X6M!bvLa)0IA9%kpKVy delta 114 zcmZ1@w?=Nmbrwd$%{N#i*%*r_EAWU;X6M!bvLa)0H*08g8%>k diff --git a/target/scala-2.12/classes/ifu/ifu_iccm$delayedInit$body.class b/target/scala-2.12/classes/ifu/ifu_iccm$delayedInit$body.class index ee2c6fb16d05a76227e27474c30b3f4cd3a8177b..d39718fb30a65cbf2ac35adcfa161f23edef8c5a 100644 GIT binary patch delta 19 ZcmaFP`kZxx7ZYR2WN)SbAUTK08vsTT25SHS delta 19 ZcmaFP`kZxx7ZYRgWN)SbAUTK08vsTD25A5Q