Merge remote-tracking branch 'origin/main'

This commit is contained in:
jeffdi 2023-09-06 09:36:53 -07:00
commit e98df2f52b
5 changed files with 496 additions and 18 deletions

View File

@ -31,12 +31,18 @@ SPLIT_FILES := $(shell find . -type f -name "*.$(ARCHIVE_EXT).00.split")
SPLIT_FILES_SOURCES := $(basename $(basename $(basename $(SPLIT_FILES))))
# Needed to uncompress the existing archives
ARCHIVES := $(shell find . -type f -not -path "./signoff/*" -not -path "./mgmt_core_wrapper/signoff/*" -name "*.$(ARCHIVE_EXT)")
ARCHIVES := $(shell find . -type f -not -path "*/signoff/*" -name "*.$(ARCHIVE_EXT)")
ARCHIVE_SOURCES := $(basename $(ARCHIVES))
# Needed to compress and split files/archives that are too large
LARGE_FILES := $(shell find ./gds -type f -name "*.gds")
LARGE_FILES += $(shell find . -type f -size +$(FILE_SIZE_LIMIT_MB)M -not -path "./signoff/*" -not -path "./mgmt_core_wrapper/signoff/*" -not -path "./.git/*" -not -path "./*/.git/*" -not -path "./gds/*" -not -path "./tapeout/outputs/oas/*" -not -path "./openlane/*")
LARGE_FILES += $(shell find . -type f -size +$(FILE_SIZE_LIMIT_MB)M \
-not -path "*/signoff/*" \
-not -path "*/.git/*" \
-not -path "./gds/*" \
-not -path "./tapeout/outputs/oas/*" \
-not -path "*/openlane/*" \
-not -name "*.$(ARCHIVE_EXT)")
LARGE_FILES_GZ := $(addsuffix .$(ARCHIVE_EXT), $(LARGE_FILES))
LARGE_FILES_GZ_SPLIT := $(addsuffix .$(ARCHIVE_EXT).00.split, $(LARGE_FILES))
# consider splitting existing archives
@ -56,12 +62,12 @@ MCW_LITE?=1
ifeq ($(MCW),LITEX_VEXRISCV)
MCW_NAME := mcw-litex-vexriscv
MCW_REPO := https://github.com/efabless/caravel_mgmt_soc_litex
MCW_TAG := $(MPW_TAG)
MCW_REPO ?= https://github.com/efabless/caravel_mgmt_soc_litex
MCW_TAG ?= $(MPW_TAG)
else
MCW_NAME := mcw-pico
MCW_REPO := https://github.com/efabless/caravel_pico
MCW_TAG := $(MPW_TAG)
MCW_REPO ?= https://github.com/efabless/caravel_pico
MCW_TAG ?= $(MPW_TAG)
endif
# Install caravel as submodule, (1): submodule, (0): clone
@ -1173,7 +1179,7 @@ update_caravel:
.PHONY: install_mcw
install_mcw:
if [ -d "$(MCW_ROOT)" ]; then \
echo "Deleting exisiting $(MCW_ROOT)" && \
echo "Deleting existing $(MCW_ROOT)" && \
rm -rf $(MCW_ROOT) && sleep 2;\
fi
ifeq ($(SUBMODULE),1)
@ -1250,7 +1256,7 @@ clean-pdk:
.PHONY: skywater-pdk
skywater-pdk:
if [ -d "$(PDK_ROOT)/skywater-pdk" ]; then\
echo "Deleting exisiting $(PDK_ROOT)/skywater-pdk" && \
echo "Deleting existing $(PDK_ROOT)/skywater-pdk" && \
rm -rf $(PDK_ROOT)/skywater-pdk && sleep 2;\
fi
git clone https://github.com/google/skywater-pdk.git $(PDK_ROOT)/skywater-pdk
@ -1267,7 +1273,7 @@ skywater-pdk:
.PHONY: open-pdks
open-pdks:
if [ -d "$(PDK_ROOT)/open_pdks" ]; then \
echo "Deleting exisiting $(PDK_ROOT)/open_pdks" && \
echo "Deleting existing $(PDK_ROOT)/open_pdks" && \
rm -rf $(PDK_ROOT)/open_pdks && sleep 2; \
fi
git clone git://opencircuitdesign.com/open_pdks $(PDK_ROOT)/open_pdks
@ -1278,7 +1284,7 @@ open-pdks:
.PHONY: sky130
sky130:
if [ -d "$(PDK_ROOT)/$(PDK)" ]; then \
echo "Deleting exisiting $(PDK_ROOT)/$(PDK)" && \
echo "Deleting existing $(PDK_ROOT)/$(PDK)" && \
rm -rf $(PDK_ROOT)/$(PDK) && sleep 2;\
fi
docker run --rm\

View File

@ -7,10 +7,10 @@
cc82a78753f5f5d0a1519bd81adbcff8a4296d91 verilog/rtl/__user_project_wrapper.v
3c8c04f53b2848dc46132cda82c614e06e56571b verilog/rtl/buff_flash_clkrst.v
14064261ec18d633a5d72b45b2347c388f2f446f verilog/rtl/caravan.v
120661aaee20d83948e5e419a88ca9b63531ec95 verilog/rtl/caravan_core.v
502219ed86a5c1707bd0cf636f3b61de78f159d8 verilog/rtl/caravan_core.v
e68fd2e085679d0f61040115fdd1d50651705d3a verilog/rtl/caravan_logo.v
d265ea6bf861e3f5c1b1b984ae057dbaed995008 verilog/rtl/caravan_motto.v
d36e539fad7563a03974cb7d18489e6a0ccfe80d verilog/rtl/caravan_netlists.v
baf7cf0e8a8a712621aed75aff98198a663db43b verilog/rtl/caravan_netlists.v
a3d12a2d2d3596800bec47d1266dce2399a2fcc6 verilog/rtl/caravan_openframe.v
b532b4c6315c29fd19fe38ac221b6fc41e6f5ecb verilog/rtl/caravan_power_routing.v
fa26aa34b4b382aacad9b7ac07a36b17172a401f verilog/rtl/caravel.v
@ -52,6 +52,7 @@ e0c6ead5e35c1ba01d923c482e953c2af9691524 verilog/rtl/mprj_io_buffer.v
669d16642d5dd5f6824812754db20db98c9fe17b verilog/rtl/ring_osc2x13.v
739ca5ed63a513d2e4c9bf3ecfad32d9fa527518 verilog/rtl/simple_por.v
b9d6114a5067a04dd59cdd46fb988591c16743ce verilog/rtl/spare_logic_block.v
036dc8e9066082b2e133dc7b72fd3ad5a52f254b verilog/rtl/toplevel_cocotb.v
8f0bec01c914efe790a09ffe62bbfe0781069e35 verilog/rtl/xres_buf.v
256190717faa72005cf7656d8443c4c0693b3f78 scripts/set_user_id.py
98168b1fb6f80b196f9a05e725ec6ad99bc57ac6 scripts/generate_fill.py

View File

@ -126,7 +126,7 @@ module caravan_core (
inout [`MPRJ_IO_PADS-`ANALOG_PADS-10:0] user_gpio_noesd,
inout [`ANALOG_PADS-1:0] user_analog,
inout [2:0] user_clamp_high,
inout wire [2:0] user_clamp_low
inout [2:0] user_clamp_low
);
//------------------------------------------------------------

View File

@ -97,11 +97,16 @@
`include "buff_flash_clkrst.v"
`include "RAM128.v"
`include "RAM256.v"
`include "VexRiscv_MinDebug.v"
`include "VexRiscv_MinDebugCache.v"
`include "mgmt_core.v"
`include "caravan.v"
`endif
`include "simple_por.v"
`include "caravan_core.v"
`include "caravan_logo.v"
`include "caravan_motto.v"
`include "copyright_block_a.v"
`include "open_source.v"
`include "user_id_textblock.v"
`endif

View File

@ -0,0 +1,466 @@
`timescale 1 ns / 1 ps
`include "includes.v" // in case of RTL coverage is needed and it doesn't work correctly without include files by this way
`ifdef VCS
`ifdef sky130
`ifndef ENABLE_SDF
`include "libs.ref/sky130_fd_io/verilog/sky130_fd_io.v"
`include "libs.ref/sky130_fd_io/verilog/sky130_ef_io.v"
`include "libs.ref/sky130_fd_sc_hd/verilog/primitives.v"
`include "libs.ref/sky130_fd_sc_hd/verilog/sky130_fd_sc_hd.v"
`include "libs.ref/sky130_fd_sc_hvl/verilog/primitives.v"
`include "libs.ref/sky130_fd_sc_hvl/verilog/sky130_fd_sc_hvl.v"
`else
`include "cvc-pdk/sky130_ef_io.v"
`include "cvc-pdk/sky130_fd_io.v"
`include "cvc-pdk/primitives_hd.v"
`include "cvc-pdk/sky130_fd_sc_hd.v"
`include "cvc-pdk/primitives_hvl.v"
`include "cvc-pdk/sky130_fd_sc_hvl.v"
`endif // ~ ENABLE_SDF
`elsif gf180 // sky180
`include "libs.ref/gf180mcu_fd_io/verilog/gf180mcu_fd_io.v"
// `include "libs.ref/gf180mcu_fd_sc_mcu7t5v0/verilog/GF018hv5v_mcu_sc7_udp.v"
`include "libs.ref/gf180mcu_fd_sc_mcu7t5v0/verilog/primitives.v"
`include "libs.ref/gf180mcu_fd_sc_mcu7t5v0/verilog/gf180mcu_fd_sc_mcu7t5v0.v"
// `include "libs.ref/gf180mcu_sc7_hv/verilog/GF018hv5v_mcu_sc7.v"
`include "libs.ref/gf180mcu_fd_ip_sram/verilog/gf180mcu_fd_ip_sram__sram512x8m8wm1.v"
`endif //sky180
`endif //VCS
module caravel_top ;
// parameter FILENAME = {"hex_files/",`TESTNAME,".hex"};
parameter FILENAME={"firmware.hex"};
`ifdef WAVE_GEN
initial begin
`ifdef VCS
`ifdef ENABLE_SDF
$vcdplusfile("waves.vpd");
`else
$vcdplusfile("waves.vpd");
`endif
$vcdpluson();
`else
$dumpfile ({"waves.vcd"});
$dumpvars (0, caravel_top);
`endif
end
`endif // WAVE_GEN
`ifdef ENABLE_SDF
`ifdef VCS
initial begin
`ifndef CARAVAN
`ifdef ARM
$sdf_annotate({`SDF_PATH,"/",`SDF_POSTFIX,"/swift_caravel.",`CORNER ,".sdf"}, uut,,{`RUN_PATH,"/sim/",`TAG,"/",`FTESTNAME,"/caravel_sdf.log"},`ifdef MAX_SDF "MAXIMUM" `else "MINIMUM" `endif );
`else
$sdf_annotate({`SDF_PATH,"/",`SDF_POSTFIX,"/caravel.",`CORNER ,".sdf"}, uut,,{`RUN_PATH,"/sim/",`TAG,"/",`FTESTNAME,"/caravel_sdf.log"},`ifdef MAX_SDF "MAXIMUM" `else "MINIMUM" `endif );
`endif //ARM
`else // CARAVAN
$sdf_annotate({`SDF_PATH,"/",`SDF_POSTFIX,"/caravan.", `CORNER,".sdf"}, uut,,{`RUN_PATH,"/sim/",`TAG,"/",`FTESTNAME,"/caravan_sdf.log"},`ifdef MAX_SDF "MAXIMUM" `else "MINIMUM" `endif );
`endif
`ifdef USER_SDF_ENABLE
$sdf_annotate({`USER_PROJECT_ROOT,"/signoff/user_project_wrapper/primetime/sdf/",`SDF_POSTFIX,"/user_project_wrapper.", `CORNER,".sdf"}, uut.chip_core.mprj,,{`RUN_PATH,"/sim/",`TAG,"/",`FTESTNAME,"/user_prog_sdf.log"},`ifdef MAX_SDF "MAXIMUM" `else "MINIMUM" `endif );
`endif // USER_SDF_ENABLE
end
`endif // VCS
`endif // ENABLE_SDF
wire vddio_tb; // Common 3.3V padframe/ESD power
wire vddio_2_tb; // Common 3.3V padframe/ESD power
wire vssio_tb; // Common padframe/ESD ground
wire vssio_2_tb; // Common padframe/ESD ground
wire vdda_tb; // Management 3.3V power
wire vssa_tb; // Common analog ground
wire vccd_tb; // Management/Common 1.8V power
wire vssd_tb; // Common digital ground
wire vdda1_tb; // User area 1 3.3V power
wire vdda1_2_tb; // User area 1 3.3V power
wire vdda2_tb; // User area 2 3.3V power
wire vssa1_tb; // User area 1 analog ground
wire vssa1_2_tb; // User area 1 analog ground
wire vssa2_tb; // User area 2 analog ground
wire vccd1_tb; // User area 1 1.8V power
wire vccd2_tb; // User area 2 1.8V power
wire vssd1_tb; // User area 1 digital ground
wire vssd2_tb; // User area 2 digital ground
wire gpio_tb; // Used for external LDO control
`ifndef OPENFRAME
wire [`MPRJ_IO_PADS-1:0] mprj_io_tb;
`else //OPENFRAME
wire [`OPENFRAME_IO_PADS-1:0] mprj_io_tb;
`endif //OPENFRAME
reg clock_tb; // CMOS core clock input; not a crystal
wire resetb_tb; // Reset input (sense inverted)
// Note that only two flash data pins are dedicated to the
// management SoC wrapper. The management SoC exports the
// quad SPI mode status to make use of the top two mprj_io
// pins for io2 and io3.
wire flash_csb_tb;
wire flash_clk_tb;
wire flash_io0_tb;
wire flash_io1_tb;
`ifndef OPENFRAME
`ifdef CPU_TYPE_ARM
swift_caravel uut (
`else //CPU_TYPE_ARM
`ifdef CARAVAN
caravan uut (
`else // caravan
caravel uut (
`endif // caravan
`endif // CPU_TYPE_ARM
`ifdef sky130
.vddio (vddio_tb),
.vddio_2 (vddio_2_tb),
.vssio (vssio_tb),
.vssio_2 (vssio_2_tb),
.vdda (vdda_tb),
.vssa (vssa_tb),
.vccd (vccd_tb),
.vssd (vssd_tb),
.vdda1 (vdda1_tb),
.vdda1_2 (vdda1_2_tb),
.vdda2 (vdda2_tb),
.vssa1 (vssa1_tb),
.vssa1_2 (vssa1_2_tb),
.vssa2 (vssa2_tb),
.vccd1 (vccd1_tb),
.vccd2 (vccd2_tb),
.vssd1 (vssd1_tb),
.vssd2 (vssd2_tb),
`elsif gf180
.VDD (vddio_tb),
.VSS (vssio_tb),
`endif // sky130
.clock (clock_tb),
.gpio (gpio_tb),
.mprj_io (mprj_io_tb),
.flash_csb(flash_csb_tb),
.flash_clk(flash_clk_tb),
.flash_io0(flash_io0_tb),
.flash_io1(flash_io1_tb),
.resetb (resetb_tb)
);
`ifdef CPU_TYPE_ARM
sst26wf080b flash(
.SCK (flash_clk_tb),
.SIO ({mprj_io_tb[37], mprj_io_tb[36], flash_io1_tb, flash_io0_tb} ),
.CEb (flash_csb_tb)
);
initial begin
$display("Reading %s", FILENAME);
#1 $readmemh(FILENAME, flash.I0.memory);
//$display("Memory 5 bytes = 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x",
// memory[0], memory[1], memory[2],
// memory[3], memory[4]);
$display("%s loaded into memory", FILENAME);
$display("Memory 5 bytes = 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x",
flash.I0.memory[0], flash.I0.memory[1], flash.I0.memory[2],
flash.I0.memory[3], flash.I0.memory[4]);
end
`else
spiflash #(
FILENAME
) spiflash (
.csb(flash_csb_tb),
.clk(flash_clk_tb),
.io0(flash_io0_tb),
.io1(flash_io1_tb),
.io2(), // not used
.io3() // not used
);
`endif // CPU_TYPE_ARM
`else // ! openframe
assign mprj_io_tb[38] = clock_tb;
caravel_openframe uut (
.vddio (vddio_tb),
.vssio (vssio_tb),
.vdda (vdda_tb),
.vssa (vssa_tb),
.vccd (vccd_tb),
.vssd (vssd_tb),
.vdda1 (vdda1_tb),
.vdda2 (vdda2_tb),
.vssa1 (vssa1_tb),
.vssa2 (vssa2_tb),
.vccd1 (vccd1_tb),
.vccd2 (vccd2_tb),
.vssd1 (vssd1_tb),
.vssd2 (vssd2_tb),
.gpio (mprj_io_tb),
.resetb (resetb_tb)
);
spiflash #(
.FILENAME(FILENAME)
) spiflash (
.csb(mprj_io_tb[39]),
.clk(mprj_io_tb[40]),
.io0(mprj_io_tb[41]),
.io1(mprj_io_tb[42]),
.io2(mprj_io_tb[36]),
.io3(mprj_io_tb[37])
);
// do anything to the unused wires so cocotb can read them when iverilog is used
// apparently iverilog can't read the unused wires and that causes an error in python
assign gpio_tb = 0;
assign vddio_2_tb = 0;
assign vssio_2_tb = 0;
assign vdda1_2_tb = 0;
assign vssa1_2_tb = 0;
`endif // ! openframe
// make speical variables for the mprj input to assign the input without writing to the output gpios
// cocotb limitation #2587: iverilog deal with array as 1 object not multiple of objects so can't write to only 1 element
wire gpio0;
wire gpio0_en;
wire gpio1;
wire gpio1_en;
wire gpio2;
wire gpio2_en;
wire gpio3;
wire gpio3_en;
wire gpio4;
wire gpio4_en;
wire gpio5;
wire gpio5_en;
wire gpio6;
wire gpio6_en;
wire gpio7;
wire gpio7_en;
wire gpio8;
wire gpio8_en;
wire gpio9;
wire gpio9_en;
wire gpio10;
wire gpio10_en;
wire gpio11;
wire gpio11_en;
wire gpio12;
wire gpio12_en;
wire gpio13;
wire gpio13_en;
wire gpio14;
wire gpio14_en;
wire gpio15;
wire gpio15_en;
wire gpio16;
wire gpio16_en;
wire gpio17;
wire gpio17_en;
wire gpio18;
wire gpio18_en;
wire gpio19;
wire gpio19_en;
wire gpio20;
wire gpio20_en;
wire gpio21;
wire gpio21_en;
wire gpio22;
wire gpio22_en;
wire gpio23;
wire gpio23_en;
wire gpio24;
wire gpio24_en;
wire gpio25;
wire gpio25_en;
wire gpio26;
wire gpio26_en;
wire gpio27;
wire gpio27_en;
wire gpio28;
wire gpio28_en;
wire gpio29;
wire gpio29_en;
wire gpio30;
wire gpio30_en;
wire gpio31;
wire gpio31_en;
wire gpio32;
wire gpio32_en;
wire gpio33;
wire gpio33_en;
wire gpio34;
wire gpio34_en;
wire gpio35;
wire gpio35_en;
wire gpio36;
wire gpio36_en;
wire gpio37;
wire gpio37_en;
`ifdef OPENFRAME
wire gpio38;
wire gpio38_en;
wire gpio39;
wire gpio39_en;
wire gpio40;
wire gpio40_en;
wire gpio41;
wire gpio41_en;
wire gpio42;
wire gpio42_en;
wire gpio43;
wire gpio43_en;
`endif // OPENFRAME
assign mprj_io_tb[0] = (gpio0_en) ? gpio0 : 1'bz;
assign mprj_io_tb[1] = (gpio1_en) ? gpio1 : 1'bz;
assign mprj_io_tb[2] = (gpio2_en) ? gpio2 : 1'bz;
assign mprj_io_tb[3] = (gpio3_en) ? gpio3 : 1'bz;
assign mprj_io_tb[4] = (gpio4_en) ? gpio4 : 1'bz;
assign mprj_io_tb[5] = (gpio5_en) ? gpio5 : 1'bz;
assign mprj_io_tb[6] = (gpio6_en) ? gpio6 : 1'bz;
assign mprj_io_tb[7] = (gpio7_en) ? gpio7 : 1'bz;
assign mprj_io_tb[8] = (gpio8_en) ? gpio8 : 1'bz;
assign mprj_io_tb[9] = (gpio9_en) ? gpio9 : 1'bz;
assign mprj_io_tb[10] = (gpio10_en) ? gpio10 : 1'bz;
assign mprj_io_tb[11] = (gpio11_en) ? gpio11 : 1'bz;
assign mprj_io_tb[12] = (gpio12_en) ? gpio12 : 1'bz;
assign mprj_io_tb[13] = (gpio13_en) ? gpio13 : 1'bz;
assign mprj_io_tb[14] = (gpio14_en) ? gpio14 : 1'bz;
assign mprj_io_tb[15] = (gpio15_en) ? gpio15 : 1'bz;
assign mprj_io_tb[16] = (gpio16_en) ? gpio16 : 1'bz;
assign mprj_io_tb[17] = (gpio17_en) ? gpio17 : 1'bz;
assign mprj_io_tb[18] = (gpio18_en) ? gpio18 : 1'bz;
assign mprj_io_tb[19] = (gpio19_en) ? gpio19 : 1'bz;
assign mprj_io_tb[20] = (gpio20_en) ? gpio20 : 1'bz;
assign mprj_io_tb[21] = (gpio21_en) ? gpio21 : 1'bz;
assign mprj_io_tb[22] = (gpio22_en) ? gpio22 : 1'bz;
assign mprj_io_tb[23] = (gpio23_en) ? gpio23 : 1'bz;
assign mprj_io_tb[24] = (gpio24_en) ? gpio24 : 1'bz;
assign mprj_io_tb[25] = (gpio25_en) ? gpio25 : 1'bz;
assign mprj_io_tb[26] = (gpio26_en) ? gpio26 : 1'bz;
assign mprj_io_tb[27] = (gpio27_en) ? gpio27 : 1'bz;
assign mprj_io_tb[28] = (gpio28_en) ? gpio28 : 1'bz;
assign mprj_io_tb[29] = (gpio29_en) ? gpio29 : 1'bz;
assign mprj_io_tb[30] = (gpio30_en) ? gpio30 : 1'bz;
assign mprj_io_tb[31] = (gpio31_en) ? gpio31 : 1'bz;
assign mprj_io_tb[32] = (gpio32_en) ? gpio32 : 1'bz;
assign mprj_io_tb[33] = (gpio33_en) ? gpio33 : 1'bz;
assign mprj_io_tb[34] = (gpio34_en) ? gpio34 : 1'bz;
assign mprj_io_tb[35] = (gpio35_en) ? gpio35 : 1'bz;
assign mprj_io_tb[36] = (gpio36_en) ? gpio36 : 1'bz;
assign mprj_io_tb[37] = (gpio37_en) ? gpio37 : 1'bz;
`ifdef OPENFRAME
assign mprj_io_tb[38] = (gpio38_en) ? gpio38 : 1'bz;
assign mprj_io_tb[39] = (gpio39_en) ? gpio39 : 1'bz;
assign mprj_io_tb[40] = (gpio40_en) ? gpio40 : 1'bz;
assign mprj_io_tb[41] = (gpio41_en) ? gpio41 : 1'bz;
assign mprj_io_tb[42] = (gpio42_en) ? gpio42 : 1'bz;
assign mprj_io_tb[43] = (gpio43_en) ? gpio43 : 1'bz;
`endif // OPENFRAME
// to read from mprj array with iverilog
wire gpio0_monitor;
wire gpio1_monitor;
wire gpio2_monitor;
wire gpio3_monitor;
wire gpio4_monitor;
wire gpio5_monitor;
wire gpio6_monitor;
wire gpio7_monitor;
wire gpio8_monitor;
wire gpio9_monitor;
wire gpio10_monitor;
wire gpio11_monitor;
wire gpio12_monitor;
wire gpio13_monitor;
wire gpio14_monitor;
wire gpio15_monitor;
wire gpio16_monitor;
wire gpio17_monitor;
wire gpio18_monitor;
wire gpio19_monitor;
wire gpio20_monitor;
wire gpio21_monitor;
wire gpio22_monitor;
wire gpio23_monitor;
wire gpio24_monitor;
wire gpio25_monitor;
wire gpio26_monitor;
wire gpio27_monitor;
wire gpio28_monitor;
wire gpio29_monitor;
wire gpio30_monitor;
wire gpio31_monitor;
wire gpio32_monitor;
wire gpio33_monitor;
wire gpio34_monitor;
wire gpio35_monitor;
wire gpio36_monitor;
wire gpio37_monitor;
`ifdef OPENFRAME
wire gpio38_monitor;
wire gpio39_monitor;
wire gpio40_monitor;
wire gpio41_monitor;
wire gpio42_monitor;
wire gpio43_monitor;
`endif // OPENFRAME
assign gpio0_monitor = mprj_io_tb[0];
assign gpio1_monitor = mprj_io_tb[1];
assign gpio2_monitor = mprj_io_tb[2];
assign gpio3_monitor = mprj_io_tb[3];
assign gpio4_monitor = mprj_io_tb[4];
assign gpio5_monitor = mprj_io_tb[5];
assign gpio6_monitor = mprj_io_tb[6];
assign gpio7_monitor = mprj_io_tb[7];
assign gpio8_monitor = mprj_io_tb[8];
assign gpio9_monitor = mprj_io_tb[9];
assign gpio10_monitor = mprj_io_tb[10];
assign gpio11_monitor = mprj_io_tb[11];
assign gpio12_monitor = mprj_io_tb[12];
assign gpio13_monitor = mprj_io_tb[13];
assign gpio14_monitor = mprj_io_tb[14];
assign gpio15_monitor = mprj_io_tb[15];
assign gpio16_monitor = mprj_io_tb[16];
assign gpio17_monitor = mprj_io_tb[17];
assign gpio18_monitor = mprj_io_tb[18];
assign gpio19_monitor = mprj_io_tb[19];
assign gpio20_monitor = mprj_io_tb[20];
assign gpio21_monitor = mprj_io_tb[21];
assign gpio22_monitor = mprj_io_tb[22];
assign gpio23_monitor = mprj_io_tb[23];
assign gpio24_monitor = mprj_io_tb[24];
assign gpio25_monitor = mprj_io_tb[25];
assign gpio26_monitor = mprj_io_tb[26];
assign gpio27_monitor = mprj_io_tb[27];
assign gpio28_monitor = mprj_io_tb[28];
assign gpio29_monitor = mprj_io_tb[29];
assign gpio30_monitor = mprj_io_tb[30];
assign gpio31_monitor = mprj_io_tb[31];
assign gpio32_monitor = mprj_io_tb[32];
assign gpio33_monitor = mprj_io_tb[33];
assign gpio34_monitor = mprj_io_tb[34];
assign gpio35_monitor = mprj_io_tb[35];
assign gpio36_monitor = mprj_io_tb[36];
assign gpio37_monitor = mprj_io_tb[37];
`ifdef OPENFRAME
assign gpio38_monitor = mprj_io_tb[38];
assign gpio39_monitor = mprj_io_tb[39];
assign gpio40_monitor = mprj_io_tb[40];
assign gpio41_monitor = mprj_io_tb[41];
assign gpio42_monitor = mprj_io_tb[42];
assign gpio43_monitor = mprj_io_tb[43];
`endif // OPENFRAME
endmodule