Ahmed Ghazy | 31c3465 | 2020-12-01 19:59:44 +0200 | [diff] [blame] | 1 | # cannot commit files larger than 100 MB to GitHub |
| 2 | FILE_SIZE_LIMIT_MB = 100 |
| 3 | LARGE_FILES := $(shell find ./gds -type f -name "*.gds") |
Ahmed Ghazy | 0011f61 | 2020-12-02 22:53:33 +0200 | [diff] [blame] | 4 | LARGE_FILES += $(shell find . -type f -size +$(FILE_SIZE_LIMIT_MB)M -not -path "./.git/*" -not -path "./gds/*" -not -path "./openlane/*") |
Ahmed Ghazy | 5898e4a | 2020-11-13 22:28:55 +0200 | [diff] [blame] | 5 | |
| 6 | LARGE_FILES_GZ := $(addsuffix .gz, $(LARGE_FILES)) |
| 7 | |
| 8 | ARCHIVES := $(shell find . -type f -name "*.gz") |
| 9 | ARCHIVE_SOURCES := $(basename $(ARCHIVES)) |
| 10 | |
Ahmed Ghazy | fdda2cb | 2020-12-04 02:00:38 +0200 | [diff] [blame] | 11 | |
agorararmard | 212cd82 | 2020-11-26 22:40:17 +0200 | [diff] [blame] | 12 | # PDK setup configs |
| 13 | THREADS ?= $(shell nproc) |
| 14 | STD_CELL_LIBRARY ?= sky130_fd_sc_hd |
| 15 | SPECIAL_VOLTAGE_LIBRARY ?= sky130_fd_sc_hvl |
| 16 | IO_LIBRARY ?= sky130_fd_io |
agorararmard | fed74ec | 2020-12-01 18:03:46 +0200 | [diff] [blame] | 17 | SKYWATER_COMMIT ?= 3d7617a1acb92ea883539bcf22a632d6361a5de4 |
agorararmard | c804333 | 2020-12-04 23:53:38 +0200 | [diff] [blame] | 18 | OPEN_PDKS_COMMIT ?= b184e85de7629b8c87087a46b79eb45e7f7cd383 |
Ahmed Ghazy | efdc529 | 2020-11-19 16:05:48 +0200 | [diff] [blame] | 19 | |
| 20 | .DEFAULT_GOAL := ship |
Ahmed Ghazy | efdc529 | 2020-11-19 16:05:48 +0200 | [diff] [blame] | 21 | # We need portable GDS_FILE pointers... |
| 22 | .PHONY: ship |
agorararmard | 212cd82 | 2020-11-26 22:40:17 +0200 | [diff] [blame] | 23 | ship: check-env uncompress |
Ahmed Ghazy | efdc529 | 2020-11-19 16:05:48 +0200 | [diff] [blame] | 24 | @echo "###############################################" |
| 25 | @echo "Generating Caravel GDS (sources are in the 'gds' directory)" |
| 26 | @sleep 1 |
agorararmard | f8e91c3 | 2020-11-30 23:59:58 +0200 | [diff] [blame] | 27 | @cp gds/caravel.gds gds/caravel.old.gds && echo "Copying old Caravel to gds/caravel.old.gds" || true |
Ahmed Ghazy | 0252f54 | 2020-11-25 14:45:38 +0200 | [diff] [blame] | 28 | @cd gds && MAGTYPE=mag magic -rcfile ${PDK_ROOT}/sky130A/libs.tech/magic/current/sky130A.magicrc -noc -dnull gen_caravel.tcl < /dev/null |
Ahmed Ghazy | efdc529 | 2020-11-19 16:05:48 +0200 | [diff] [blame] | 29 | |
| 30 | |
Ahmed Ghazy | e4c7ec5 | 2020-11-20 13:10:15 +0200 | [diff] [blame] | 31 | |
Ahmed Ghazy | 5898e4a | 2020-11-13 22:28:55 +0200 | [diff] [blame] | 32 | .PHONY: clean |
| 33 | clean: |
| 34 | echo "clean" |
| 35 | |
| 36 | |
| 37 | |
| 38 | .PHONY: verify |
| 39 | verify: |
| 40 | echo "verify" |
| 41 | |
| 42 | |
| 43 | |
| 44 | $(LARGE_FILES_GZ): %.gz: % |
Ahmed Ghazy | 0252f54 | 2020-11-25 14:45:38 +0200 | [diff] [blame] | 45 | @if ! [ $(suffix $<) == ".gz" ]; then\ |
Ahmed Ghazy | e4c7ec5 | 2020-11-20 13:10:15 +0200 | [diff] [blame] | 46 | gzip -n --best $< > /dev/null &&\ |
Ahmed Ghazy | 5898e4a | 2020-11-13 22:28:55 +0200 | [diff] [blame] | 47 | echo "$< -> $@";\ |
| 48 | fi |
| 49 | |
Ahmed Ghazy | e4c7ec5 | 2020-11-20 13:10:15 +0200 | [diff] [blame] | 50 | # This target compresses all files larger than $(FILE_SIZE_LIMIT_MB) MB |
Ahmed Ghazy | 5898e4a | 2020-11-13 22:28:55 +0200 | [diff] [blame] | 51 | .PHONY: compress |
| 52 | compress: $(LARGE_FILES_GZ) |
| 53 | @echo "Files larger than $(FILE_SIZE_LIMIT_MB) MBytes are compressed!" |
| 54 | |
| 55 | |
| 56 | |
| 57 | $(ARCHIVE_SOURCES): %: %.gz |
Ahmed Ghazy | e4c7ec5 | 2020-11-20 13:10:15 +0200 | [diff] [blame] | 58 | @gzip -d $< &&\ |
| 59 | echo "$< -> $@";\ |
Ahmed Ghazy | 5898e4a | 2020-11-13 22:28:55 +0200 | [diff] [blame] | 60 | |
| 61 | .PHONY: uncompress |
| 62 | uncompress: $(ARCHIVE_SOURCES) |
| 63 | @echo "All files are uncompressed!" |
agorararmard | 212cd82 | 2020-11-26 22:40:17 +0200 | [diff] [blame] | 64 | |
Ahmed Ghazy | fdda2cb | 2020-12-04 02:00:38 +0200 | [diff] [blame] | 65 | |
| 66 | # LVS |
| 67 | NETGEN_SETUP=$(PDK_ROOT)/sky130A/libs.tech/netgen/sky130A_setup.tcl |
| 68 | |
| 69 | BLOCKS = $(shell cd openlane && find * -maxdepth 0 -type d) |
| 70 | LVS_BLOCKS = $(foreach block, $(BLOCKS), lvs-$(block)) |
| 71 | $(LVS_BLOCKS): lvs-% : ./mag/%.mag ./verilog/gl/%.v ./spi/lvs/%.spice |
| 72 | echo "Extracting $*" |
| 73 | mkdir -p ./mag/tmp |
| 74 | echo "load $* -dereference;\ |
| 75 | extract no all;\ |
| 76 | extract do local;\ |
| 77 | extract;\ |
| 78 | ext2spice lvs;\ |
| 79 | ext2spice;\ |
| 80 | feedback save extract_$*.log;\ |
| 81 | exit;" > ./mag/extract_$*.tcl |
| 82 | cd mag && MAGTYPE=maglef magic -rcfile ${PDK_ROOT}/sky130A/libs.tech/magic/current/sky130A.magicrc -noc -dnull extract_$*.tcl |
| 83 | mv ./mag/$*.spice ./spi/lvs |
| 84 | mv -f ./mag/extract_$*.{tcl,log} ./mag/*.ext ./mag/tmp |
| 85 | #### |
| 86 | mkdir -p ./spi/lvs/tmp |
| 87 | sh ./spi/lvs/run_lvs.sh ./verilog/gl/$*.v ./spi/lvs/$*.spice $* |
| 88 | mv -f ./spi/lvs/*{.out,.json,.log} ./spi/lvs/tmp |
| 89 | |
| 90 | |
| 91 | .PHONY: help |
| 92 | help: |
| 93 | @$(MAKE) -pRrq -f $(lastword $(MAKEFILE_LIST)) : 2>/dev/null | awk -v RS= -F: '/^# File/,/^# Finished Make data base/ {if ($$1 !~ "^[#.]") {print $$1}}' | sort | egrep -v -e '^[^[:alnum:]]' -e '^$@$$' |
| 94 | |
| 95 | |
| 96 | ########################################################################### |
agorararmard | 212cd82 | 2020-11-26 22:40:17 +0200 | [diff] [blame] | 97 | .PHONY: pdk |
| 98 | pdk: skywater-pdk skywater-library open_pdks build-pdk |
| 99 | |
| 100 | $(PDK_ROOT)/skywater-pdk: |
| 101 | git clone https://github.com/google/skywater-pdk.git $(PDK_ROOT)/skywater-pdk |
| 102 | |
| 103 | .PHONY: skywater-pdk |
| 104 | skywater-pdk: check-env $(PDK_ROOT)/skywater-pdk |
| 105 | cd $(PDK_ROOT)/skywater-pdk && \ |
| 106 | git checkout -qf $(SKYWATER_COMMIT) |
| 107 | |
| 108 | .PHONY: skywater-library |
| 109 | skywater-library: check-env $(PDK_ROOT)/skywater-pdk |
| 110 | cd $(PDK_ROOT)/skywater-pdk && \ |
| 111 | git submodule update --init libraries/$(STD_CELL_LIBRARY)/latest && \ |
| 112 | git submodule update --init libraries/$(IO_LIBRARY)/latest && \ |
| 113 | git submodule update --init libraries/$(SPECIAL_VOLTAGE_LIBRARY)/latest && \ |
| 114 | $(MAKE) -j$(THREADS) timing |
| 115 | |
| 116 | ### OPEN_PDKS |
| 117 | $(PDK_ROOT)/open_pdks: |
agorararmard | 065a942 | 2020-12-05 00:24:07 +0200 | [diff] [blame^] | 118 | git clone https://github.com/RTimothyEdwards/open_pdks.git $(PDK_ROOT)/open_pdks |
agorararmard | 212cd82 | 2020-11-26 22:40:17 +0200 | [diff] [blame] | 119 | |
| 120 | .PHONY: open_pdks |
| 121 | open_pdks: check-env $(PDK_ROOT)/open_pdks |
| 122 | cd $(PDK_ROOT)/open_pdks && \ |
| 123 | git checkout -qf $(OPEN_PDKS_COMMIT) |
| 124 | |
| 125 | .PHONY: build-pdk |
| 126 | build-pdk: check-env $(PDK_ROOT)/open_pdks $(PDK_ROOT)/skywater-pdk |
| 127 | [ -d $(PDK_ROOT)/sky130A ] && \ |
| 128 | (echo "Warning: A sky130A build already exists under $(PDK_ROOT). It will be deleted first!" && \ |
| 129 | sleep 5 && \ |
| 130 | rm -rf $(PDK_ROOT)/sky130A) || \ |
| 131 | true |
| 132 | cd $(PDK_ROOT)/open_pdks && \ |
| 133 | ./configure --with-sky130-source=$(PDK_ROOT)/skywater-pdk/libraries --with-sky130-local-path=$(PDK_ROOT) && \ |
| 134 | cd sky130 && \ |
| 135 | $(MAKE) veryclean && \ |
| 136 | $(MAKE) && \ |
| 137 | $(MAKE) install-local |
| 138 | |
| 139 | check-env: |
| 140 | ifndef PDK_ROOT |
| 141 | $(error PDK_ROOT is undefined, please export it before running make) |
Ahmed Ghazy | 31c3465 | 2020-12-01 19:59:44 +0200 | [diff] [blame] | 142 | endif |