2023-12-23 12:23:18 +00:00
|
|
|
VSRC := $(wildcard vsrc/*.v)
|
|
|
|
CPPSRC := $(addprefix $(PWD)/,$(wildcard csrc/*.cpp))
|
|
|
|
PREFIX ?= build
|
|
|
|
OBJDIR := $(PREFIX)/obj
|
|
|
|
SUBMAKE := $(OBJDIR)/Vexample.mk
|
|
|
|
VERILATOR_FLAGS := --cc --exe
|
2022-02-21 04:22:27 +00:00
|
|
|
|
2023-12-23 12:23:18 +00:00
|
|
|
all: sim
|
|
|
|
|
|
|
|
sim: VERILATOR_FLAGS += --trace
|
|
|
|
sim: $(VSRC) $(CPPSRC) $(OBJDIR)/Vexample
|
2022-02-21 04:22:27 +00:00
|
|
|
$(call git_commit, "sim RTL") # DO NOT REMOVE THIS LINE!!!
|
2023-12-23 12:23:18 +00:00
|
|
|
@echo "Running" $(OBJDIR)/Vexample "..."
|
|
|
|
@echo "================================"
|
|
|
|
@$(OBJDIR)/Vexample
|
|
|
|
|
|
|
|
$(OBJDIR)/Vexample: $(SUBMAKE)
|
|
|
|
$(MAKE) -C $(OBJDIR) -f $(notdir $(SUBMAKE)) Vexample
|
|
|
|
|
|
|
|
$(SUBMAKE): $(VSRC) $(CPPSRC) $(OBJDIR)
|
|
|
|
verilator $(VERILATOR_FLAGS) --Mdir $(PWD)/$(OBJDIR) $(VSRC) $(CPPSRC)
|
|
|
|
|
|
|
|
$(OBJDIR):
|
|
|
|
mkdir -p $(OBJDIR)
|
2022-02-21 04:22:27 +00:00
|
|
|
|
|
|
|
include ../Makefile
|
2023-12-23 12:23:18 +00:00
|
|
|
|
|
|
|
.PHONY: clean
|
|
|
|
|
|
|
|
clean:
|
|
|
|
$(RM) -r $(OBJDIR)
|