OpenRAM/compiler/Makefile

107 lines
2.5 KiB
Makefile
Raw Normal View History

TECH = scn4m_subm
CUR_DIR = $(shell pwd)
TEST_DIR = ${CUR_DIR}/tests
#MAKEFLAGS += -j 1
# Library test
2018-12-05 21:58:10 +01:00
LIBRARY_TESTS = $(shell find ${TEST_DIR} -name 0[1-2]*_test.py)
# Technology and DRC tests (along with ptx)
2018-12-05 21:58:10 +01:00
TECH_TESTS = $(shell find ${TEST_DIR} -name 03*_test.py)
# Parameterized cells
2018-12-05 21:58:10 +01:00
CELL_TESTS = $(shell find ${TEST_DIR} -name 04*_test.py)
# Dynamically generated modules and arrays
2018-12-05 21:58:10 +01:00
MODULE_TESTS = $(shell find ${TEST_DIR} -name 0[5-9]*_test.py)\
$(shell find ${TEST_DIR} -name 1*_test.py)
# Top-level SRAM configurations
2018-12-05 21:58:10 +01:00
TOP_TESTS = $(shell find ${TEST_DIR} -name 20*_test.py)
# All simulation tests.
2018-12-05 21:58:10 +01:00
CHAR_TESTS = $(shell find ${TEST_DIR} -name 2[1-2]*_test.py)
# Keep the model lib test here since it is fast
# and doesn't need simulation.
2018-12-05 21:58:10 +01:00
USAGE_TESTS = $(shell find ${TEST_DIR} -name 2[3-9]*_test.py)\
$(shell find ${TEST_DIR} -name 30*_test.py)
2018-12-05 21:58:10 +01:00
ALL_TESTS = \
${LIBRARY_TESTS} \
${TECH_TESTS} \
2018-12-05 21:58:10 +01:00
${CELL_TESTS} \
${MODULE_TESTS} \
${TOP_TESTS} \
${CHAR_TESTS} \
2021-11-03 19:36:19 +01:00
${USAGE_TESTS}
2018-12-05 21:58:10 +01:00
.PHONY: ${ALL_TESTS}
2018-12-05 21:58:10 +01:00
all: ${ALL_TESTS}
# Library tests
lib: ${LIBRARY_TESTS}
# Transistor and wire tests
tech: ${TECH_TESTS}
# Dynamically generated cells
2018-12-05 21:58:10 +01:00
cell: ${CELL_TESTS}
# Dynamically generated modules
2018-12-05 21:58:10 +01:00
module: ${MODULE_TESTS}
# Top level SRAM tests
top: ${TOP_TESTS}
# Timing and characterization tests
char: ${CHAR_TESTS}
# Usage and file generation
usage: ${USAGE_TESTS}
2018-12-05 21:58:10 +01:00
$(ALL_TESTS):
python3 $@ -t ${TECH}
2021-11-03 19:36:19 +01:00
OPENRAM_TECHS = $(subst :, ,$(OPENRAM_TECH))
TECH_DIR := $(word 1, $(foreach dir,$(OPENRAM_TECHS),$(wildcard $(dir)/$(TECH))))
CONFIG_DIR = $(OPENRAM_HOME)/model_configs
MODEL_CONFIGS = $(wildcard $(CONFIG_DIR)/*.py)
SIM_DIR = $(OPENRAM_HOME)/model_data/$(TECH)
CSV_DIR = $(TECH_DIR)/sim_data
# Creates names of technology specific okay files for the configs
STAMPS=$(addprefix $(SIM_DIR)/, $(addsuffix .ok, $(notdir $(basename $(MODEL_CONFIGS)))))
2021-11-03 19:36:19 +01:00
OPTS =
# Characterize and perform DRC/LVS
2021-11-03 19:36:19 +01:00
OPTS += -c
# Do not characterize or perform DRC/LVS
OPTS += -n
# Verbosity
#OPTS += -v
# Spice
OPTS += -s hspice
.PHONY: model
model: $(STAMPS)
mkdir -p $(CSV_DIR)
python3 $(OPENRAM_HOME)/model_data_util.py $(SIM_DIR) $(CSV_DIR)
%.ok:
$(eval bname=$(basename $(notdir $@)))
$(eval config_path=$(CONFIG_DIR)/$(addsuffix .py, $(notdir $(basename $@))))
mkdir -p $(SIM_DIR)/$(bname)
2022-11-06 23:05:08 +01:00
-python3 $(OPENRAM_HOME)/../sram_compiler.py $(OPTS) -p $(SIM_DIR)/$(bname) -o $(bname) -t $(TECH) $(config_path) 2>&1 > /dev/null
touch $@
clean_model:
rm -f -r $(SIM_DIR)/*.ok
2021-11-03 19:36:19 +01:00
clean:
find . -name \*.pyc -exec rm {} \;
find . -name \*~ -exec rm {} \;