-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathMakefile
77 lines (58 loc) · 1.46 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
SRC = src
INCLUDE = include
CFLAGS = -O3 -Wall
LDFLAGS = -lm -lrt
VER_FLAGS = -D_GNU_SOURCE
ifeq ($(VERSION),DEBUG)
CFLAGS = -O0 -ggdb -Wall -g -fno-inline
endif
UNAME := $(shell uname -n)
ifeq ($(UNAME), lpd48core)
PLATFORM = OPTERON
CC = gcc
PLATFORM_NUMA = 1
endif
ifeq ($(UNAME), diassrv8)
PLATFORM = XEON
CC = gcc
PLATFORM_NUMA = 1
endif
ifeq ($(UNAME), maglite)
PLATFORM = NIAGARA
CC = /opt/csw/bin/gcc
CFLAGS += -m64 -mcpu=v9 -mtune=v9
endif
ifeq ($(UNAME), parsasrv1.epfl.ch)
PLATFORM = TILERA
CC = tile-gcc
LDFLAGS += -ltmc
endif
ifeq ($(UNAME), diascld19)
PLATFORM = XEON2
CC = gcc
endif
ifeq ($(UNAME), diascld9)
PLATFORM = OPTERON2
CC = gcc
endif
ifeq ($(PLATFORM), )
PLATFORM = DEFAULT
CC = gcc
endif
VER_FLAGS += -D$(PLATFORM)
ifeq ($(PLATFORM_NUMA),1) #give PLATFORM_NUMA=1 for NUMA
LDFLAGS += -lnuma
VER_FLAGS += -DPLATFORM_NUMA
endif
default: ccbench
all: ccbench
ccbench: ccbench.o $(SRC)/pfd.c $(SRC)/barrier.c $(INCLUDE)/common.h $(INCLUDE)/ccbench.h $(INCLUDE)/pfd.h $(INCLUDE)/barrier.h barrier.o pfd.o
$(CC) $(VER_FLAGS) -o ccbench ccbench.o pfd.o barrier.o $(CFLAGS) $(LDFLAGS) -I./$(INCLUDE)
ccbench.o: $(SRC)/ccbench.c $(INCLUDE)/ccbench.h
$(CC) $(VER_FLAGS) -c $(SRC)/ccbench.c $(CFLAGS) -I./$(INCLUDE)
pfd.o: $(SRC)/pfd.c $(INCLUDE)/pfd.h
$(CC) $(VER_FLAGS) -c $(SRC)/pfd.c $(CFLAGS) -I./$(INCLUDE)
barrier.o: $(SRC)/barrier.c $(INCLUDE)/barrier.h
$(CC) $(VER_FLAGS) -c $(SRC)/barrier.c $(CFLAGS) -I./$(INCLUDE)
clean:
rm -f *.o ccbench