2021-11-16 23:33:35 +01:00
|
|
|
TOP_DIR := $(realpath $(dir $(lastword $(MAKEFILE_LIST)))../..)
|
|
|
|
|
include $(TOP_DIR)/openram.mk
|
|
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
.DEFAULT_GOAL := all
|
2021-11-16 23:33:35 +01:00
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
ARGS ?=
|
2022-02-10 20:30:20 +01:00
|
|
|
TEST_TECHS ?= scn4m_subm freepdk45
|
2022-02-10 20:18:52 +01:00
|
|
|
TECHS ?= scn4m_subm freepdk45 sky130
|
2021-11-16 23:33:35 +01:00
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
TEST_DIR = $(TOP_DIR)/compiler/tests
|
|
|
|
|
TEST_SRCS = $(sort $(notdir $(wildcard $(TEST_DIR)/*_test.py)))
|
|
|
|
|
TEST_BASES = $(basename $(TEST_SRCS))
|
|
|
|
|
TEST_STAMPS= $(addsuffix .ok,$(TEST_BASES))
|
2021-11-16 23:33:35 +01:00
|
|
|
|
2023-01-23 03:19:56 +01:00
|
|
|
OPENRAM_DIR = $(OPENRAM_HOME)/tests
|
2022-02-04 23:38:35 +01:00
|
|
|
RESULTS_DIR = $(OPENRAM_DIR)/results
|
|
|
|
|
|
2022-02-09 01:04:43 +01:00
|
|
|
# Use % for all techs:
|
|
|
|
|
# %/test.py
|
|
|
|
|
# or a specific tech:
|
|
|
|
|
# freepdk45/test.py
|
|
|
|
|
BROKEN_STAMPS = \
|
|
|
|
|
sky130/01_library_test.ok \
|
|
|
|
|
sky130/04_column_mux_pbitcell_test.ok \
|
|
|
|
|
sky130/04_dummy_pbitcell_test.ok \
|
|
|
|
|
sky130/04_pbitcell_test.ok \
|
|
|
|
|
sky130/04_pnand4_test.ok \
|
2022-02-10 20:30:20 +01:00
|
|
|
sky130/04_pand4_test.ok \
|
2022-02-09 01:04:43 +01:00
|
|
|
sky130/04_precharge_pbitcell_test.ok \
|
|
|
|
|
sky130/04_replica_pbitcell_test.ok \
|
|
|
|
|
sky130/05_pbitcell_array_test.ok \
|
|
|
|
|
sky130/05_bitcell_array_test.ok \
|
|
|
|
|
sky130/05_bitcell_array_1rw_1r_test.ok \
|
|
|
|
|
sky130/05_dummy_array_test.ok \
|
2022-03-06 20:27:13 +01:00
|
|
|
%/06_hierarchical_decoder_4096row_test.ok \
|
2022-02-09 01:04:43 +01:00
|
|
|
sky130/07_column_mux_array_pbitcell_test.ok \
|
|
|
|
|
sky130/19_pmulti_bank_test.ok \
|
|
|
|
|
sky130/19_psingle_bank_test.ok \
|
|
|
|
|
sky130/19_bank_select_pbitcell_test.ok \
|
2022-03-01 19:33:40 +01:00
|
|
|
%/19_single_bank_16mux_1rw_1r_test.ok \
|
|
|
|
|
%/19_single_bank_16mux_test.ok \
|
2022-03-01 19:44:56 +01:00
|
|
|
%/20_sram_1bank_16mux_1rw_1r_test.ok \
|
2022-02-28 21:03:01 +01:00
|
|
|
%/20_sram_1bank_16mux_test.ok \
|
2022-03-01 19:33:40 +01:00
|
|
|
%/20_psram_1bank_2mux_1rw_1w_test.ok \
|
|
|
|
|
%/20_psram_1bank_2mux_1rw_1w_wmask_test.ok \
|
|
|
|
|
%/20_psram_1bank_2mux_1w_1r_test.ok \
|
|
|
|
|
%/20_psram_1bank_2mux_test.ok \
|
2022-03-01 23:44:04 +01:00
|
|
|
%/21_hspice_delay_test.ok \
|
|
|
|
|
%/21_hspice_setuphold_test.ok \
|
2022-02-09 01:04:43 +01:00
|
|
|
sky130/20_psram_1bank_4mux_1rw_1r_test.ok \
|
|
|
|
|
sky130/22_psram_1bank_2mux_func_test.ok \
|
|
|
|
|
sky130/22_psram_1bank_4mux_func_test.ok \
|
|
|
|
|
sky130/22_psram_1bank_8mux_func_test.ok \
|
|
|
|
|
sky130/22_psram_1bank_nomux_func_test.ok \
|
2022-02-24 00:31:15 +01:00
|
|
|
%/22_psram_1bank_2mux_func_test.ok \
|
|
|
|
|
%/22_psram_1bank_4mux_func_test.ok \
|
|
|
|
|
%/22_psram_1bank_8mux_func_test.ok \
|
|
|
|
|
%/22_psram_1bank_nomux_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_2mux_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_2mux_global_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_2mux_sparecols_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_4mux_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_8mux_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_nomux_1rw_1r_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_nomux_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_nomux_sparecols_func_test.ok \
|
|
|
|
|
%/22_sram_1bank_wmask_1rw_1r_func_test.ok \
|
|
|
|
|
%/22_sram_wmask_func_test.ok \
|
2022-03-06 20:27:13 +01:00
|
|
|
sky130/23_lib_sram_linear_regression_test.ok \
|
|
|
|
|
sky130/23_lib_sram_model_corners_test.ok \
|
|
|
|
|
sky130/23_lib_sram_model_test.ok \
|
|
|
|
|
sky130/23_lib_sram_prune_test.ok \
|
|
|
|
|
sky131/23_lib_sram_test.ok \
|
2022-03-01 23:44:04 +01:00
|
|
|
%/26_hspice_pex_pinv_test.ok \
|
2022-07-14 01:40:21 +02:00
|
|
|
%/27_verilog_multibank_test.ok \
|
2022-02-09 01:04:43 +01:00
|
|
|
%/50_riscv_1k_1rw1r_func_test.ok \
|
|
|
|
|
%/50_riscv_1k_1rw_func_test.ok \
|
|
|
|
|
%/50_riscv_1rw1r_func_test.ok \
|
|
|
|
|
%/50_riscv_1rw1r_phys_test.ok \
|
|
|
|
|
%/50_riscv_1rw_func_test.ok \
|
|
|
|
|
%/50_riscv_1rw_phys_test.ok \
|
|
|
|
|
%/50_riscv_2k_1rw1r_func_test.ok \
|
|
|
|
|
%/50_riscv_2k_1rw_func_test.ok \
|
|
|
|
|
%/50_riscv_4k_1rw1r_func_test.ok \
|
|
|
|
|
%/50_riscv_4k_1rw_func_test.ok \
|
|
|
|
|
%/50_riscv_512b_1rw1r_func_test.ok \
|
|
|
|
|
%/50_riscv_512b_1rw_func_test.ok \
|
|
|
|
|
%/50_riscv_8k_1rw1r_func_test.ok \
|
2023-02-17 19:42:31 +01:00
|
|
|
%/50_riscv_8k_1rw_func_test.ok \
|
2021-11-16 23:33:35 +01:00
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
gettech = $(word 1,$(subst /, ,$*))
|
|
|
|
|
getfile = $(word 2,$(subst /, ,$*))
|
2022-02-10 20:18:52 +01:00
|
|
|
TECH_TEST_STAMPS=$(foreach T, $(TEST_TECHS), $(addprefix $T/, $(TEST_STAMPS)))
|
2022-02-09 01:04:43 +01:00
|
|
|
|
|
|
|
|
# Filter out the tests after creating the tech stamps
|
2022-03-06 19:31:43 +01:00
|
|
|
WORKING_TECH_TEST_STAMPS=$(shell shuf -e -- $(filter-out $(BROKEN_STAMPS), $(TECH_TEST_STAMPS)))
|
2022-02-09 01:04:43 +01:00
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
|
2022-02-07 20:27:10 +01:00
|
|
|
# Run all technologies
|
2022-03-07 16:58:41 +01:00
|
|
|
all: clean $(WORKING_TECH_TEST_STAMPS)
|
2022-02-11 22:11:24 +01:00
|
|
|
@ls -1 $(TOP_DIR)/compiler/tests/results/*/*.bad 1> /dev/null 2>&1 && echo "FAILING TESTS" && ls -1 $(TOP_DIR)/compiler/tests/results/*/*.bad | sed -e "s#^.*results\/##" && exit 1 || exit 0
|
2022-02-04 23:38:35 +01:00
|
|
|
.PHONY: all
|
|
|
|
|
|
2022-02-07 20:27:10 +01:00
|
|
|
# Run a given technology
|
|
|
|
|
# e.g. make freepdk45
|
2022-03-06 19:31:43 +01:00
|
|
|
$(TECHS):
|
2022-02-09 01:04:43 +01:00
|
|
|
@$(MAKE) --no-print-directory $(filter-out $(BROKEN_STAMPS), $(addprefix $@/, $(TEST_STAMPS)))
|
2022-02-07 20:27:10 +01:00
|
|
|
.PHONY: $(TECHS)
|
|
|
|
|
|
2022-02-10 20:18:52 +01:00
|
|
|
# Targets for each individual test in all technologies
|
2022-02-04 23:38:35 +01:00
|
|
|
# e.g. make 04_pinv_1x_test
|
|
|
|
|
$(TEST_BASES):
|
2022-02-10 20:18:52 +01:00
|
|
|
@$(MAKE) --no-print-directory $(foreach T, $(TECHS), $(addprefix $T/, $@.ok))
|
2022-02-04 23:38:35 +01:00
|
|
|
.PHONY: $(TEST_BASES)
|
2021-11-16 23:33:35 +01:00
|
|
|
|
2022-02-04 23:38:35 +01:00
|
|
|
# To run a test in a given technology
|
2022-03-01 19:33:40 +01:00
|
|
|
%.ok:
|
2022-02-04 23:38:35 +01:00
|
|
|
# @echo "Running $(gettech) $(getfile) ... "
|
2022-02-02 18:36:19 +01:00
|
|
|
@rm -rf results/$*
|
2022-02-11 22:11:24 +01:00
|
|
|
@rm -rf results/$*.*
|
2022-02-04 23:38:35 +01:00
|
|
|
@mkdir -p results/$*/tmp
|
2023-01-23 03:19:56 +01:00
|
|
|
@sh -c "python3 -u $(OPENRAM_DIR)/$(getfile).py -t $(gettech) -k -v $(ARGS) -p $(OPENRAM_DIR)/results/$* > $(OPENRAM_DIR)/results/$*.out 2>&1 && touch $(OPENRAM_DIR)/results/$*.ok || touch $(OPENRAM_DIR)/results/$*.bad"
|
2022-11-02 16:02:22 +01:00
|
|
|
ifdef KEEP
|
2022-09-08 22:40:48 +02:00
|
|
|
@test -f $(TOP_DIR)/compiler/tests/results/$*.ok && echo "$* ... PASS!" || echo "$* ... FAIL!"
|
|
|
|
|
else
|
|
|
|
|
@test -f $(TOP_DIR)/compiler/tests/results/$*.ok && echo "$* ... PASS!" && rm -rf $(TOP_DIR)/compiler/tests/results/$* || echo "$* ... FAIL!"
|
|
|
|
|
endif
|
2021-11-16 23:33:35 +01:00
|
|
|
.DELETE_ON_ERROR: $(TEST_STAMPS)
|
|
|
|
|
|
2022-03-01 19:33:40 +01:00
|
|
|
.PHONY: docker-pull
|
|
|
|
|
docker-pull:
|
|
|
|
|
docker pull vlsida/openram-ubuntu:latest
|
|
|
|
|
|
2021-11-16 23:33:35 +01:00
|
|
|
clean:
|
2022-02-04 23:38:35 +01:00
|
|
|
@rm -rf $(TOP_DIR)/compiler/tests/results
|
2021-11-16 23:33:35 +01:00
|
|
|
.PHONE: clean
|