-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
175 lines (142 loc) · 6.39 KB
/
Makefile
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
SIM_ROOT ?= $(shell readlink -f "$(CURDIR)")
CLEAN=$(findstring clean,$(MAKECMDGOALS))
STANDALONE=$(SIM_ROOT)/lib/sniper
PIN_FRONTEND=$(SIM_ROOT)/frontend/pin-frontend/obj-intel64/pin_frontend
LIB_CARBON=$(SIM_ROOT)/lib/libcarbon_sim.a
LIB_PIN_SIM=$(SIM_ROOT)/pin/../lib/pin_sim.so
LIB_FOLLOW=$(SIM_ROOT)/pin/../lib/follow_execv.so
LIB_SIFT=$(SIM_ROOT)/sift/libsift.a
LIB_DECODER=$(SIM_ROOT)/decoder_lib/libdecoder.a
SIM_TARGETS=$(LIB_DECODER) $(LIB_CARBON) $(LIB_SIFT) $(LIB_PIN_SIM) $(LIB_FOLLOW) $(STANDALONE) $(PIN_FRONTEND)
.PHONY: all message dependencies compile_simulator configscripts package_deps pin python linux builddir showdebugstatus distclean mbuild xed_install xed
# Remake LIB_CARBON on each make invocation, as only its Makefile knows if it needs to be rebuilt
.PHONY: $(LIB_CARBON)
all: message dependencies $(SIM_TARGETS) configscripts
dependencies: package_deps xed pin python mcpat linux builddir showdebugstatus
$(SIM_TARGETS): dependencies
include common/Makefile.common
message:
ifeq ($(BUILD_RISCV),0)
@echo Building for x86 \($(SNIPER_TARGET_ARCH)\)
else
@echo Building for x86 \($(SNIPER_TARGET_ARCH)\) and RISCV
endif
$(STANDALONE): $(LIB_CARBON) $(LIB_SIFT) $(LIB_DECODER)
@$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/standalone
$(PIN_FRONTEND):
@$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/frontend/pin-frontend
# Disable original frontend
#$(LIB_PIN_SIM): $(LIB_CARBON) $(LIB_SIFT) $(LIB_DECODER)
# @$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/pin $@
#$(LIB_FOLLOW):
# @$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/pin $@
$(LIB_CARBON):
@$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/common
$(LIB_SIFT): $(LIB_CARBON)
@$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/sift
$(LIB_DECODER): $(LIB_CARBON)
@$(MAKE) $(MAKE_QUIET) -C $(SIM_ROOT)/decoder_lib
MBUILD_GITID=1651029643b2adf139a8d283db51b42c3c884513
MBUILD_INSTALL=$(SIM_ROOT)/mbuild
MBUILD_INSTALL_DEP=$(MBUILD_INSTALL)/mbuild/arar.py
mbuild: $(MBUILD_INSTALL_DEP)
$(MBUILD_INSTALL_DEP):
$(_MSG) '[DOWNLO] mbuild'
$(_CMD) git clone --quiet https://github.com/intelxed/mbuild.git $(MBUILD_INSTALL)
$(_CMD) git -C $(MBUILD_INSTALL) reset --quiet --hard $(MBUILD_GITID)
XED_GITID=2be2d282939f6eb84e03e1fed9ba82f32c8bac2d
XED_INSTALL_DEP=$(XED_INSTALL)/src/common/xed-init.c
xed_install: $(XED_INSTALL_DEP)
$(XED_INSTALL_DEP):
$(_MSG) '[DOWNLO] xed'
$(_CMD) git clone --quiet https://github.com/intelxed/xed.git $(XED_INSTALL)
$(_CMD) git -C $(XED_INSTALL) reset --quiet --hard $(XED_GITID)
XED_DEP=$(XED_HOME)/include/xed/xed-iclass-enum.h
xed: mbuild xed_install $(XED_DEP)
$(XED_DEP): $(XED_INSTALL_DEP)
$(_MSG) '[INSTAL] xed'
$(_CMD) cd $(XED_INSTALL) ; ./mfile.py --silent --extra-flags=-fPIC --shared --install-dir $(XED_HOME) install
ifneq ($(NO_PIN_CHECK),1)
PIN_REV_MINIMUM=71313
pin: $(PIN_HOME)/intel64/bin/pinbin $(PIN_HOME)/source/tools/Config/makefile.config package_deps
@if [ "$$(tools/pinversion.py $(PIN_HOME) | cut -d. -f3)" -lt "$(PIN_REV_MINIMUM)" ]; then echo; echo "Found Pin version $$(tools/pinversion.py $(PIN_HOME)) in $(PIN_HOME)"; echo "but at least revision $(PIN_REV_MINIMUM) is required."; echo; false; fi
$(PIN_HOME)/source/tools/Config/makefile.config:
@echo
@echo "Old Pin version found in $(PIN_HOME), Sniper requires Pin version $(PIN_REV_MINIMUM) or newer."
@echo
@false
$(PIN_HOME)/intel64/bin/pinbin:
@echo
@echo "Cannot find Pin in $(PIN_HOME). Please download and extract Pin version $(PIN_REV_MINIMUM)"
@echo "from http://www.pintool.org/downloads.html into $(PIN_HOME), or set the PIN_HOME environment variable."
@echo
@false
endif
ifneq ($(NO_PYTHON_DOWNLOAD),1)
PYTHON_DEP=python_kit/$(SNIPER_TARGET_ARCH)/lib/python2.7/lib-dynload/_sqlite3.so
python: $(PYTHON_DEP)
$(PYTHON_DEP):
$(_MSG) '[DOWNLO] Python $(SNIPER_TARGET_ARCH)'
$(_CMD) mkdir -p python_kit/$(SNIPER_TARGET_ARCH)
$(_CMD) wget -O - --no-verbose --quiet "http://snipersim.org/packages/sniper-python27-$(SNIPER_TARGET_ARCH).tgz" | tar xz --strip-components 1 -C python_kit/$(SNIPER_TARGET_ARCH)
endif
ifneq ($(NO_MCPAT_DOWNLOAD),1)
mcpat: mcpat/mcpat-1.0
mcpat/mcpat-1.0:
$(_MSG) '[DOWNLO] McPAT'
$(_CMD) mkdir -p mcpat
$(_CMD) wget -O - --no-verbose --quiet "http://snipersim.org/packages/mcpat-1.0.tgz" | tar xz -C mcpat
endif
linux: include/linux/perf_event.h
include/linux/perf_event.h:
$(_MSG) '[INSTAL] perf_event.h'
$(_CMD) if [ -e /usr/include/linux/perf_event.h ]; then cp /usr/include/linux/perf_event.h include/linux/perf_event.h; else cp include/linux/perf_event_2.6.32.h include/linux/perf_event.h; fi
builddir: lib
lib:
@mkdir -p $(SIM_ROOT)/lib
showdebugstatus:
ifneq ($(DEBUG),)
@echo Using flags: $(OPT_CFLAGS)
endif
configscripts: dependencies
@mkdir -p config
@> config/sniper.py
@echo '# This file is auto-generated, changes made to it will be lost. Please edit Makefile instead.' >> config/sniper.py
@echo "target=\"$(SNIPER_TARGET_ARCH)\"" >> config/sniper.py
@./tools/makerelativepath.py pin_home "$(SIM_ROOT)" "$(PIN_HOME)" >> config/sniper.py
@./tools/makerelativepath.py xed_home "$(SIM_ROOT)" "$(XED_HOME)" >> config/sniper.py
@./tools/makerelativepath.py dynamorio_home "$(SIM_ROOT)" "$(DR_HOME)" >> config/sniper.py
@if [ $$(which git) ]; then if [ -e "$(SIM_ROOT)/.git" ]; then echo "git_revision=\"$$(git --git-dir='$(SIM_ROOT)/.git' rev-parse HEAD)\"" >> config/sniper.py; fi ; fi
@./tools/makebuildscripts.py "$(SIM_ROOT)" "$(PIN_HOME)" "$(DR_HOME)" "$(CC)" "$(CXX)" "$(SNIPER_TARGET_ARCH)"
empty_config:
$(_MSG) '[CLEAN ] config'
$(_CMD) rm -f config/sniper.py config/buildconf.sh config/buildconf.makefile
clean: empty_config empty_deps
$(_MSG) '[CLEAN ] standalone'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C standalone clean
$(_MSG) '[CLEAN ] pin'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C pin clean
$(_MSG) '[CLEAN ] common'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C common clean
$(_MSG) '[CLEAN ] sift'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C sift clean
$(_MSG) '[CLEAN ] tools'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C tools clean
$(_MSG) '[CLEAN ] frontend/pin-frontend'
$(_CMD) $(MAKE) $(MAKE_QUIET) -C frontend/pin-frontend clean
$(_CMD) rm -f .build_os
distclean: clean
$(_MSG) '[DISTCL] python_kit'
$(_CMD) rm -rf python_kit
$(_MSG) '[DISTCL] McPAT'
$(_CMD) rm -rf mcpat
$(_MSG) '[DISTCL] Xed'
$(_CMD) rm -rf xed xed_kit mbuild
$(_MSG) '[DISTCL] perf_event.h'
$(_CMD) rm -f include/linux/perf_event.h
regress_quick: regress_unit regress_apps
empty_deps:
$(_MSG) '[CLEAN ] deps'
$(_CMD) find . -name \*.d -exec rm {} \;
package_deps:
@BOOST_INCLUDE=$(BOOST_INCLUDE) ./tools/checkdependencies.py