############################################################## # extra variables/targets ingested by the chipyard make system ############################################################## VORTEX_SRC_DIR = $(base_dir)/generators/radiance/src/main/resources/vsrc/vortex 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 += 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 ifeq ($(shell echo $(CONFIG) | grep -E "FP16Config$$"),$(CONFIG)) EXTRA_SIM_PREPROC_DEFINES += +define+NUM_CORES=8 endif ifeq ($(shell echo $(CONFIG) | grep -E "HopperConfig$$"),$(CONFIG)) EXTRA_SIM_PREPROC_DEFINES += +define+NUM_CORES=4 +define+EXT_T_HOPPER endif ifeq ($(shell echo $(CONFIG) | grep -E "BlackwellConfig$$"),$(CONFIG)) EXTRA_SIM_PREPROC_DEFINES += +define+NUM_CORES=1 +define+NUM_WARPS=4 +define+NUM_THREADS=4 +define+NUM_TENSOR_WARPS=2 +define+EXT_T_BLACKWELL endif ifeq ($(shell echo $(CONFIG) | grep -E "FlashConfig$$"),$(CONFIG)) EXTRA_SIM_PREPROC_DEFINES += +define+NUM_CORES=4 endif EXTRA_SIM_PREPROC_DEFINES += \ +define+SIMULATION \ +define+GPR_RESET \ +define+GPR_DUPLICATED \ +define+DBG_TRACE_CORE_PIPELINE_VCS \ +define+PERF_ENABLE \ +define+ICACHE_DISABLE +define+DCACHE_DISABLE \ +define+GBAR_ENABLE \ +define+GBAR_CLUSTER_ENABLE \ +define+FPU_FPNEW # +define+LSU_DUP_DISABLE \ 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: cyclotron cyclotron: cd $(CYCLOTRON_SRC_DIR) && cargo build # --release EXTRA_SIM_REQS += vortex_vsrc.$(CONFIG) # 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 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 # 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 # 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 # in the verilog sources are reflected before Verilator/VCS kicks in. This is # 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): $(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 \ cp -v "$$file" $(GEN_COLLATERAL_DIR); \ fi; \ fi; \ done touch $@