caravel/Makefile

907 lines
36 KiB
Makefile
Raw Normal View History

2021-11-04 09:16:39 -05:00
# SPDX-FileCopyrightText: 2020 Efabless Corporation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# SPDX-License-Identifier: Apache-2.0
# cannot commit files larger than 100 MB to GitHub
FILE_SIZE_LIMIT_MB = 100
# Commands to be used to compress/uncompress files
# they must operate **in place** (otherwise, modify the target to delete the
# intermediate file/archive)
COMPRESS ?= gzip -n --best
UNCOMPRESS ?= gzip -d
ARCHIVE_EXT ?= gz
# The following variables are to build static pattern rules
# Needed to rebuild archives that were previously split
SPLIT_FILES := $(shell find . -type f -name "*.$(ARCHIVE_EXT).00.split")
SPLIT_FILES_ARCHIVES := $(basename $(basename $(SPLIT_FILES)))
2021-11-04 09:16:39 -05:00
SPLIT_FILES_SOURCES := $(basename $(basename $(basename $(SPLIT_FILES))))
# Needed to uncompress the existing archives
ARCHIVES := $(shell find . -type f -not -path "*/signoff/*" -name "*.$(ARCHIVE_EXT)")
2021-11-04 09:16:39 -05:00
ARCHIVE_SOURCES := $(basename $(ARCHIVES))
# Needed to compress and split files/archives that are too large
LARGE_FILES := $(shell find ./gds -type f -name "*.gds")
LARGE_FILES += $(shell find . -type f -size +$(FILE_SIZE_LIMIT_MB)M \
-not -path "*/signoff/*" \
-not -path "*/.git/*" \
-not -path "./gds/*" \
-not -path "./tapeout/outputs/oas/*" \
-not -path "*/openlane/*" \
-not -name "*.$(ARCHIVE_EXT)")
2021-11-04 09:16:39 -05:00
LARGE_FILES_GZ := $(addsuffix .$(ARCHIVE_EXT), $(LARGE_FILES))
LARGE_FILES_GZ_SPLIT := $(addsuffix .$(ARCHIVE_EXT).00.split, $(LARGE_FILES))
# consider splitting existing archives
LARGE_FILES_GZ_SPLIT += $(addsuffix .00.split, $(ARCHIVES))
2021-11-24 11:23:58 -06:00
MCW_ROOT?=$(PWD)/mgmt_core_wrapper
MCW ?=LITEX_VEXRISCV
2024-09-12 16:01:55 -05:00
MPW_TAG ?= 2024.09.12-1
2021-11-24 11:23:58 -06:00
2023-01-19 06:16:46 -06:00
PYTHON_BIN ?= python3
# PDK switch varient
2022-04-12 11:41:40 -05:00
export PDK?=sky130A
2021-11-24 11:23:58 -06:00
# Install lite version of caravel, (1): caravel-lite, (0): caravel
MCW_LITE?=1
ifeq ($(MCW),LITEX_VEXRISCV)
MCW_NAME := mcw-litex-vexriscv
2023-09-11 13:01:40 -05:00
MCW_REPO ?= https://github.com/efabless/caravel_mgmt_soc_litex
MCW_TAG ?= $(MPW_TAG)
2021-11-24 11:23:58 -06:00
else
MCW_NAME := mcw-pico
2023-09-11 13:01:40 -05:00
MCW_REPO ?= https://github.com/efabless/caravel_pico
MCW_TAG ?= $(MPW_TAG)
2021-11-24 11:23:58 -06:00
endif
# Install caravel as submodule, (1): submodule, (0): clone
SUBMODULE?=0
2021-11-04 09:16:39 -05:00
# Caravel Root (Default: pwd)
# Need to be overwritten if running the makefile from UPRJ_ROOT,
# If caravel is sub-moduled in the user project, run export CARAVEL_ROOT=$(pwd)/caravel
CARAVEL_ROOT ?= $(shell pwd)
# User project root
UPRJ_ROOT ?= $(shell pwd)
# MANAGEMENT AREA ROOT
MGMT_AREA_ROOT ?= $(shell pwd)/mgmt_core_wrapper
# Ensure commands which are piped through tee return the correct exit code
# to make
SHELL=/bin/bash -o pipefail
2021-11-04 09:16:39 -05:00
# PDK setup configs
THREADS ?= $(shell nproc)
STD_CELL_LIBRARY ?= sky130_fd_sc_hd
SPECIAL_VOLTAGE_LIBRARY ?= sky130_fd_sc_hvl
IO_LIBRARY ?= sky130_fd_io
PRIMITIVES_LIBRARY ?= sky130_fd_pr
2023-10-22 02:00:28 -05:00
OPEN_PDKS_COMMIT ?= 12df12e2e74145e31c5a13de02f9a1e176b56e67
2022-04-25 16:02:35 -05:00
# = 1.0.303
2021-11-04 09:16:39 -05:00
.DEFAULT_GOAL := ship
# We need portable GDS_FILE pointers...
.PHONY: ship
ship: check-env uncompress uncompress-caravel
@echo "Running make ship in the foreground..."
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __ship
@echo "Make ship completed." 2>&1 | tee -a ./signoff/build/make_ship.out
__ship:
@echo "###############################################"
@echo "Generating Caravel GDS (sources are in the 'gds' directory)"
@sleep 1
#### Runs from the CARAVEL_ROOT mag directory
@echo "\
random seed `$(CARAVEL_ROOT)/scripts/set_user_id.py -report`; \
drc off; \
crashbackups stop; \
2021-11-29 16:11:12 -06:00
addpath hexdigits; \
addpath $(MCW_ROOT)/mag; \
2023-04-20 18:50:36 -05:00
addpath $(UPRJ_ROOT)/mag; \
2021-11-29 16:11:12 -06:00
load user_project_wrapper; \
property LEFview true; \
property GDS_FILE $(UPRJ_ROOT)/gds/user_project_wrapper.gds; \
property GDS_START 0; \
load $(UPRJ_ROOT)/mag/user_id_programming; \
load $(UPRJ_ROOT)/mag/user_id_textblock; \
load $(CARAVEL_ROOT)/maglef/simple_por; \
2023-04-20 18:50:36 -05:00
load $(UPRJ_ROOT)/mag/caravel_core -dereference; \
2023-04-20 20:50:22 -05:00
load caravel -dereference; \
2021-11-29 16:11:12 -06:00
select top cell; \
expand; \
2021-11-04 09:16:39 -05:00
cif *hier write disable; \
cif *array write disable; \
gds write $(UPRJ_ROOT)/gds/caravel.gds; \
2021-11-29 16:11:12 -06:00
quit -noprompt;" > $(UPRJ_ROOT)/mag/mag2gds_caravel.tcl
2021-11-04 09:16:39 -05:00
### Runs from CARAVEL_ROOT
@mkdir -p ./signoff/build
#@cd $(CARAVEL_ROOT)/mag && PDKPATH=${PDK_ROOT}/$(PDK) MAGTYPE=mag magic -noc -dnull -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc $(UPRJ_ROOT)/mag/mag2gds_caravel.tcl 2>&1 | tee $(UPRJ_ROOT)/signoff/build/make_ship.out
@cd $(CARAVEL_ROOT)/mag && PDKPATH=${PDK_ROOT}/$(PDK) MAGTYPE=mag magic -noc -dnull -rcfile ./.magicrc $(UPRJ_ROOT)/mag/mag2gds_caravel.tcl 2>&1 | tee $(UPRJ_ROOT)/signoff/build/make_ship.out
2021-11-04 09:16:39 -05:00
### @rm $(UPRJ_ROOT)/mag/mag2gds_caravel.tcl
truck: check-env uncompress uncompress-caravel
@echo "Running make truck in the foreground..."
mkdir -p ./signoff
mkdir -p ./build
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __truck
@echo "Make truck completed." 2>&1 | tee -a ./signoff/build/make_truck.out
__truck:
@echo "###############################################"
@echo "Generating Caravan GDS (sources are in the 'gds' directory)"
@sleep 1
#### Runs from the CARAVEL_ROOT mag directory
@echo "\
random seed `$(CARAVEL_ROOT)/scripts/set_user_id.py -report`; \
drc off; \
crashbackups stop; \
2021-11-29 16:11:12 -06:00
addpath hexdigits; \
2023-05-24 22:30:36 -05:00
addpath $(MCW_ROOT)/mag; \
2021-11-29 18:04:43 -06:00
addpath $(UPRJ_ROOT)/mag; \
2021-12-02 11:28:08 -06:00
load user_analog_project_wrapper; \
2021-11-29 16:11:12 -06:00
property LEFview true; \
2021-12-02 11:28:08 -06:00
property GDS_FILE $(UPRJ_ROOT)/gds/user_analog_project_wrapper.gds; \
2021-11-29 16:11:12 -06:00
property GDS_START 0; \
load $(UPRJ_ROOT)/mag/user_id_programming; \
load $(UPRJ_ROOT)/mag/user_id_textblock; \
2023-05-24 22:30:36 -05:00
load $(CARAVEL_ROOT)/maglef/simple_por; \
load $(UPRJ_ROOT)/mag/caravan_core -dereference; \
2023-05-24 23:38:26 -05:00
load caravan -dereference; \
2021-11-29 16:11:12 -06:00
select top cell; \
expand; \
2021-11-04 09:16:39 -05:00
cif *hier write disable; \
cif *array write disable; \
gds write $(UPRJ_ROOT)/gds/caravan.gds; \
2021-11-29 16:11:12 -06:00
quit -noprompt;" > $(UPRJ_ROOT)/mag/mag2gds_caravan.tcl
2021-11-04 09:16:39 -05:00
### Runs from CARAVEL_ROOT
@mkdir -p ./signoff/build
#@cd $(CARAVEL_ROOT)/mag && PDKPATH=${PDK_ROOT}/$(PDK) MAGTYPE=mag magic -noc -dnull -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc $(UPRJ_ROOT)/mag/mag2gds_caravan.tcl 2>&1 | tee $(UPRJ_ROOT)/signoff/build/make_truck.out
@cd $(CARAVEL_ROOT)/mag && PDKPATH=${PDK_ROOT}/$(PDK) MAGTYPE=mag magic -noc -dnull -rcfile ./.magicrc $(UPRJ_ROOT)/mag/mag2gds_caravan.tcl 2>&1 | tee $(UPRJ_ROOT)/signoff/build/make_truck.out
2021-11-04 09:16:39 -05:00
### @rm $(UPRJ_ROOT)/mag/mag2gds_caravan.tcl
2023-06-07 14:29:04 -05:00
.PHONY: openframe
2023-06-07 14:25:05 -05:00
openframe: check-env uncompress uncompress-caravel
@echo "Running make openframe in the foreground..."
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __openframe
@echo "Make openframe completed." 2>&1 | tee -a ./signoff/build/make_openframe.out
__openframe:
@echo "###############################################"
@echo "Generating Caravel GDS (sources are in the 'gds' directory)"
@sleep 1
#### Runs from the CARAVEL_ROOT mag directory
@echo "\
drc off; \
crashbackups stop; \
addpath hexdigits; \
addpath $(UPRJ_ROOT)/mag; \
load openframe_project_wrapper; \
property LEFview true; \
property GDS_FILE $(UPRJ_ROOT)/gds/openframe_project_wrapper.gds; \
property GDS_START 0; \
2023-06-07 19:08:10 -05:00
load $(UPRJ_ROOT)/mag/user_id_programming; \
load $(UPRJ_ROOT)/mag/user_id_textblock; \
2023-06-07 14:25:05 -05:00
load $(CARAVEL_ROOT)/maglef/simple_por; \
2023-06-07 14:31:14 -05:00
load caravel_openframe -dereference; \
2023-06-07 14:25:05 -05:00
select top cell; \
expand; \
cif *hier write disable; \
cif *array write disable; \
2023-06-07 14:25:05 -05:00
gds write $(UPRJ_ROOT)/gds/caravel_openframe.gds; \
2023-09-11 12:46:18 -05:00
quit -noprompt;" > $(UPRJ_ROOT)/mag/mag2gds_caravel_openframe.tcl
2023-06-07 14:25:05 -05:00
### Runs from CARAVEL_ROOT
@mkdir -p ./signoff/build
2023-09-11 12:46:18 -05:00
@cd $(CARAVEL_ROOT)/mag && PDKPATH=${PDK_ROOT}/$(PDK) MAGTYPE=mag magic -noc -dnull -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc $(UPRJ_ROOT)/mag/mag2gds_caravel_openframe.tcl 2>&1 | tee $(UPRJ_ROOT)/signoff/build/make_openframe.out
2023-06-07 14:25:05 -05:00
2021-11-04 09:16:39 -05:00
.PHONY: clean
clean:
cd $(CARAVEL_ROOT)/verilog/dv/caravel/mgmt_soc/ && \
$(MAKE) -j$(THREADS) clean
cd $(CARAVEL_ROOT)/verilog/dv/wb_utests/ && \
$(MAKE) -j$(THREADS) clean
.PHONY: verify
verify:
cd $(CARAVEL_ROOT)/verilog/dv/caravel/mgmt_soc/ && \
$(MAKE) -j$(THREADS) all
cd $(CARAVEL_ROOT)/verilog/dv/wb_utests/ && \
$(MAKE) -j$(THREADS) all
#####
$(LARGE_FILES_GZ): %.$(ARCHIVE_EXT): %
@if ! [ $(suffix $<) = ".$(ARCHIVE_EXT)" ]; then\
$(COMPRESS) $< > /dev/null &&\
echo "$< -> $@";\
fi
$(LARGE_FILES_GZ_SPLIT): %.$(ARCHIVE_EXT).00.split: %.$(ARCHIVE_EXT)
@if [ -n "$$(find "$<" -prune -size +$(FILE_SIZE_LIMIT_MB)M)" ]; then\
split $< -b $(FILE_SIZE_LIMIT_MB)M $<. -d &&\
rm $< &&\
for file in $$(ls $<.*); do mv "$$file" "$$file.split"; done &&\
echo -n "$< -> $$(ls $<.*.split)" | tr '\n' ' ' && echo "";\
fi
# This target compresses all files larger than $(FILE_SIZE_LIMIT_MB) MB
.PHONY: compress
compress: $(LARGE_FILES_GZ) $(LARGE_FILES_GZ_SPLIT)
@echo "Files larger than $(FILE_SIZE_LIMIT_MB) MBytes are compressed!"
#####
$(ARCHIVE_SOURCES): %: %.$(ARCHIVE_EXT)
@$(UNCOMPRESS) $<
@echo "$< -> $@"
.SECONDEXPANSION:
$(SPLIT_FILES_SOURCES): %: $$(sort $$(wildcard %.$(ARCHIVE_EXT).*.split))
@cat $? > $@.$(ARCHIVE_EXT)
@rm $?
@echo "$? -> $@.$(ARCHIVE_EXT)"
@$(UNCOMPRESS) $@.$(ARCHIVE_EXT)
@echo "$@.$(ARCHIVE_EXT) -> $@"
.PHONY: uncompress
uncompress: $(SPLIT_FILES_SOURCES) $(ARCHIVE_SOURCES)
@echo "All files are uncompressed!"
# Needed for targets that are run from UPRJ_ROOT for which caravel isn't submoduled.
.PHONY: uncompress-caravel
uncompress-caravel:
cd $(CARAVEL_ROOT) && \
$(MAKE) uncompress
.SECONDEXPANSION:
$(SPLIT_FILES_ARCHIVES): %: $$(sort $$(wildcard %.*.split))
@cat $? > $@
@rm $?
@echo "$? -> $@"
.PHONY: unsplit
unsplit: $(SPLIT_FILES_ARCHIVES)
@echo "All split files have been combined!"
# Needed for targets that are run from UPRJ_ROOT for which caravel isn't submoduled.
.PHONY: unsplit-caravel
unsplit-caravel:
cd $(CARAVEL_ROOT) && \
$(MAKE) unsplit
2021-11-04 09:16:39 -05:00
# Digital Wrapper
# verify that the wrapper was respected
.PHONY: xor-wrapper
xor-wrapper:
@echo "The xor-wrapper target has been removed."
@echo "This check is part of mpw_precheck."
@exit 1
2021-11-04 09:16:39 -05:00
# Analog Wrapper
# verify that the wrapper was respected
.PHONY: xor-analog-wrapper
xor-analog-wrapper:
@echo "The xor-analog-wrapper target has been removed."
@echo "This check is part of mpw_precheck."
@exit 1
2021-11-04 09:16:39 -05:00
OPENLANE_BLOCKS = $(shell cd openlane && find * -maxdepth 0 -type d)
2021-11-04 09:16:39 -05:00
# LVS
LVS_MAG_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), lvs-$(block))
$(LVS_MAG_BLOCKS): lvs-% : ./mag/%.mag ./verilog/gl/%.v
@echo "The lvs-* targets have been renamed to lvs-mag-*"
@exit 1
LVS_MAG_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), lvs-mag-$(block))
$(LVS_MAG_BLOCKS): lvs-mag-% : ./mag/%.mag ./verilog/gl/%.v
@echo "Warning: the lvs-mag-* recipes may be out-of-date and are not officially supported."
2021-11-04 09:16:39 -05:00
echo "Extracting $*"
# Clear result directories
rm -rf ./mag/tmp
2021-11-04 09:16:39 -05:00
mkdir -p ./mag/tmp
rm -rf ./spi/lvs/tmp
mkdir -p ./spi/lvs/tmp
2021-11-04 09:16:39 -05:00
echo "addpath $(CARAVEL_ROOT)/mag/hexdigits;\
2021-12-14 06:29:42 -06:00
addpath $(CARAVEL_ROOT)/mag/primitives;\
addpath $(MCW_ROOT)/mag;\
2021-11-04 09:16:39 -05:00
addpath $(CARAVEL_ROOT)/subcells/simple_por/mag;\
addpath \$$PDKPATH/libs.ref/sky130_ml_xx_hd/mag;\
load $* -dereference;\
select top cell;\
foreach cell [cellname list children] {\
load \$$cell -dereference;\
property LEFview TRUE;\
};\
load $* -dereference;\
select top cell;\
extract no all;\
extract do local;\
extract unique;\
extract;\
ext2spice lvs;\
ext2spice $*.ext;\
feedback save extract_$*.log;\
exit;" > ./mag/extract_$*.tcl
cd mag && \
export MAGTYPE=maglef; \
magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull extract_$*.tcl < /dev/null
2021-11-04 09:16:39 -05:00
mv ./mag/$*.spice ./spi/lvs
rm ./mag/*.ext
mv -f ./mag/extract_$*.tcl ./mag/tmp
mv -f ./mag/extract_$*.log ./mag/tmp
####
sh $(CARAVEL_ROOT)/spi/lvs/run_lvs.sh ./spi/lvs/$*.spice ./verilog/gl/$*.v $*
@echo ""
python3 $(CARAVEL_ROOT)/scripts/count_lvs.py -f ./verilog/gl/$*.v_comp.json | tee ./spi/lvs/tmp/$*.lvs.summary.log
mv -f ./verilog/gl/*.out ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.json ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.log ./spi/lvs/tmp 2> /dev/null || true
@echo ""
@echo "LVS: ./spi/lvs/$*.spice vs. ./verilog/gl/$*.v"
@echo "Comparison result: ./spi/lvs/tmp/$*.v_comp.out"
@awk '/^NET mismatches/,0' ./spi/lvs/tmp/$*.v_comp.out
LVS_GDS_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), lvs-gds-$(block))
2021-11-04 09:16:39 -05:00
$(LVS_GDS_BLOCKS): lvs-gds-% : ./gds/%.gds ./verilog/gl/%.v
@echo "Warning: the lvs-gds-* recipes may be out-of-date and are not officially supported."
2021-11-04 09:16:39 -05:00
echo "Extracting $*"
# Clear result directories
rm -rf ./gds/tmp
2021-11-04 09:16:39 -05:00
mkdir -p ./gds/tmp
rm -rf ./spi/lvs/tmp
mkdir -p ./spi/lvs/tmp
echo " gds flatglob \"*_example_*\";\
gds flatten true;\
gds read ./$*.gds;\
2021-11-04 09:16:39 -05:00
load $* -dereference;\
select top cell;\
extract no all;\
extract do local;\
Caravan redesign (#321) * Fixed caravan top level power routing and updated views for mag, gds and lef * caravan(rtl): updates ~ typos fix - remove unused pin in chip_io_alt + add caravan_power_routing verilog * Apply automatic changes to Manifest and README.rst * ~ update caravan openlane configs to add extra cell references ~ correct placment and cell names of some macro in caravan interactive script * reharden: caravan + add non functional blocks + add an initial iteration of caravan * Apply automatic changes to Manifest and README.rst * Revert "Fixed caravan top level power routing and updated views for mag, gds and lef" This reverts commit 70628f748af35aaeae06829b05b2c28a49648fc2. * fixed caravan top level power routing * reharden: caravan based on new power routing ~ guard rtl chip_io power pins in the power macro guard * Apply automatic changes to Manifest and README.rst * fixed caravan top level power routing * rehadren: caravan + add caravan signal routing to openlane run ~ change rtl to guard power and analog against routing by openlane by ifndef TOP_ROUTING ~ add pr bounadry for caravan signal routing to fix origin issues * Apply automatic changes to Manifest and README.rst * fix power connection in buffering block and regenerate gl * Apply automatic changes to Manifest and README.rst * updated views for caravan * Added extract unique to lvs-gds-cell target. (#313) * This fixes errors in the top level RTL of caravan that failed to hook up the buffers through the SoC correctly. * Apply automatic changes to Manifest and README.rst * reharden: caravan ~ rtl updated * fixed caravan mag top level * updated views for caravan + signoff * fixed top level cell name * fix syntax error related to signal initialization place in caravan (#319) * fix syntax error related to signal initialization place in caravan- fixed in caravel in another commit * Apply automatic changes to Manifest and README.rst Co-authored-by: M0stafaRady <M0stafaRady@users.noreply.github.com> * Apply automatic changes to Manifest and README.rst Co-authored-by: Marwan Abbas <marwaneltoukhy@aucegypt.edu> Co-authored-by: kareem <kareem.farid@efabless.com> Co-authored-by: kareefardi <kareefardi@users.noreply.github.com> Co-authored-by: Mitch Bailey <d-m-bailey@users.noreply.github.com> Co-authored-by: Tim Edwards <tim@opencircuitdesign.com> Co-authored-by: RTimothyEdwards <RTimothyEdwards@users.noreply.github.com> Co-authored-by: Marwan Abbas <67271180+marwaneltoukhy@users.noreply.github.com> Co-authored-by: M0stafaRady <107422726+M0stafaRady@users.noreply.github.com> Co-authored-by: M0stafaRady <M0stafaRady@users.noreply.github.com> Co-authored-by: jeffdi <jeffdi@users.noreply.github.com>
2022-10-21 09:37:41 -05:00
extract unique;\
2021-11-04 09:16:39 -05:00
extract;\
ext2spice lvs;\
ext2spice $*.ext;\
feedback save extract_$*.log;\
exit;" > ./gds/extract_$*.tcl
cd gds && \
magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull extract_$*.tcl < /dev/null
2021-11-04 09:16:39 -05:00
mv ./gds/$*.spice ./spi/lvs
rm ./gds/*.ext
mv -f ./gds/extract_$*.tcl ./gds/tmp
mv -f ./gds/extract_$*.log ./gds/tmp
####
MAGIC_EXT_USE_GDS=1 sh $(CARAVEL_ROOT)/spi/lvs/run_lvs.sh ./spi/lvs/$*.spice ./verilog/gl/$*.v $*
@echo ""
python3 $(CARAVEL_ROOT)/scripts/count_lvs.py -f ./verilog/gl/$*.v_comp.json | tee ./spi/lvs/tmp/$*.lvs.summary.log
mv -f ./verilog/gl/*.out ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.json ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.log ./spi/lvs/tmp 2> /dev/null || true
@echo ""
@echo "LVS: ./spi/lvs/$*.spice vs. ./verilog/gl/$*.v"
@echo "Comparison result: ./spi/lvs/tmp/$*.v_comp.out"
@awk '/^NET mismatches/,0' ./spi/lvs/tmp/$*.v_comp.out
# connect-by-label is enabled here!
LVS_MAGLEF_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), lvs-maglef-$(block))
2021-11-04 09:16:39 -05:00
$(LVS_MAGLEF_BLOCKS): lvs-maglef-% : ./mag/%.mag ./verilog/gl/%.v
@echo "Warning: the lvs-maglef-* recipes may be out-of-date and are not officially supported."
2021-11-04 09:16:39 -05:00
echo "Extracting $*"
mkdir -p ./maglef/tmp
echo "load $* -dereference;\
select top cell;\
foreach cell [cellname list children] {\
load \$$cell -dereference;\
property LEFview TRUE;\
};\
load $* -dereference;\
select top cell;\
extract no all;\
extract do local;\
extract;\
ext2spice lvs;\
ext2spice $*.ext;\
feedback save extract_$*.log;\
exit;" > ./mag/extract_$*.tcl
cd mag && export MAGTYPE=maglef; magic -noc -dnull extract_$*.tcl < /dev/null
mv ./mag/$*.spice ./spi/lvs
rm ./maglef/*.ext
mv -f ./mag/extract_$*.tcl ./maglef/tmp
mv -f ./mag/extract_$*.log ./maglef/tmp
####
mkdir -p ./spi/lvs/tmp
sh $(CARAVEL_ROOT)/spi/lvs/run_lvs.sh ./spi/lvs/$*.spice ./verilog/gl/$*.v $*
@echo ""
python3 $(CARAVEL_ROOT)/scripts/count_lvs.py -f ./verilog/gl/$*.v_comp.json | tee ./spi/lvs/tmp/$*.maglef.lvs.summary.log
mv -f ./verilog/gl/*.out ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.json ./spi/lvs/tmp 2> /dev/null || true
mv -f ./verilog/gl/*.log ./spi/lvs/tmp 2> /dev/null || true
@echo ""
@echo "LVS: ./spi/lvs/$*.spice vs. ./verilog/gl/$*.v"
@echo "Comparison result: ./spi/lvs/tmp/$*.v_comp.out"
@awk '/^NET mismatches/,0' ./spi/lvs/tmp/$*.v_comp.out
# DRC
DRC_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), drc-$(block))
2021-11-04 09:16:39 -05:00
$(DRC_BLOCKS): drc-% : ./gds/%.gds
echo "Running DRC on $*"
mkdir -p ./gds/tmp
cd gds && export DESIGN_IN_DRC=$* && export MAGTYPE=mag; magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull $(CARAVEL_ROOT)/gds/drc_on_gds.tcl < /dev/null
2021-11-04 09:16:39 -05:00
@echo "DRC result: ./gds/tmp/$*.drc"
# Antenna
ANTENNA_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), antenna-$(block))
2021-11-04 09:16:39 -05:00
$(ANTENNA_BLOCKS): antenna-% : ./gds/%.gds
echo "Running Antenna Checks on $*"
mkdir -p ./gds/tmp
cd gds && export DESIGN_IN_ANTENNA=$* && export MAGTYPE=mag; magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull $(CARAVEL_ROOT)/gds/antenna_on_gds.tcl < /dev/null 2>&1 | tee ./tmp/$*.antenna
2021-11-04 09:16:39 -05:00
mv -f ./gds/*.ext ./gds/tmp/
@echo "Antenna result: ./gds/tmp/$*.antenna"
# MAG2GDS
MAG_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), mag2gds-$(block))
2021-11-04 09:16:39 -05:00
$(MAG_BLOCKS): mag2gds-% : ./mag/%.mag uncompress
echo "Converting mag file $* to GDS..."
echo "addpath $(CARAVEL_ROOT)/mag/hexdigits;\
addpath ${PDKPATH}/libs.ref/sky130_ml_xx_hd/mag;\
addpath $(CARAVEL_ROOT)/mag/primitives;\
2021-11-04 09:16:39 -05:00
drc off;\
gds rescale false;\
load $* -dereference;\
select top cell;\
expand;\
gds write $*.gds;\
exit;" > ./mag/mag2gds_$*.tcl
cd ./mag && magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull mag2gds_$*.tcl < /dev/null
2021-11-04 09:16:39 -05:00
rm ./mag/mag2gds_$*.tcl
mv -f ./mag/$*.gds ./gds/
# MAG2LEF
MAG_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), mag2lef-$(block))
$(MAG_BLOCKS): mag2lef-% : ./mag/%.mag uncompress
echo "Converting mag file $* to LEF..."
echo "addpath $(CARAVEL_ROOT)/mag/hexdigits;\
addpath ${PDKPATH}/libs.ref/sky130_ml_xx_hd/mag;\
addpath $(CARAVEL_ROOT)/mag/primitives;\
drc off;\
load $*;\
lef write $*.lef;\
exit;" > ./mag/mag2lef_$*.tcl
cd ./mag && magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull mag2lef_$*.tcl < /dev/null
rm ./mag/mag2lef_$*.tcl
mv -f ./mag/$*.lef ./lef/
2021-12-02 13:20:40 -06:00
# MAG2DEF
# BLOCKS = $(shell cd openlane && find * -maxdepth 0 -type d)
# MAG_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), mag2lef-$(block))
2021-12-02 13:20:40 -06:00
# $(MAG_BLOCKS): mag2lef-% : ./mag/%.mag uncompress
# echo "Converting mag file $* to DEF..."
# echo "addpath $(CARAVEL_ROOT)/mag/hexdigits;\
# addpath ${PDKPATH}/libs.ref/sky130_ml_xx_hd/mag;\
# addpath $(CARAVEL_ROOT)/mag/primitives;\
# drc off;\
# load $*;\
# lef write $*.lef;\
# exit;" > ./mag/mag2lef_$*.tcl
# cd ./mag && magic -rcfile ${PDK_ROOT}/$(PDK)/libs.tech/magic/$(PDK).magicrc -noc -dnull mag2lef_$*.tcl < /dev/null
2021-12-02 13:20:40 -06:00
# rm ./mag/mag2lef_$*.tcl
# mv -f ./mag/$*.lef ./lef/
2021-11-04 09:16:39 -05:00
.PHONY: help
help:
@$(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 '^$@$$'
# RCX Extraction
RCX_BLOCKS = $(foreach block, $(OPENLANE_BLOCKS), rcx-$(block))
2021-12-14 06:29:42 -06:00
OPENLANE_IMAGE_NAME=efabless/openlane:2021.11.25_01.26.14
$(RCX_BLOCKS): rcx-% : ./def/%.def
2021-11-04 09:16:39 -05:00
echo "Running RC Extraction on $*"
mkdir -p ./def/tmp
# merge techlef and standard cell lef files
python3 $(OPENLANE_ROOT)/scripts/mergeLef.py -i $(PDK_ROOT)/$(PDK)/libs.ref/$(STD_CELL_LIBRARY)/techlef/$(STD_CELL_LIBRARY).tlef $(PDK_ROOT)/$(PDK)/libs.ref/$(STD_CELL_LIBRARY)/lef/*.lef $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/techlef/$(SPECIAL_VOLTAGE_LIBRARY).tlef $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/lef/*.lef $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lef/*.lef -o ./def/tmp/merged.lef
2021-11-04 09:16:39 -05:00
echo "\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(STD_CELL_LIBRARY)/lib/$(STD_CELL_LIBRARY)__tt_025C_1v80.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/lib/$(SPECIAL_VOLTAGE_LIBRARY)__tt_025C_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/lib/$(SPECIAL_VOLTAGE_LIBRARY)__tt_025C_3v30_lv1v80.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/sky130_sram_macros/lib/sky130_sram_2kbyte_1rw1r_32x512_8_TT_1p8V_25C.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_gpiov2_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_hvc_wpad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_lvc_wpad_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_lvc_wpad_tt_100C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_power_lvc_wpad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_xres4v2_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__gpiov2_pad_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vccd_lvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vdda_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssa_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssd_lvc_clamped3_pad_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vccd_lvc_clamped3_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssd_lvc_clamped_pad_tt_025C_1v80_3v30.lib;\
2021-11-04 09:16:39 -05:00
set std_cell_lef ./def/tmp/merged.lef;\
set sram_lef $(PDK_ROOT)/$(PDK)/libs.ref/sky130_sram_macros/lef/sky130_sram_2kbyte_1rw1r_32x512_8.lef;\
2021-11-04 09:16:39 -05:00
if {[catch {read_lef \$$std_cell_lef} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
};\
2021-12-14 06:29:42 -06:00
if {[catch {read_lef \$$sram_lef} errmsg]} {\
2021-11-04 09:16:39 -05:00
puts stderr \$$errmsg;\
exit 1;\
};\
2021-12-14 06:29:42 -06:00
foreach lef_file [glob ./lef/*.lef] {\
if {[catch {read_lef \$$lef_file} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
2021-12-14 06:29:42 -06:00
}\
};\
2021-11-04 09:16:39 -05:00
if {[catch {read_def -order_wires ./def/$*.def} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
};\
2021-12-14 06:29:42 -06:00
read_sdc -echo ./sdc/$*.sdc;\
2021-11-04 09:16:39 -05:00
set_propagated_clock [all_clocks];\
set rc_values \"mcon 9.249146E-3,via 4.5E-3,via2 3.368786E-3,via3 0.376635E-3,via4 0.00580E-3\";\
2021-12-14 06:29:42 -06:00
set l_rc \"li1 1.499e-04 7.176e-02,met1 1.449e-04 8.929e-04,met2 1.331e-04 8.929e-04,met3 1.464e-04 1.567e-04,met4 1.297e-04 1.567e-04,met5 1.501e-04 1.781e-05\";\
set layers_rc [split \$$l_rc ","];\
foreach layer_rc \$$layers_rc {\
set layer_name [lindex \$$layer_rc 0];\
set capacitance [lindex \$$layer_rc 1];\
set resistance [lindex \$$layer_rc 2];\
set_layer_rc -layer \$$layer_name -capacitance \$$capacitance -resistance \$$resistance;\
};\
2021-11-04 09:16:39 -05:00
set vias_rc [split \$$rc_values ","];\
foreach via_rc \$$vias_rc {\
set layer_name [lindex \$$via_rc 0];\
set resistance [lindex \$$via_rc 1];\
set_layer_rc -via \$$layer_name -resistance \$$resistance;\
};\
set_wire_rc -signal -layer met2;\
set_wire_rc -clock -layer met5;\
define_process_corner -ext_model_index 0 X;\
extract_parasitics -ext_model_file ${PDK_ROOT}/$(PDK)/libs.tech/openlane/rcx_rules.info -corner_cnt 1 -max_res 50 -coupling_threshold 0.1 -cc_model 10 -context_depth 5;\
2021-11-28 07:06:18 -06:00
write_spef ./spef/$*.spef" > ./def/tmp/rcx_$*.tcl
2021-11-04 09:16:39 -05:00
## Generate Spef file
2021-12-14 06:29:42 -06:00
docker run -it -v $(OPENLANE_ROOT):/openlane -v $(PDK_ROOT):$(PDK_ROOT) -v $(PWD):/caravel -e PDK_ROOT=$(PDK_ROOT) -u $(shell id -u $(USER)):$(shell id -g $(USER)) $(OPENLANE_IMAGE_NAME) \
2021-11-28 07:06:18 -06:00
sh -c " cd /caravel; openroad -exit ./def/tmp/rcx_$*.tcl |& tee ./def/tmp/rcx_$*.log"
2021-11-04 09:16:39 -05:00
## Run OpenSTA
echo "\
set std_cell_lef ./def/tmp/merged.lef;\
set sram_lef $(PDK_ROOT)/$(PDK)/libs.ref/sky130_sram_macros/lef/sky130_sram_2kbyte_1rw1r_32x512_8.lef;\
2021-11-04 09:16:39 -05:00
if {[catch {read_lef \$$std_cell_lef} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
};\
2021-12-14 06:29:42 -06:00
if {[catch {read_lef \$$sram_lef} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
};\
2021-11-04 09:16:39 -05:00
foreach lef_file [glob ./lef/*.lef] {\
if {[catch {read_lef \$$lef_file} errmsg]} {\
puts stderr \$$errmsg;\
exit 1;\
}\
};\
set_cmd_units -time ns -capacitance pF -current mA -voltage V -resistance kOhm -distance um;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(STD_CELL_LIBRARY)/lib/$(STD_CELL_LIBRARY)__tt_025C_1v80.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/lib/$(SPECIAL_VOLTAGE_LIBRARY)__tt_025C_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(SPECIAL_VOLTAGE_LIBRARY)/lib/sky130_fd_sc_hvl__tt_025C_3v30_lv1v80.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/sky130_sram_macros/lib/sky130_sram_2kbyte_1rw1r_32x512_8_TT_1p8V_25C.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_gpiov2_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_hvc_wpad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_lvc_wpad_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_ground_lvc_wpad_tt_100C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_power_lvc_wpad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_fd_io__top_xres4v2_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__gpiov2_pad_tt_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vccd_lvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vdda_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssa_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssd_lvc_clamped3_pad_tt_025C_1v80_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vccd_lvc_clamped3_pad_tt_025C_1v80_3v30_3v30.lib;\
read_liberty $(PDK_ROOT)/$(PDK)/libs.ref/$(IO_LIBRARY)/lib/sky130_ef_io__vssd_lvc_clamped_pad_tt_025C_1v80_3v30.lib;\
2021-12-14 06:29:42 -06:00
read_verilog ./verilog/gl/$*.v;\
link_design $*;\
2021-11-28 07:06:18 -06:00
read_spef ./spef/$*.spef;\
2021-12-02 13:20:40 -06:00
read_sdc -echo ./sdc/$*.sdc;\
2021-12-14 06:29:42 -06:00
write_sdf ./sdf/$*.sdf -divider . -include_typ;\
report_checks -fields {capacitance slew input_pins nets fanout} -path_delay min_max -group_count 5;\
2021-11-04 09:16:39 -05:00
report_check_types -max_slew -max_capacitance -max_fanout -violators;\
2021-11-28 07:06:18 -06:00
report_checks -to [all_outputs] -group_count 1000;\
2021-12-14 06:29:42 -06:00
" > ./def/tmp/sta_$*.tcl
docker run -it -v $(OPENLANE_ROOT):/openlane -v $(PDK_ROOT):$(PDK_ROOT) -v $(PWD):/caravel -e PDK_ROOT=$(PDK_ROOT) -u $(shell id -u $(USER)):$(shell id -g $(USER)) $(OPENLANE_IMAGE_NAME) \
sh -c "cd /caravel; openroad -exit ./def/tmp/sta_$*.tcl |& tee ./def/tmp/sta_$*.log"
2021-11-04 09:16:39 -05:00
2021-12-02 13:20:40 -06:00
2025-02-12 21:18:13 -06:00
.PHONY: caravel_timing_typ caravel_timing_typ caravel_timing_slow
caravel_timing_typ:
@echo "The caravel_timing_typ: target has been removed."
@echo "Please use the caravel-sta target in the caravel_user_project/Makefile"
@exit 1
caravel_timing_slow:
@echo "The caravel_timing_slow: target has been removed."
@echo "Please use the caravel-sta target in the caravel_user_project/Makefile"
@exit 1
caravel_timing_fast:
@echo "The caravel_timing_fast: target has been removed."
@echo "Please use the caravel-sta target in the caravel_user_project/Makefile"
@exit 1
2021-12-02 13:20:40 -06:00
2021-11-04 09:16:39 -05:00
###########################################################################
.PHONY: generate_fill
generate_fill: check-env check-uid check-project uncompress
@echo "Running generate_fill in the foreground..."
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __generate_fill
@echo "Generate fill completed." 2>&1 | tee -a ./signoff/build/generate_fill.out
__generate_fill:
@mkdir -p ./signoff/build
@cp -r $(CARAVEL_ROOT)/mag/.magicrc $(shell pwd)/mag
2023-06-09 01:25:59 -05:00
python3 $(CARAVEL_ROOT)/scripts/generate_fill.py $(USER_ID) $(PROJECT) $(shell pwd) -dist 2>&1 | tee ./signoff/build/generate_fill.out
2023-06-08 09:37:32 -05:00
#python3 $(CARAVEL_ROOT)/scripts/generate_fill.py $(USER_ID) $(PROJECT) $(shell pwd) -keep 2>&1 | tee ./signoff/build/generate_fill.out
2021-11-04 09:16:39 -05:00
.PHONY: final
final: check-env check-uid check-project uncompress uncompress-caravel
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __final
@echo "Final build completed." 2>&1 | tee -a ./signoff/build/final_build.out
__final:
python3 $(CARAVEL_ROOT)/scripts/compositor.py $(USER_ID) $(PROJECT) $(shell pwd) $(CARAVEL_ROOT)/mag $(shell pwd)/gds -keep
#mv $(CARAVEL_ROOT)/mag/caravel_$(USER_ID).mag ./mag/
@rm -rf ./mag/tmp
.PHONY: set_user_id
set_user_id: check-env check-uid
2021-11-04 09:16:39 -05:00
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __set_user_id
@echo "Set user ID completed." 2>&1 | tee -a ./signoff/build/set_user_id.out
__set_user_id:
mkdir -p ./signoff/build
# Update info.yaml
# sed -r "s/^(\s*project_id\s*:\s*).*/\1${USER_ID}/" -i info.yaml
cp $(CARAVEL_ROOT)/mag/user_id_programming.mag ./mag/user_id_programming.mag
cp $(CARAVEL_ROOT)/mag/user_id_textblock.mag ./mag/user_id_textblock.mag
2023-04-20 19:12:51 -05:00
cp $(CARAVEL_ROOT)/verilog/rtl/caravel_core.v ./verilog/rtl/caravel_core.v
cp $(CARAVEL_ROOT)/verilog/gl/user_id_programming.v ./verilog/gl/user_id_programming.v
2021-11-04 09:16:39 -05:00
python3 $(CARAVEL_ROOT)/scripts/set_user_id.py $(USER_ID) $(shell pwd) 2>&1 | tee ./signoff/build/set_user_id.out
2021-11-29 18:04:43 -06:00
.PHONY: gpio_defaults
gpio_defaults: check-env
2021-11-29 18:04:43 -06:00
$(MAKE) -f $(CARAVEL_ROOT)/Makefile __gpio_defaults
@echo "GPIO defaults completed." 2>&1 | tee -a ./signoff/build/__gpio_defaults.out
__gpio_defaults:
mkdir -p ./signoff/build
mkdir -p ./verilog/gl
2021-11-29 18:04:43 -06:00
python3 $(CARAVEL_ROOT)/scripts/gen_gpio_defaults.py $(shell pwd) 2>&1 | tee ./signoff/build/gpio_defaults.out
2021-11-04 09:16:39 -05:00
.PHONY: update_caravel
update_caravel:
2025-02-10 10:42:08 -06:00
@echo "The update_caravel target has been removed."
@exit 1
2021-11-04 09:16:39 -05:00
2021-11-24 11:23:58 -06:00
###########################################################################
# Install Mgmt Core Wrapper
.PHONY: install_mcw
install_mcw:
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
if [ -d "$(MCW_ROOT)" ]; then \
2023-09-11 13:01:40 -05:00
echo "Deleting existing $(MCW_ROOT)" && \
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
rm -rf $(MCW_ROOT) && sleep 2;\
fi
2021-11-24 11:23:58 -06:00
ifeq ($(SUBMODULE),1)
@echo "Installing $(MCW_NAME) as a submodule.."
# Convert MCW_ROOT to relative path because .gitmodules doesn't accept '/'
$(eval MCW_PATH := $(shell realpath --relative-to=$(shell pwd) $(MCW_ROOT)))
@if [ ! -d $(MCW_ROOT) ]; then git submodule add --name $(MCW_NAME) $(MCW_REPO) $(MCW_PATH); fi
@git submodule update --init
2022-02-25 19:55:26 -06:00
@cd $(MCW_ROOT); git checkout $(MCW_TAG)
2021-11-24 11:23:58 -06:00
$(MAKE) simlink
else
@echo "Installing $(MCW_NAME).."
2022-02-25 19:55:26 -06:00
@git clone -b $(MCW_TAG) $(MCW_REPO) $(MCW_ROOT) --depth=1
2021-11-24 11:23:58 -06:00
endif
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
2021-11-24 11:23:58 -06:00
# Update Mgmt Core Wrapper
.PHONY: update_mcw
update_mcw: check-mcw
ifeq ($(SUBMODULE),1)
@git submodule update --init --recursive
cd $(MCW_ROOT) && \
2022-02-25 19:55:26 -06:00
git checkout $(MCW_TAG) && \
2021-11-24 11:23:58 -06:00
git pull
else
cd $(MCW_ROOT)/ && \
2022-02-25 19:55:26 -06:00
git checkout $(MCW_TAG) && \
2021-11-24 11:23:58 -06:00
git pull
endif
# Uninstall Mgmt Core Wrapper
.PHONY: uninstall_mcw
uninstall_mcw:
ifeq ($(SUBMODULE),1)
git config -f .gitmodules --remove-section "submodule.$(MCW_NAME)"
git add .gitmodules
git submodule deinit -f $(MCW_ROOT)
git rm --cached $(MCW_ROOT)
rm -rf .git/modules/$(MCW_NAME)
rm -rf $(MCW_ROOT)
else
rm -rf $(MCW_ROOT)/*
endif
###########################################################################
.PHONY: pdk pdk-with-sram
pdk-with-sram: pdk
pdk: check-env pdk-with-volare
.PHONY: pdk-with-volare
pdk-with-volare: check-env venv/manifest.txt
2023-01-22 04:39:42 -06:00
./venv/bin/volare enable ${OPEN_PDKS_COMMIT}
.PHONY: install-volare
install-volare:
@echo "The install-volare target has been removed."
@echo "To delete and reinstall: make -B venv/manifest.txt"
@exit 1
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
.PHONY: clean-pdk
clean-pdk:
rm -rf $(PDK_ROOT)
2021-11-04 09:16:39 -05:00
.PHONY: skywater-pdk
skywater-pdk:
@echo "The skywater-pdk target has been removed."
@echo "To install the pdk with volare: make pdk-with-volare"
@exit 1
### OPEN_PDKS
.PHONY: open-pdks
open-pdks:
@echo "The open-pdks target has been removed."
@echo "To install the pdk with volare: make pdk-with-volare"
@exit 1
.PHONY: sky130
sky130:
@echo "The sky130 target has been removed."
@echo "To install the pdk with volare: make pdk-with-volare"
@exit 1
.PHONY: gen-sources
gen-sources:
@echo "The gen-sources target has been removed."
@echo "The $(PDK_ROOT)/$(PDK)/SOURCES file is created by volare."
@exit 1
# Make README.rst
README.rst: README.src.rst docs/source/getting-started.rst docs/source/tool-versioning.rst openlane/README.src.rst docs/source/caravel-with-openlane.rst Makefile ./venv/manifest.txt
rm -f README.rst openlane/README.rst && \
./venv/bin/rst_include include README.src.rst - | \
sed \
-e's@\.\/\_static@\/docs\/source\/\_static@g' \
-e's@:doc:`tool-versioning`@`tool-versioning.rst <./docs/source/tool-versioning.rst>`__@g' \
-e's@.. note::@**NOTE:**@g' \
-e's@.. warning::@**WARNING:**@g' \
> README.rst && \
./venv/bin/rst_include include openlane/README.src.rst - | \
sed \
-e's@https://github.com/efabless/caravel/blob/master/verilog@../verilog@g' \
-e's@:ref:`getting-started`@`README.rst <../README.rst>`__@g' \
-e's@https://github.com/efabless/caravel/blob/master/openlane/@./@g' \
-e's@.. note::@**NOTE:**@g' \
-e's@.. warning::@**WARNING:**@g' \
> openlane/README.rst
venv/manifest.txt: ./requirements.txt
$(MAKE) check-python
rm -rf ./venv
$(PYTHON_BIN) -m venv ./venv
./venv/bin/python3 -m pip install --upgrade --no-cache-dir pip
./venv/bin/python3 -m pip install --upgrade --no-cache-dir -r requirements.txt
./venv/bin/python3 -m pip freeze > $@
2021-11-04 09:16:39 -05:00
###########################################################################
.PHONY: manifest
2021-11-04 09:16:39 -05:00
manifest: mag/ maglef/ verilog/rtl/ Makefile
touch manifest && \
find verilog/rtl/* -type f ! -name "caravel_netlists.v" ! -name "user_*.v" ! -name "README" ! -name "defines.v" -exec shasum {} \; > manifest && \
shasum scripts/set_user_id.py scripts/generate_fill.py scripts/compositor.py >> manifest
# since the order of files returned by find is indeterminate, sort the final output by filename
sort -k2,2 -o manifest manifest
2021-11-04 09:16:39 -05:00
# shasum lef/user_project_wrapper_empty.lef >> manifest
# find maglef/*.mag -type f ! -name "user_project_wrapper.mag" -exec shasum {} \; >> manifest && \
# shasum mag/caravel.mag mag/.magicrc >> manifest
.PHONY: master_manifest
2021-11-04 09:16:39 -05:00
master_manifest:
# to get the shasums of compressed files, first create a list of the compressed files
# uncompress them, take the shasums, and then recompress the files
shopt -s nullglob; \
ls verilog/rtl/*.$(ARCHIVE_EXT) verilog/gl/*.$(ARCHIVE_EXT) lef/*.lef.$(ARCHIVE_EXT) def/*.def.$(ARCHIVE_EXT) mag/*.mag.$(ARCHIVE_EXT) \
maglef/*.mag.$(ARCHIVE_EXT) spi/lvs/*.spice.$(ARCHIVE_EXT) gds/*.gds.$(ARCHIVE_EXT) | \
sed 's/\.'$(ARCHIVE_EXT)'\>//g' > manifest.compressed.list && sleep 2
find verilog/rtl -type f -not -name "*.$(ARCHIVE_EXT)" -exec shasum {} \; > master_manifest && \
find verilog/gl -type f -not -name "*.$(ARCHIVE_EXT)" -exec shasum {} \; >> master_manifest && \
2021-11-04 09:16:39 -05:00
shasum scripts/set_user_id.py scripts/generate_fill.py scripts/compositor.py >> master_manifest && \
find lef -name "*.lef" -type f -exec shasum {} \; >> master_manifest && \
find def -name "*.def" -type f -exec shasum {} \; >> master_manifest && \
find mag -name "*.mag" -type f -exec shasum {} \; >> master_manifest && \
find maglef -name "*.mag" -type f -exec shasum {} \; >> master_manifest && \
find spi/lvs -name "*.spice" -type f -exec shasum {} \; >> master_manifest && \
find gds -name "*.gds" -type f -exec shasum {} \; >> master_manifest
# since file compression options may be different, do not uncompress and recompress
for file in $$(cat manifest.compressed.list); do \
echo "$$( $(UNCOMPRESS) -c $$file | shasum | awk '{print $$1}' ) $$file" >> master_manifest; \
done
# since the order of files returned by find is indeterminate, sort the final output by filename
sort -k2,2 -o master_manifest master_manifest
rm -rf manifest.compressed.list
2021-11-04 09:16:39 -05:00
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
.PHONY: check-env
2021-11-04 09:16:39 -05:00
check-env:
ifndef PDK_ROOT
$(error PDK_ROOT is undefined, please export it before running make)
endif
check-uid:
ifndef USER_ID
$(error USER_ID is undefined, please export it before running make set_user_id)
else
@echo USER_ID is set to $(USER_ID)
endif
check-project:
ifndef PROJECT
$(error PROJECT is undefined, please export it before running make generate_fill or make final)
else
@echo PROJECT is set to $(PROJECT)
endif
2021-11-25 11:58:04 -06:00
check-mcw:
@if [ ! -d "$(MCW_ROOT)" ]; then \
echo "MCW Root: "$(MCW_ROOT)" doesn't exists, please export the correct path before running make. "; \
exit 1; \
fi
check-python:
@if ! command -v $(PYTHON_BIN) > /dev/null; then\
echo "Python 3 binary '$(PYTHON_BIN)' not found.";\
exit 1;\
fi
@$(PYTHON_BIN) -c "import sys; assert sys.version_info >= (3, 6), 'Python version less than 3.6'"
@echo "Python >=3.6 found."
- change litex tag to mpw-5c - warn before deleting when rerunning these targets: install_mcw openlane pdk - clone litex with depth=1 and single branch - simplified pdk targets by removing these targets: skywater-timing build-pdk skywater-library - add clean-pdk and clean-openlane - add make prerequisites in pdk (not sure if that's needed) - run openlane docker non interactive - export OPENLANE_IMAGE_NAME when running openlane docker - add check-openlane-env target Squashed commit of the following: commit b7904e08ae649116ae8af5808b5acbf66e300625 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 13:32:36 2022 -0800 typo commit 8507bcf1eef959e3e11ec872fcbcd38681511f42 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:51:42 2022 -0800 undo tag for testing commit 12114e08d2b27f839d6862138df8d533a6868897 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:50:41 2022 -0800 typo commit 1a15d4646a2ea429b403aaa1f51d03404fd5acbf Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:47:26 2022 -0800 fix folder not found check commit addf24a8b67a4c1d7295bc97c4f61201dd265032 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 11:03:31 2022 -0800 remove export path and ls that were for testing commit 91a305f365560524454b6582ab547aaa4b25b697 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:57:39 2022 -0800 typo commit 00c249db5cdd493281574371e0d7fb3d97d039ca Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:50:28 2022 -0800 - use tag for MCW_BRANCH - non phony install_mcw - clone with depth 1 commit ba14b7a6aa6b6d0ec07c3e34728f1e4a7826ba82 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 10:39:59 2022 -0800 the return of non phony commit f5657bbabf98b68c37e6f87c6a6b6c9758180168 Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 05:04:51 2022 -0800 revert commit ids of openpdks, magic and openlane (we are going to set them in caravel_user_project) commit 0fc8c4dacdf213bfc96e3a692c45ab0581fe1ebe Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 24 04:46:37 2022 -0800 gen-source for sky130B commit c875a7b05897a3f2e825d968ee28cca743d0e515 Merge: 801b3dc ff403f5 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:16:25 2022 -0800 Merge remote-tracking branch 'upstream/main' into makefile commit 801b3dc28d7dddb3dd6f4b2938b3fdc5ea6ddc63 Author: kareem <kareem.farid@efabless.com> Date: Wed Feb 23 14:15:25 2022 -0800 also update openlane, magic, openpdks commit id commit 47091c6fba57a7faa4cc726b3eadd472a8a9bcf7 Author: kareem <kareem.farid@efabless.com> Date: Tue Feb 22 13:35:07 2022 -0800 more changes commit 67a49b0aa26fce7197216cf251c981854ef0a39c Author: kareem <kareem.farid@efabless.com> Date: Thu Feb 17 11:56:56 2022 -0800 WIP actual usage of make targets
2022-02-25 12:39:11 -06:00
.PHONY: clean-openlane
clean-openlane:
rm -rf $(OPENLANE_ROOT)