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