shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 1 | module chip_io( |
| 2 | // Package Pins |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 3 | inout vdd3v3, |
| 4 | inout vdd1v8, |
| 5 | inout vss, |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 6 | inout gpio, |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 7 | inout clock, |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 8 | inout resetb, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 9 | output flash_csb, |
| 10 | output flash_clk, |
| 11 | output flash_io0, |
| 12 | output flash_io1, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 13 | // Chip Core Interface |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 14 | output porb_h, |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 15 | output clock_core, |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 16 | input gpio_out_core, |
| 17 | output gpio_in_core, |
| 18 | input gpio_mode0_core, |
| 19 | input gpio_mode1_core, |
| 20 | input gpio_outenb_core, |
| 21 | input gpio_inenb_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 22 | input flash_csb_core, |
| 23 | input flash_clk_core, |
| 24 | input flash_csb_oeb_core, |
| 25 | input flash_clk_oeb_core, |
| 26 | input flash_io0_oeb_core, |
| 27 | input flash_io1_oeb_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 28 | input flash_csb_ieb_core, |
| 29 | input flash_clk_ieb_core, |
| 30 | input flash_io0_ieb_core, |
| 31 | input flash_io1_ieb_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 32 | input flash_io0_do_core, |
| 33 | input flash_io1_do_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 34 | output flash_io0_di_core, |
| 35 | output flash_io1_di_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 36 | input pll_clk16, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 37 | // Mega-project IOs |
| 38 | input [`MPRJ_IO_PADS-1:0] mprj_io, |
| 39 | input [`MPRJ_IO_PADS-1:0] mprj_io_out, |
| 40 | input [`MPRJ_IO_PADS-1:0] mprj_io_oeb_n, |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 41 | input [`MPRJ_IO_PADS-1:0] mprj_io_hldh_n, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 42 | input [`MPRJ_IO_PADS-1:0] mprj_io_enh, |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 43 | input [`MPRJ_IO_PADS-1:0] mprj_io_inp_dis, |
| 44 | input [`MPRJ_IO_PADS-1:0] mprj_io_ib_mode_sel, |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 45 | input [`MPRJ_IO_PADS-1:0] mprj_io_vtrip_sel, |
| 46 | input [`MPRJ_IO_PADS-1:0] mprj_io_slow_sel, |
| 47 | input [`MPRJ_IO_PADS-1:0] mprj_io_holdover, |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 48 | input [`MPRJ_IO_PADS-1:0] mprj_io_analog_en, |
| 49 | input [`MPRJ_IO_PADS-1:0] mprj_io_analog_sel, |
| 50 | input [`MPRJ_IO_PADS-1:0] mprj_io_analog_pol, |
| 51 | input [`MPRJ_IO_PADS*3-1:0] mprj_io_dm, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 52 | output [`MPRJ_IO_PADS-1:0] mprj_io_in |
| 53 | ); |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 54 | |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 55 | wire analog_a, analog_b; |
| 56 | wire vddio_q, vssio_q; |
| 57 | // Instantiate power cells for VDD3V3 domain (8 total; 4 high clamps and |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 58 | // 4 low clamps) |
| 59 | s8iom0_vdda_hvc_pad vdd3v3hclamp [1:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 60 | `ABUTMENT_PINS |
| 61 | .drn_hvc(), |
| 62 | .src_bdy_hvc() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 63 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 64 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 65 | s8iom0_vddio_hvc_pad vddiohclamp [1:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 66 | `ABUTMENT_PINS |
| 67 | .drn_hvc(), |
| 68 | .src_bdy_hvc() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 69 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 70 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 71 | s8iom0_vdda_lvc_pad vdd3v3lclamp [3:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 72 | `ABUTMENT_PINS |
| 73 | .bdy2_b2b(), |
| 74 | .drn_lvc1(), |
| 75 | .drn_lvc2(), |
| 76 | .src_bdy_lvc1(), |
| 77 | .src_bdy_lvc2() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 78 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 79 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 80 | // Instantiate the core voltage supply (since it is not generated on-chip) |
| 81 | // (1.8V) (4 total, 2 high and 2 low clamps) |
| 82 | s8iom0_vccd_hvc_pad vdd1v8hclamp [1:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 83 | `ABUTMENT_PINS |
| 84 | .drn_hvc(), |
| 85 | .src_bdy_hvc() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 86 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 87 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 88 | s8iom0_vccd_lvc_pad vdd1v8lclamp [1:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 89 | `ABUTMENT_PINS |
| 90 | .bdy2_b2b(), |
| 91 | .drn_lvc1(), |
| 92 | .drn_lvc2(), |
| 93 | .src_bdy_lvc1(), |
| 94 | .src_bdy_lvc2() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 95 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 96 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 97 | // Instantiate ground cells (7 total, 4 high clamps and 3 low clamps) |
| 98 | s8iom0_vssa_hvc_pad vsshclamp [3:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 99 | `ABUTMENT_PINS |
| 100 | .drn_hvc(), |
| 101 | .src_bdy_hvc() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 102 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 103 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 104 | s8iom0_vssa_lvc_pad vssalclamp ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 105 | `ABUTMENT_PINS |
| 106 | .bdy2_b2b(), |
| 107 | .drn_lvc1(), |
| 108 | .drn_lvc2(), |
| 109 | .src_bdy_lvc1(), |
| 110 | .src_bdy_lvc2() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 111 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 112 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 113 | s8iom0_vssd_lvc_pad vssdlclamp ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 114 | `ABUTMENT_PINS |
| 115 | .bdy2_b2b(), |
| 116 | .drn_lvc1(), |
| 117 | .drn_lvc2(), |
| 118 | .src_bdy_lvc1(), |
| 119 | .src_bdy_lvc2() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 120 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 121 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 122 | s8iom0_vssio_lvc_pad vssiolclamp ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 123 | `ABUTMENT_PINS |
| 124 | .bdy2_b2b(), |
| 125 | .drn_lvc1(), |
| 126 | .drn_lvc2(), |
| 127 | .src_bdy_lvc1(), |
| 128 | .src_bdy_lvc2() |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 129 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 130 | |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 131 | wire [2:0] dm_all = |
| 132 | {gpio_mode1_core, gpio_mode1_core, gpio_mode0_core}; |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 133 | wire[2:0] flash_io0_mode = |
| 134 | {flash_io0_ieb_core, flash_io0_ieb_core, flash_io0_oeb_core}; |
| 135 | wire[2:0] flash_io1_mode = |
| 136 | {flash_io1_ieb_core, flash_io1_ieb_core, flash_io1_oeb_core}; |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 137 | |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 138 | // GPIO pad |
| 139 | `INOUT_PAD( |
| 140 | gpio, gpio_in_core, gpio_out_core, |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 141 | gpio_inenb_core, gpio_outenb_core, dm_all); |
| 142 | |
| 143 | // Flash pads |
| 144 | `INOUT_PAD( |
| 145 | flash_io0, flash_io0_di_core, flash_io0_do_core, |
| 146 | flash_io0_ieb_core, flash_io0_oeb_core, flash_io0_mode); |
| 147 | `INOUT_PAD( |
| 148 | flash_io1, flash_io1_di_core, flash_io1_do_core, |
| 149 | flash_io1_ieb_core, flash_io1_oeb_core, flash_io1_mode); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 150 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 151 | `INPUT_PAD(clock, clock_core); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 152 | |
| 153 | // Output Pads |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 154 | `OUTPUT_PAD(flash_csb, flash_csb_core, flash_csb_ieb_core, flash_csb_oeb_core); |
| 155 | `OUTPUT_PAD(flash_clk, flash_clk_core, flash_clk_ieb_core, flash_clk_oeb_core); |
| 156 | |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 157 | |
| 158 | // NOTE: The analog_out pad from the raven chip has been replaced by |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 159 | // the digital reset input resetb on caravel due to the lack of an on-board |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 160 | // power-on-reset circuit. The XRES pad is used for providing a glitch- |
| 161 | // free reset. |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 162 | s8iom0s8_top_xres4v2 resetb_pad ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 163 | `ABUTMENT_PINS |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 164 | `ifndef TOP_ROUTING |
Tim Edwards | 04ba17f | 2020-10-02 22:27:50 -0400 | [diff] [blame^] | 165 | .pad(resetb), |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 166 | `endif |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 167 | .tie_weak_hi_h(xresloop), // Loop-back connection to pad through pad_a_esd_h |
| 168 | .tie_hi_esd(), |
| 169 | .tie_lo_esd(), |
| 170 | .pad_a_esd_h(xresloop), |
| 171 | .xres_h_n(porb_h), |
| 172 | .disable_pullup_h(vss), // 0 = enable pull-up on reset pad |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 173 | .enable_h(vdd3v3), // Power-on-reset to the power-on-reset input?? |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 174 | .en_vddio_sig_h(vss), // No idea. |
| 175 | .inp_sel_h(vss), // 1 = use filt_in_h else filter the pad input |
| 176 | .filt_in_h(vss), // Alternate input for glitch filter |
| 177 | .pullup_h(vss), // Pullup connection for alternate filter input |
| 178 | .enable_vddio(vdd1v8) |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 179 | ); |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 180 | |
| 181 | // Corner cells (These are overlay cells; it is not clear what is normally |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 182 | // supposed to go under them.) |
| 183 | `ifndef TOP_ROUTING |
| 184 | s8iom0_corner_pad corner [3:0] ( |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 185 | .vssio(vss), |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 186 | .vddio(vdd3v3), |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 187 | .vddio_q(vddio_q), |
| 188 | .vssio_q(vssio_q), |
| 189 | .amuxbus_a(analog_a), |
| 190 | .amuxbus_b(analog_b), |
| 191 | .vssd(vss), |
| 192 | .vssa(vss), |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 193 | .vswitch(vdd3v3), |
| 194 | .vdda(vdd3v3), |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 195 | .vccd(vdd1v8), |
| 196 | .vcchib(vdd1v8) |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 197 | ); |
| 198 | `endif |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 199 | |
| 200 | mprj_io mprj_pads( |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 201 | .vdd(vdd3v3), |
shalan | 0d14e6e | 2020-08-31 16:50:48 +0200 | [diff] [blame] | 202 | .vdd1v8(vdd1v8), |
| 203 | .vss(vss), |
| 204 | .vddio_q(vddio_q), |
| 205 | .vssio_q(vssio_q), |
| 206 | .analog_a(analog_a), |
| 207 | .analog_b(analog_b), |
| 208 | .io(mprj_io), |
| 209 | .io_out(mprj_io_out), |
| 210 | .oeb_n(mprj_io_oeb_n), |
| 211 | .hldh_n(mprj_io_hldh_n), |
| 212 | .enh(mprj_io_enh), |
| 213 | .inp_dis(mprj_io_inp_dis), |
| 214 | .ib_mode_sel(mprj_io_ib_mode_sel), |
| 215 | .analog_en(mprj_io_analog_en), |
| 216 | .analog_sel(mprj_io_analog_sel), |
| 217 | .analog_pol(mprj_io_analog_pol), |
| 218 | .dm(mprj_io_dm), |
| 219 | .io_in(mprj_io_in) |
| 220 | ); |
| 221 | |
Tim Edwards | ef8312e | 2020-09-22 17:20:06 -0400 | [diff] [blame] | 222 | endmodule |