Merge branch 'main' of https://github.com/AmoghLonkar/openram_testchip into main
diff --git a/verilog/dv/gpio_test/Makefile b/verilog/dv/gpio_test/Makefile
new file mode 100644
index 0000000..bbb93d6
--- /dev/null
+++ b/verilog/dv/gpio_test/Makefile
@@ -0,0 +1,78 @@
+# 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
+
+## Caravel Pointers
+CARAVEL_ROOT ?= ../../../caravel
+CARAVEL_PATH ?= $(CARAVEL_ROOT)
+CARAVEL_FIRMWARE_PATH = $(CARAVEL_PATH)/verilog/dv/caravel
+CARAVEL_VERILOG_PATH = $(CARAVEL_PATH)/verilog
+CARAVEL_RTL_PATH = $(CARAVEL_VERILOG_PATH)/rtl
+CARAVEL_BEHAVIOURAL_MODELS = $(CARAVEL_VERILOG_PATH)/dv/caravel
+
+## User Project Pointers
+UPRJ_VERILOG_PATH ?= ../../../verilog
+UPRJ_RTL_PATH = $(UPRJ_VERILOG_PATH)/rtl
+UPRJ_BEHAVIOURAL_MODELS = ../
+
+## RISCV GCC
+GCC_PATH?=/ef/apps/bin
+GCC_PREFIX?=riscv32-unknown-elf
+PDK_PATH?=/ef/tech/SW/sky130A
+
+## Simulation mode: RTL/GL
+SIM?=RTL
+
+.SUFFIXES:
+
+PATTERN = gpio_test
+
+all: ${PATTERN:=.vcd}
+
+hex: ${PATTERN:=.hex}
+
+%.vvp: %_tb.v %.hex
+ifeq ($(SIM),RTL)
+ iverilog -DFUNCTIONAL -DSIM -I $(PDK_PATH) \
+ -I $(CARAVEL_BEHAVIOURAL_MODELS) -I $(CARAVEL_RTL_PATH) \
+ -I $(UPRJ_BEHAVIOURAL_MODELS) -I $(UPRJ_RTL_PATH) \
+ $< -o $@
+else
+ iverilog -DFUNCTIONAL -DSIM -DGL -I $(PDK_PATH) \
+ -I $(CARAVEL_BEHAVIOURAL_MODELS) -I $(CARAVEL_RTL_PATH) -I $(CARAVEL_VERILOG_PATH) \
+ -I $(UPRJ_BEHAVIOURAL_MODELS) -I$(UPRJ_RTL_PATH) -I $(UPRJ_VERILOG_PATH) \
+ $< -o $@
+endif
+
+%.vcd: %.vvp
+ vvp $<
+
+%.elf: %.c $(CARAVEL_FIRMWARE_PATH)/sections.lds $(CARAVEL_FIRMWARE_PATH)/start.s
+ ${GCC_PATH}/${GCC_PREFIX}-gcc -I $(CARAVEL_PATH) -march=rv32imc -mabi=ilp32 -Wl,-Bstatic,-T,$(CARAVEL_FIRMWARE_PATH)/sections.lds,--strip-debug -ffreestanding -nostdlib -o $@ $(CARAVEL_FIRMWARE_PATH)/start.s $<
+
+%.hex: %.elf
+ ${GCC_PATH}/${GCC_PREFIX}-objcopy -O verilog $< $@
+ # to fix flash base address
+ sed -i 's/@10000000/@00000000/g' $@
+
+%.bin: %.elf
+ ${GCC_PATH}/${GCC_PREFIX}-objcopy -O binary $< /dev/stdout | tail -c +1048577 > $@
+
+# ---- Clean ----
+
+clean:
+ rm -f *.elf *.hex *.bin *.vvp *.vcd *.log
+
+.PHONY: clean hex all
diff --git a/verilog/dv/gpio_test/gpio_test_tb.v b/verilog/dv/gpio_test/gpio_test_tb.v
index 8249637..7730d88 100644
--- a/verilog/dv/gpio_test/gpio_test_tb.v
+++ b/verilog/dv/gpio_test/gpio_test_tb.v
@@ -58,17 +58,19 @@
assign mprj_io[16] = 1;
assign mprj_io[17] = gpio_clk;
assign mprj_io[18] = gpio_in;
- assign mprj_io[20] = gpio_scan;
- assign mprj_io[21] = gpio_sram_load;
+ assign mprj_io[19] = gpio_scan;
+ assign mprj_io[20] = gpio_sram_load;
+ assign mprj_io[21] = global_csb;
always #12.5 gpio_clk = !gpio_clk;
initial begin
- $dumpfile("gpio_test.vcd");
- $dumpvars(0, gpio_test_tb);
-
+ //$dumpfile("gpio_test.vcd");
+ //$dumpvars(0, gpio_test_tb);
+
+ /*
// Repeat cycles of 1000 clock edges as needed to complete testbench
- repeat (25) begin
+ repeat (2) begin
repeat (1000) @(posedge clock);
// $display("+1000 cycles");
end
@@ -78,6 +80,7 @@
$display ("Monitor: Timeout, Test GPIO Full Chip Sim (RTL) Failed");
`endif
$finish;
+ */
end
@@ -87,30 +90,34 @@
reg [111:0] out_data;
initial begin
+ $dumpfile("gpio_test.vcd");
+ $dumpvars(0, gpio_test_tb);
+
gpio_clk = 1;
global_csb = 1;
-
- //Testing 32B Dual Port Memories
- for(i = 0; i < 5; i = i + 1) begin
+
+ //Testing 32B Dual Port Memories
+ for(i = 0; i < 1; i = i + 1) begin
sel = i;
//Write 1 to addr1 using GPIO Pins
gpio_scan = 1;
gpio_sram_load = 0;
in_data = {sel, 16'd1, 32'd1, 1'b0, 1'b0, 4'd15, 16'd0, 32'd0, 1'b1, 1'b1, 4'd0};
-
+
for(j = 0; j < 112; j = j + 1) begin
gpio_in = in_data[111 - j];
- #10;
+ #25;
end
-
+
gpio_scan = 0;
global_csb = 0;
- #10;
+ #25;
global_csb = 1;
gpio_sram_load = 1;
- #10;
+ #25;
+ /*
//Write 2 to addr2 using GPIO Pins
gpio_scan = 1;
gpio_sram_load = 0;
@@ -118,17 +125,17 @@
for(j = 0; j < 112; j = j + 1) begin
gpio_in = in_data[111 - j];
- #10;
+ #25;
end
gpio_scan = 0;
global_csb = 0;
- #10;
+ #25;
global_csb = 1;
gpio_sram_load = 1;
- #10;
+ #25;
- #10;
+ #25;
//Read addr1 and addr2
gpio_scan = 1;
gpio_sram_load = 0;
@@ -136,28 +143,28 @@
for(j = 0; j < 112; j = j + 1) begin
gpio_in = in_data[111 - j];
- #10;
+ #25;
end
gpio_scan = 0;
global_csb = 0;
- #10;
+ #25;
global_csb = 1;
gpio_sram_load = 1;
- #10;
+ #25;
- #10
+ #25;
gpio_sram_load = 0;
gpio_scan = 1;
for(j = 0; j < 112; j = j + 1) begin
out_data[111 - j] = mprj_io_22;
- #10;
+ #25;
end
- #10;
+ #25;
//`assert(out_data, {sel, 16'd1, 32'd1, 1'b0, 1'b1, 4'd0, 16'd2, 32'd2, 1'b0, 1'b1, 4'd0});
+ */
end
-
- #10; $finish;
+ #25; $finish;
end
initial begin