Change Makefile to use docker in parallel instead of regress.py

This commit is contained in:
mrg 2022-02-04 14:38:35 -08:00
parent 049751ae1f
commit 548178e343
1 changed files with 43 additions and 45 deletions

View File

@ -1,14 +1,20 @@
TOP_DIR := $(realpath $(dir $(lastword $(MAKEFILE_LIST)))../..) TOP_DIR := $(realpath $(dir $(lastword $(MAKEFILE_LIST)))../..)
include $(TOP_DIR)/openram.mk include $(TOP_DIR)/openram.mk
.DEFAULT_GOAL := regress .DEFAULT_GOAL := all
ARGS ?= "-k" ARGS ?=
TECH ?= scn4m_subm
TECHS := scn4m_subm freepdk45
# sky130
TEST_DIR = $(TOP_DIR)/compiler/tests TEST_DIR = $(TOP_DIR)/compiler/tests
TEST_SRCS=$(sort $(notdir $(wildcard $(TEST_DIR)/*_test.py))) TEST_SRCS = $(sort $(notdir $(wildcard $(TEST_DIR)/*_test.py)))
TEST_DIRS=$(basename $(TEST_SRCS)) TEST_BASES = $(basename $(TEST_SRCS))
TEST_STAMPS=$(addsuffix .ok,$(TEST_DIRS)) TEST_STAMPS= $(addsuffix .ok,$(TEST_BASES))
OPENRAM_DIR := /openram/compiler/tests
RESULTS_DIR := $(OPENRAM_DIR)/results
TEST_BROKEN := \ TEST_BROKEN := \
50_riscv_1k_1rw1r_func_test.py \ 50_riscv_1k_1rw1r_func_test.py \
@ -29,55 +35,48 @@ TEST_BROKEN := \
WORKING_TEST_STAMPS=$(filter-out $(addsuffix .ok, (TEST_BROKEN)), $(TEST_STAMPS)) WORKING_TEST_STAMPS=$(filter-out $(addsuffix .ok, (TEST_BROKEN)), $(TEST_STAMPS))
$(TEST_DIRS):
$(TEST_BASES):
@$(MAKE) --no-print-directory $@.ok @$(MAKE) --no-print-directory $@.ok
tests: gettech = $(word 1,$(subst /, ,$*))
@echo "Running the following tests" getfile = $(word 2,$(subst /, ,$*))
@for S in $(WORKING_TEST_STAMPS); do echo " - $$S"; done WORKING_TECH_TEST_STAMPS=$(foreach T, $(TECHS),$(addprefix $T/,$(WORKING_TEST_STAMPS)))
@sleep 5
@$(MAKE) $(WORKING_TEST_STAMPS)
.PHONY:
all: $(WORKING_TECH_TEST_STAMPS)
# To run individual tests
%.ok: %.py %.ok: %.py
@echo "Running $*" @$(MAKE) --no-print-directory $(TECH)/$*.ok
@mkdir -p $(TOP_DIR)/compiler/tests/results/$*
# To run a test in a given technology
%.ok:
# @echo "Running $(gettech) $(getfile) ... "
@mkdir -p results/$*
@docker run \ @docker run \
-v $(TOP_DIR):/openram \ -v $(TOP_DIR):/openram \
-v $(FREEPDK45):/pdk/freepdk45\ -v $(FREEPDK45):/pdk/freepdk45\
-v $(PDK_ROOT):/pdk \ -v $(PDK_ROOT):/pdk \
--user $(UID):$(GID) \ --user $(UID):$(GID) \
-e OPENRAM_TMP=$(OPENRAM_DIR)/results/$* \
vlsida/openram-ubuntu:latest \ vlsida/openram-ubuntu:latest \
sh -c ". ~/.bashrc && python3 -u /openram/compiler/tests/$*.py $(ARGS) && touch $@" sh -c ". ~/.bashrc && python3 -u $(OPENRAM_DIR)/$(getfile).py -t $(gettech) -k $(ARGS) > $(OPENRAM_DIR)/results/$*.out 2>&1 && touch $(OPENRAM_DIR)/results/$*.ok"
@test -f $(TOP_DIR)/compiler/tests/results/$*.ok && echo "$* ... PASS!" || echo "$* ... FAIL!"
.DELETE_ON_ERROR: $(TEST_STAMPS) .DELETE_ON_ERROR: $(TEST_STAMPS)
TECHS := scn4m_subm freepdk45 #$(TECHS):
#sky130 # @echo "Running $*"
# docker run \
$(TECHS): # -v $(TOP_DIR):/openram \
docker run \ # -v $(FREEPDK45):/pdk/freepdk45 \
-v $(TOP_DIR):/openram \ # -v $(PDK_ROOT):/pdk \
-v $(FREEPDK45):/pdk/freepdk45 \ # --user $(UID):$(GID) \
-v $(PDK_ROOT):/pdk \ # -e OPENRAM_TMP=$(OPENRAM_DIR)/results/$@ \
--user $(UID):$(GID) \ # vlsida/openram-ubuntu:latest \
-e OPENRAM_TMP=/openram/compiler/tests/tmp_$@/$* \ # sh -c ". ~/.bashrc && python3 -u $(OPENRAM_DIR)/regress.py -t $@ $(ARGS)"
vlsida/openram-ubuntu:latest \ #.PHONY: $(TECHS)
sh -c ". ~/.bashrc && python3 -u /openram/compiler/tests/regress.py $(ARGS) -t $@" #regress: $(TECHS)
.PHONY: $(TECHS) #.PHONY: regress
regress: $(TECHS)
.PHONY: regress
foo:
docker run \
-v $(TOP_DIR):/openram \
-v $(FREEPDK45):/pdk/freepdk45 \
-v $(PDK_ROOT):/pdk \
--user $(UID):$(GID) \
vlsida/openram-ubuntu:latest \
sh -c ". ~/.bashrc && env"
.PHONY: foo
mount: mount:
docker run -it \ docker run -it \
@ -89,6 +88,5 @@ mount:
.PHONY: mount .PHONY: mount
clean: clean:
@rm -rf $(TEST_STAMPS) @rm -rf $(TOP_DIR)/compiler/tests/results
@rm -rf $(TEST_DIRS)
.PHONE: clean .PHONE: clean