forked from gluesys/fxmark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
58 lines (48 loc) · 1.45 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
# verbose flag
BUILD_VERBOSE = $(V)
ifeq ($(BUILD_VERBOSE),1)
Q =
else
Q = @
endif
# directory
SRC = src
BIN = bin
# cflags and source code
CFLAGS += $(DEFS) -Wall -g -O3 -D_GNU_SOURCE
LDFLAGS +=
LIBS = $(SRC)/bench.c $(SRC)/util.c
TC = $(SRC)/MWCM.c $(SRC)/MWCL.c \
$(SRC)/DWAL.c $(SRC)/DWOL.c \
$(SRC)/DWSL.c $(SRC)/MWRM.c \
$(SRC)/DWOM.c $(SRC)/MWRL.c \
$(SRC)/DRBL.c $(SRC)/DRBM.c \
$(SRC)/DRBH.c $(SRC)/MRDL.c \
$(SRC)/MRDM.c $(SRC)/MRPM.c \
$(SRC)/MRDL_bg.c $(SRC)/DRBL_bg.c \
$(SRC)/DRBH_bg.c $(SRC)/MRDM_bg.c \
$(SRC)/DRBM_bg.c $(SRC)/MRPM_bg.c \
$(SRC)/MWUM.c $(SRC)/MWUL.c \
$(SRC)/DWTL.c $(SRC)/MRPH.c \
$(SRC)/MRPL.c
DEPS = $(wildcard $(SRC)/*.h) $(LIBS) $(TC)
BINS = $(BIN)/fxmark
CPUPOLS = $(SRC)/cpuinfo $(SRC)/cpupol.h $(BIN)/cpupol.py
# tool
CPU_POLICY = $(BIN)/cpu-sequences | $(BIN)/gen_corepolicy
# target
all: $(BINS) $(LIBS) $(TC)
$(BIN)/%: $(SRC)/%.c $(DEPS) $(SRC)/cpupol.h $(BIN)/cpupol.py
@echo "CC $@"
$(Q)$(CC) $< $(CFLAGS) -o $@ $(LIBS) $(TC) $(LDFLAGS)
$(SRC)/cpuinfo:
$(Q)sudo $(BIN)/set-cpus all > /dev/null
- $(Q)cp /proc/cpuinfo $@
$(SRC)/cpupol.h: $(SRC)/cpuinfo $(BIN)/cpu-sequences $(BIN)/gen_corepolicy
- $(Q)cat $(SRC)/cpuinfo | $(CPU_POLICY) c > $@ 2>&1
$(BIN)/cpupol.py: $(SRC)/cpuinfo $(BIN)/cpu-sequences $(BIN)/gen_corepolicy
- $(Q)cat $(SRC)/cpuinfo | $(CPU_POLICY) py > $@ 2>&1
clean:
@echo "CLEAN"
$(Q) rm -f $(BIN)/*.o $(BINS) $(CPUPOLS)
.PHONY: all clean