-
Notifications
You must be signed in to change notification settings - Fork 2
/
Makefile.common
105 lines (95 loc) · 3.36 KB
/
Makefile.common
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
## Set common environment variables
SHELL:=/bin/bash
## Directories to install into
export BP_TOOLS_DIR ?= $(TOP)
export BP_TOOLS_PATCH_DIR := $(BP_TOOLS_DIR)/patches
export BP_TOOLS_INSTALL_DIR := $(BP_TOOLS_DIR)/install
export BP_TOOLS_BIN_DIR := $(BP_TOOLS_INSTALL_DIR)/bin
export BP_TOOLS_LIB_DIR := $(BP_TOOLS_INSTALL_DIR)/lib
export BP_TOOLS_INCLUDE_DIR := $(BP_TOOLS_INSTALL_DIR)/include
export BP_TOOLS_SHARE_DIR := $(BP_TOOLS_INSTALL_DIR)/share
export BP_TOOLS_TOUCH_DIR := $(BP_TOOLS_INSTALL_DIR)/touchfiles
ifeq ($(TOP),$(BP_TOOLS_DIR))
export BP_RTL_DIR ?= $(TOP)/../black-parrot
include $(BP_RTL_DIR)/Makefile.common
#export BP_TOOLS_DIR ?= $(TOP)/../black-parrot-tools
#include $(BP_TOOLS_DIR)/Makefile.common
export BP_SDK_DIR ?= $(TOP)/../black-parrot-sdk
include $(BP_SDK_DIR)/Makefile.common
## Setup CAD tools
# If the machine you are working on is bsg_cadenv compliant, then you do not
# need to setup the cad tools, simply put bsg_cadenv in the same root dir.
BSG_CADENV_DIR ?= $(BP_SDK_DIR)/bsg_cadenv
bsg_cadenv: $(BSG_CADENV_DIR)
$(BSG_CADENV_DIR):
git clone git@github.com:bespoke-silicon-group/bsg_cadenv.git $@
-include $(BSG_CADENV_DIR)/cadenv.mk
endif
define patch_if_new
$(eval $@_src_root = $(1))
$(eval $@_patch_root = $(2))
$(eval $@_patch_list = $(wildcard $($@_patch_root)/*.patch))
$(eval $@_patch_is_top = $(findstring patches,$(lastword $(subst /, ,$(dir $($@_patch_root))))))
for p in ${$@_patch_list}; \
do \
echo "Checking if patch is applicable"; \
cd ${$@_src_root}; $(CHECK_PATCH) $$p && continue; \
echo "Patch is unapplied..."; \
if [ $@_patch_is_top ]; then \
echo "Applying patch to sub-directory ${$@_src_root}; \
cd ${$@_src_root}; echo $$p; git am $$p; \
else \
echo "Applying patch to top-level ${$@_src_root}; \
cd ${$@_src_root}; echo $$p; git apply $$p; \
fi \
done
endef
## Override CAD tool paths if needed
# Need to be exported for some CAD tools
export VCS_HOME ?=
export VCS ?= vcs
export URG ?= urg
export VERILATOR ?= verilator
export DC_SHELL ?= dc_shell
export VIVADO ?= vivado
export _DVE ?= dve
export GTKWAVE ?= gtkwave
export YOSYS ?= yosys
## Specify license path if needed
export LM_LICENSE_FILE ?=
## Set variables needed for building tools
export GCC ?= gcc
export CMAKE ?= $(if $(shell which cmake3),cmake3,cmake)
export PYTHON ?= $(if $(shell which python3),python3,python)
export XXD ?= xxd
export CURL ?= curl
export GIT ?= git
export FIND ?= find
export CP ?= cp
export MKDIR ?= mkdir -p
export MV ?= mv
export PATCH ?= git apply --ignore-whitespace --ignore-space-change
export CHECK_PATCH ?= $(PATCH) --check --reverse
export TAR ?= tar
export WGET ?= wget
export CAT ?= cat
export SYMLINK ?= ln -nsf
export WCOUNT ?= wc -l
export ECHO ?= echo
export DIFF ?= diff
export TAIL ?= tail
export GREP ?= grep
export SED ?= sed
export TEST ?= test
export CD ?= cd
export TEE ?= tee
export RM ?= rm
export RMRF ?= rm -rf
export PRINTF ?= printf
export ENVSUBST ?= envsubst
export STTY ?= stty
export SURELOG ?= surelog
export DROMAJO ?= dromajo
export EXIT ?= exit
export TOUCH ?= touch
export PATH := $(BP_TOOLS_INSTALL_DIR)/bin:$(PATH)