Merge branch 'asplos-ae' of https://github.com/ucb-bar/radiance into asplos-ae
This commit is contained in:
39
radiance.mk
39
radiance.mk
@@ -3,15 +3,18 @@
|
||||
##############################################################
|
||||
|
||||
VORTEX_SRC_DIR = $(base_dir)/generators/radiance/src/main/resources/vsrc/vortex
|
||||
RADPIE_SRC_DIR = $(base_dir)/generators/radiance/radpie
|
||||
RADPIE_BUILD_DIR = $(RADPIE_SRC_DIR)/target/release
|
||||
CYCLOTRON_SRC_DIR = $(base_dir)/generators/radiance/cyclotron
|
||||
CYCLOTRON_BUILD_DIR = $(CYCLOTRON_SRC_DIR)/target/debug
|
||||
# CYCLOTRON_BUILD_DIR = $(CYCLOTRON_SRC_DIR)/target/release
|
||||
RADIANCE_CSRC_DIR = $(base_dir)/generators/radiance/src/main/resources/csrc
|
||||
RADIANCE_VSRC_DIR = $(base_dir)/generators/radiance/src/main/resources/vsrc
|
||||
|
||||
##################################################################
|
||||
# THE FOLLOWING MUST BE += operators
|
||||
##################################################################
|
||||
|
||||
# EXTRA_SIM_REQS += radpie
|
||||
# EXTRA_SIM_LDFLAGS += -L$(RADPIE_BUILD_DIR) -Wl,-rpath,$(RADPIE_BUILD_DIR) -lradpie
|
||||
# EXTRA_SIM_REQS += cyclotron
|
||||
# EXTRA_SIM_LDFLAGS += -L$(CYCLOTRON_BUILD_DIR) -Wl,-rpath,$(CYCLOTRON_BUILD_DIR) -lcyclotron
|
||||
ifeq ($(shell echo $(CONFIG) | grep -E "SynConfig$$"),$(CONFIG))
|
||||
EXTRA_SIM_PREPROC_DEFINES += +define+SYNTHESIS +define+NDEBUG +define+DPI_DISABLE
|
||||
endif
|
||||
@@ -37,21 +40,25 @@ VCS_NONCC_OPTS += +vcs+initreg+random
|
||||
|
||||
# cargo handles building of Rust files all on its own, so make this a PHONY
|
||||
# target to run cargo unconditionally
|
||||
.PHONY: radpie
|
||||
radpie:
|
||||
cd $(RADPIE_SRC_DIR) && cargo build --release
|
||||
.PHONY: cyclotron
|
||||
cyclotron:
|
||||
cd $(CYCLOTRON_SRC_DIR) && cargo build # --release
|
||||
|
||||
EXTRA_SIM_REQS += vortex_vsrc.$(CONFIG)
|
||||
# below manipulation of VORTEX_VLOG_SOURCES doesn't work if we try to reuse
|
||||
# below manipulation of RADIANCE_EXTERNAL_SRCS doesn't work if we try to reuse
|
||||
# $(call lookup_srcs) from common.mk, the variable doesn't expand somehow
|
||||
ifeq ($(shell which fd 2> /dev/null),)
|
||||
VORTEX_VLOG_SOURCES := $(shell find -L $(VORTEX_SRC_DIR) -type f -iname "*.sv" -o -iname "*.vh" -o -iname "*.v")
|
||||
ifeq ($(shell which fdfd 2> /dev/null),)
|
||||
# RADIANCE_EXTERNAL_SRCS := $(shell find -L $(VORTEX_SRC_DIR) -type f -iname "*.sv" -o -iname "*.vh" -o -iname "*.v")
|
||||
RADIANCE_EXTERNAL_SRCS := $(shell find -L $(RADIANCE_VSRC_DIR) -type f -iname "*.sv" -o -iname "*.vh" -o -iname "*.v")
|
||||
RADIANCE_EXTERNAL_SRCS += $(shell find -L $(RADIANCE_CSRC_DIR) -type f)
|
||||
else
|
||||
VORTEX_VLOG_SOURCES := $(shell fd -L -t f -e "sv" -e "vh" -e "v" . $(VORTEX_SRC_DIR))
|
||||
# RADIANCE_EXTERNAL_SRCS := $(shell fdfind -L -t f -e "sv" -e "vh" -e "v" . $(VORTEX_SRC_DIR))
|
||||
RADIANCE_EXTERNAL_SRCS := $(shell fdfind -L -t f -e "sv" -e "vh" -e "v" . $(RADIANCE_VSRC_DIR))
|
||||
RADIANCE_EXTERNAL_SRCS += $(shell fdfind -L -t f . $(RADIANCE_CSRC_DIR))
|
||||
endif
|
||||
# VORTEX_COLLATERAL := $(patsubst $(VORTEX_SRC_DIR)%,$(GEN_COLLATERAL_DIR)%,$(VORTEX_VLOG_SOURCES))
|
||||
# check if expanded
|
||||
# $(info VORTEX_VLOG_SOURCES: $(VORTEX_VLOG_SOURCES))
|
||||
|
||||
# for debug; check if expanded
|
||||
# $(info RADIANCE_EXTERNAL_SRCS: $(RADIANCE_EXTERNAL_SRCS))
|
||||
|
||||
# For every Vortex verilog source file, if there's a matching file in
|
||||
# gen-collateral/, copy them over. This is a hacky way to ensure the changes
|
||||
@@ -59,8 +66,8 @@ endif
|
||||
# necessary when common.mk does not trigger chipyard jar rebuild upon verilog
|
||||
# source updates, in which case we need to manually ensure the up-to-date-ness
|
||||
# of gen-collateral/.
|
||||
vortex_vsrc.$(CONFIG): $(VORTEX_VLOG_SOURCES)
|
||||
@for file in $(VORTEX_VLOG_SOURCES); do \
|
||||
vortex_vsrc.$(CONFIG): $(RADIANCE_EXTERNAL_SRCS)
|
||||
@for file in $(RADIANCE_EXTERNAL_SRCS); do \
|
||||
filename=$$(basename "$$file"); \
|
||||
if [ -f $(GEN_COLLATERAL_DIR)/$$filename ]; then \
|
||||
if ! diff $$file $(GEN_COLLATERAL_DIR)/$$filename &>/dev/null ; then \
|
||||
|
||||
Reference in New Issue
Block a user