Add Makefile to build sim. Debug sim build

Signed-off-by: Joachim Strömbergson <joachim@assured.se>
This commit is contained in:
Joachim Strömbergson 2023-05-08 13:45:56 +02:00 committed by dehanj
parent 819b93deff
commit 704d67c8ab
No known key found for this signature in database
GPG Key ID: 3707A9DBF4BB8F1A
2 changed files with 60 additions and 29 deletions

View File

@ -59,19 +59,12 @@ module tb_uart();
reg tb_reset_n; reg tb_reset_n;
reg tb_rxd; reg tb_rxd;
wire tb_txd; wire tb_txd;
wire tb_rxd_syn;
wire [7 : 0] tb_rxd_data;
wire tb_rxd_ack;
wire tb_txd_syn;
wire [7 : 0] tb_txd_data;
wire tb_txd_ack;
reg tb_cs; reg tb_cs;
reg tb_we; reg tb_we;
reg [7 : 0] tb_address; reg [7 : 0] tb_address;
reg [31 : 0] tb_write_data; reg [31 : 0] tb_write_data;
wire [31 : 0] tb_read_data; wire [31 : 0] tb_read_data;
wire tb_error; wire tb_ready;
wire [7 : 0] tb_debug;
reg txd_state; reg txd_state;
@ -86,33 +79,19 @@ module tb_uart();
.rxd(tb_rxd), .rxd(tb_rxd),
.txd(tb_txd), .txd(tb_txd),
.rxd_syn(tb_rxd_syn),
.rxd_data(tb_rxd_data),
.rxd_ack(tb_rxd_ack),
// Internal transmit interface.
.txd_syn(tb_txd_syn),
.txd_data(tb_txd_data),
.txd_ack(tb_txd_ack),
// API interface. // API interface.
.cs(tb_cs), .cs(tb_cs),
.we(tb_we), .we(tb_we),
.address(tb_address), .address(tb_address),
.write_data(tb_write_data), .write_data(tb_write_data),
.read_data(tb_read_data), .read_data(tb_read_data),
.error(tb_error), .ready(tb_ready)
.debug(tb_debug)
); );
//---------------------------------------------------------------- //----------------------------------------------------------------
// Concurrent assignments. // Concurrent assignments.
//---------------------------------------------------------------- //----------------------------------------------------------------
// We connect the internal facing ports on the dut together.
assign tb_txd_syn = tb_rxd_syn;
assign tb_txd_data = tb_rxd_data;
assign tb_rxd_ack = tb_txd_ack;
//---------------------------------------------------------------- //----------------------------------------------------------------
@ -223,9 +202,6 @@ module tb_uart();
//---------------------------------------------------------------- //----------------------------------------------------------------
task dump_tx_state; task dump_tx_state;
begin begin
$display("txd = 0x%01x, txd_reg = 0x%01x, txd_byte_reg = 0x%01x, txd_bit_ctr_reg = 0x%01x, txd_bitrate_ctr_reg = 0x%02x, txd_ack = 0x%01x, etx_ctrl_reg = 0x%02x",
dut.core.txd, dut.core.txd_reg, dut.core.txd_byte_reg, dut.core.txd_bit_ctr_reg,
dut.core.txd_bitrate_ctr_reg, dut.core.txd_ack, dut.core.etx_ctrl_reg);
end end
endtask // dump_dut_state endtask // dump_dut_state
@ -260,8 +236,8 @@ module tb_uart();
tb_rxd = 1; tb_rxd = 1;
tb_cs = 0; tb_cs = 0;
tb_we = 0; tb_we = 0;
tb_address = 8'h00; tb_address = 8'h0;
tb_write_data = 32'h00000000; tb_write_data = 32'h0;
txd_state = 1; txd_state = 1;
end end

View File

@ -0,0 +1,55 @@
#===================================================================
#
# Makefile
# --------
# Makefile for building the UART core.
#
#
# Author: Joachim Strombergson
# Copyright (C) 2022 - Tillitis AB
# SPDX-License-Identifier: GPL-2.0-only
#
#===================================================================
TOP_SRC=../rtl/uart.v ../rtl/uart_core.v ../rtl/uart_fifo.v
TB_TOP_SRC =../tb/tb_uart.v
CC = iverilog
CC_FLAGS = -Wall
LINT = verilator
LINT_FLAGS = +1364-2001ext+ --lint-only -Wall -Wno-fatal -Wno-DECLFILENAME
all: top.sim
top.sim: $(TB_TOP_SRC) $(TOP_SRC)
$(CC) $(CC_FLAGS) -o top.sim $(TB_TOP_SRC) $(TOP_SRC)
sim-top: top.sim
./top.sim
lint-top: $(TOP_SRC)
$(LINT) $(LINT_FLAGS) $(TOP_SRC)
clean:
rm -f top.sim
help:
@echo "Build system for simulation of UART core"
@echo ""
@echo "Supported targets:"
@echo "------------------"
@echo "top.sim: Build top level simulation target."
@echo "sim-top: Run top level simulation."
@echo "lint-top: Lint top rtl source files."
@echo "clean: Delete all built files."
#===================================================================
# EOF Makefile
#===================================================================