// SPDX-FileCopyrightText: 2020 Efabless Corporation // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // SPDX-License-Identifier: Apache-2.0 `default_nettype none /* *------------------------------------------------------------- * * openframe_project_wrapper * * This wrapper enumerates all of the pins available to the * user for the user openframe project. * * Written by Tim Edwards * March 27, 2023 * Efabless Corporation * *------------------------------------------------------------- */ module openframe_project_wrapper ( `ifdef USE_POWER_PINS inout vdda, // User area 0 3.3V supply inout vdda1, // User area 1 3.3V supply inout vdda2, // User area 2 3.3V supply inout vssa, // User area 0 analog ground inout vssa1, // User area 1 analog ground inout vssa2, // User area 2 analog ground inout vccd, // Common 1.8V supply inout vccd1, // User area 1 1.8V supply inout vccd2, // User area 2 1.8v supply inout vssd, // Common digital ground inout vssd1, // User area 1 digital ground inout vssd2, // User area 2 digital ground inout vddio, // Common 3.3V ESD supply inout vssio, // Common ESD ground `endif /* Signals exported from the frame area to the user project */ /* The user may elect to use any of these inputs. */ input porb_h, // power-on reset, sense inverted, 3.3V domain input porb_l, // power-on reset, sense inverted, 1.8V domain input por_l, // power-on reset, noninverted, 1.8V domain input resetb_h, // master reset, sense inverted, 3.3V domain input resetb_l, // master reset, sense inverted, 1.8V domain input [31:0] mask_rev, // 32-bit user ID, 1.8V domain /* GPIOs. There are 44 GPIOs (19 left, 19 right, 6 bottom). */ /* These must be configured appropriately by the user project. */ /* Basic bidirectional I/O. Input gpio_in_h is in the 3.3V domain; all * others are in the 1.8v domain. OEB is output enable, sense inverted. */ input [`OPENFRAME_IO_PADS-1:0] gpio_in, input [`OPENFRAME_IO_PADS-1:0] gpio_in_h, output [`OPENFRAME_IO_PADS-1:0] gpio_out, output [`OPENFRAME_IO_PADS-1:0] gpio_oeb, /* Pad configuration. These signals are usually static values. * See the documentation for the sky130_fd_io__gpiov2 cell signals * and their use. */ output [`OPENFRAME_IO_PADS-1:0] gpio_inp_dis, output [`OPENFRAME_IO_PADS-1:0] gpio_ib_mode_sel, output [`OPENFRAME_IO_PADS-1:0] gpio_vtrip_sel, output [`OPENFRAME_IO_PADS-1:0] gpio_slow_sel, output [`OPENFRAME_IO_PADS-1:0] gpio_holdover, output [`OPENFRAME_IO_PADS-1:0] gpio_analog_en, output [`OPENFRAME_IO_PADS-1:0] gpio_analog_sel, output [`OPENFRAME_IO_PADS-1:0] gpio_analog_pol, output [`OPENFRAME_IO_PADS-1:0] gpio_dm2, output [`OPENFRAME_IO_PADS-1:0] gpio_dm1, output [`OPENFRAME_IO_PADS-1:0] gpio_dm0, /* These signals correct directly to the pad. Pads using analog I/O * connections should keep the digital input and output buffers turned * off. Both signals connect to the same pad. The "noesd" signal * is a direct connection to the pad; the other signal connects through * a series resistor which gives it minimal ESD protection. Both signals * have basic over- and under-voltage protection at the pad. These * signals may be expected to attenuate heavily above 50MHz. */ inout [`OPENFRAME_IO_PADS-1:0] analog_io, inout [`OPENFRAME_IO_PADS-1:0] analog_noesd_io, /* These signals are constant one and zero in the 1.8V domain, one for * each GPIO pad, and can be looped back to the control signals on the * same GPIO pad to set a static configuration at power-up. */ input [`OPENFRAME_IO_PADS-1:0] gpio_loopback_one, input [`OPENFRAME_IO_PADS-1:0] gpio_loopback_zero ); `ifdef OPENFRAME_TESTING openframe_example test_example ( `ifdef USE_POWER_PINS .vdda(vdda), .vdda1(vdda1), .vdda2(vdda2), .vssa(vssa), .vssa1(vssa1), .vssa2(vssa2), .vccd(vccd), .vccd1(vccd1), .vccd2(vccd2), .vssd(vssd), .vssd1(vssd1), .vssd2(vssd2), .vddio(vddio), .vssio(vssio), `endif .porb_h(porb_h), .porb_l(porb_l), .por_l(por_l), .resetb_h(resetb_h), .resetb_l(resetb_l), .mask_rev(mask_rev), .gpio_in(gpio_in), .gpio_in_h(gpio_in_h), .gpio_out(gpio_out), .gpio_oeb(gpio_oeb), .gpio_inp_dis(gpio_inp_dis), .gpio_ib_mode_sel(gpio_ib_mode_sel), .gpio_vtrip_sel(gpio_vtrip_sel), .gpio_slow_sel(gpio_slow_sel), .gpio_holdover(gpio_holdover), .gpio_analog_en(gpio_analog_en), .gpio_analog_sel(gpio_analog_sel), .gpio_analog_pol(gpio_analog_pol), .gpio_dm2(gpio_dm2), .gpio_dm1(gpio_dm1), .gpio_dm0(gpio_dm0), .analog_io(analog_io), .analog_noesd_io(analog_noesd_io), .gpio_loopback_one(gpio_loopback_one), .gpio_loopback_zero(gpio_loopback_zero) ); `endif endmodule // openframe_project_wrapper