forked from uvahotspot/HotSpot
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
222 lines (190 loc) · 4.81 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
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
#
# Thanks to Greg Link from Penn State University
# for his math acceleration engine.
#
# Uncomment the following math acceleration flags
# relevant to your target and set the appropriate
# path and flag options
#SUPERLU: [0-1]
ifndef SUPERLU
SUPERLU = 0
endif
ifeq ($(SUPERLU), 1)
#Super LU
SuperLUroot = /net/if10/rz3vg/Runjie/Temp/SuperLU_4.3
SUPERLULIB = $(SuperLUroot)/lib/libsuperlu_4.3.a
BLASLIB = -L $(SuperLUroot) -lblas
SLU_HEADER = $(SuperLUroot)/SRC
MATHACCEL = none
INCDIR = $(SLU_HEADER)
LIBDIR =
LIBS = -lm $(SUPERLULIB) $(BLASLIB)
EXTRAFLAGS =
else
# default - no math acceleration
MATHACCEL = none
INCDIR =
LIBDIR =
LIBS = -lm
EXTRAFLAGS =
endif
# Intel Machines - acceleration with the Intel
# Math Kernel Library (MKL)
#MATHACCEL = intel
#INCDIR = /bigdisk/ks4kk/mkl/10.1.0.015/include
#LIBDIR = /bigdisk/ks4kk/mkl/10.1.0.015/lib/em64t
#LIBS = -lmkl_lapack -lmkl -lguide -lm -lpthread
#EXTRAFLAGS =
# AMD Machines - acceleration with the AMD
# Core Math Library (ACML)
#MATHACCEL = amd
#INCDIR = /uf1/ks4kk/lib/acml3.6.0/gfortran32/include
#LIBDIR = /uf1/ks4kk/lib/acml3.6.0/gfortran32/lib
#LIBS = -lacml -lgfortran -lm
#EXTRAFLAGS =
# Apple Machines - acceleration with the Apple
# Velocity Engine (AltiVec)
#MATHACCEL = apple
#INCDIR =
#LIBDIR =
#LIBS = -framework vecLib -lm
#EXTRAFLAGS =
# Sun Machines - acceleration with the SUN
# performance library (sunperf)
#MATHACCEL = sun
#INCDIR =
#LIBDIR =
#LIBS = -library=sunperf
#EXTRAFLAGS = -dalign
# basic compiler flags - special case for sun
ifeq ($(MATHACCEL), sun)
CC = CC
ifeq ($(DEBUG), 1)
OFLAGS = -g -erroff=badargtypel2w
else
ifeq ($(DEBUG), 2)
OFLAGS = -xpg -g -erroff=badargtypel2w
else
OFLAGS = -xO4 -erroff=badargtypel2w
endif # DEBUG = 2
endif # DEBUG = 1
else # MATHACCEL != sun
CC = gcc
ifeq ($(DEBUG), 1)
OFLAGS = -O0 -ggdb -Wall
else
ifeq ($(DEBUG), 2)
OFLAGS = -O3 -pg -ggdb -Wall
else
OFLAGS = -O3
endif # DEBUG = 2
endif # DEBUG = 1
endif # end MATHACCEL
RM = rm -f
AR = ar qcv
RANLIB = ranlib
OEXT = o
LEXT = a
# Verbosity level [0-3]
ifndef VERBOSE
VERBOSE = 1
endif
#BU_3D: Debugging 3D [0-1]
ifndef DEBUG3D
DEBUG3D = 0
endif
# Numerical ID for each acceleration engine
ifeq ($(MATHACCEL), none)
ACCELNUM = 0
endif
ifeq ($(MATHACCEL), intel)
ACCELNUM = 1
endif
ifeq ($(MATHACCEL), amd)
ACCELNUM = 2
endif
ifeq ($(MATHACCEL), apple)
ACCELNUM = 3
endif
ifeq ($(MATHACCEL), sun)
ACCELNUM = 4
endif
ifdef INCDIR
INCDIRFLAG = -I$(INCDIR)
endif
ifdef LIBDIR
LIBDIRFLAG = -L$(LIBDIR)
endif
CFLAGS = $(OFLAGS) $(EXTRAFLAGS) $(INCDIRFLAG) $(LIBDIRFLAG) -DVERBOSE=$(VERBOSE) -DMATHACCEL=$(ACCELNUM) -DDEBUG3D=$(DEBUG3D) -DSUPERLU=$(SUPERLU) -g
# sources, objects, headers and inputs
# HotFloorplan
FLPSRC = flp.c flp_desc.c npe.c shape.c
FLPOBJ = flp.$(OEXT) flp_desc.$(OEXT) npe.$(OEXT) shape.$(OEXT)
FLPHDR = flp.h npe.h shape.h
FLPIN = ev6.desc avg.p
# HotSpot
TEMPSRC = temperature.c RCutil.c
TEMPOBJ = temperature.$(OEXT) RCutil.$(OEXT)
TEMPHDR = temperature.h
TEMPIN =
# Package model
PACKSRC = package.c
PACKOBJ = package.$(OEXT)
PACKHDR = package.h
PACKIN = package.config
# HotSpot block model
BLKSRC = temperature_block.c
BLKOBJ = temperature_block.$(OEXT)
BLKHDR = temperature_block.h
BLKIN = ev6.flp gcc.ptrace
# HotSpot grid model
GRIDSRC = temperature_grid.c
GRIDOBJ = temperature_grid.$(OEXT)
GRIDHDR = temperature_grid.h
GRIDIN = layer.lcf example.lcf example.flp example.ptrace
# Miscellaneous
MISCSRC = util.c wire.c
MISCOBJ = util.$(OEXT) wire.$(OEXT)
MISCHDR = util.h wire.h
MISCIN = hotspot.config
# all objects
OBJ = $(TEMPOBJ) $(PACKOBJ) $(BLKOBJ) $(GRIDOBJ) $(FLPOBJ) $(MISCOBJ)
# targets
all: hotspot hotfloorplan lib
hotspot: hotspot.$(OEXT) $(OBJ)
$(CC) $(CFLAGS) -o hotspot hotspot.$(OEXT) $(OBJ) $(LIBS)
ifdef LIBDIR
@echo
@echo
@echo "...Done. Do not forget to include $(LIBDIR) in your LD_LIBRARY_PATH"
endif
hotfloorplan: hotfloorplan.$(OEXT) $(OBJ)
$(CC) $(CFLAGS) -o hotfloorplan hotfloorplan.$(OEXT) $(OBJ) $(LIBS)
ifdef LIBDIR
@echo
@echo
@echo "...Done. Do not forget to include $(LIBDIR) in your LD_LIBRARY_PATH"
endif
lib: hotspot hotfloorplan
$(RM) libhotspot.$(LEXT)
$(AR) libhotspot.$(LEXT) $(OBJ)
$(RANLIB) libhotspot.$(LEXT)
#pull in dependency info for existing .o files
-include $(OBJ:.o=.d)
.c.$(OEXT):
$(CC) $(CFLAGS) -c $*.c
$(CC) -MM $(CFLAGS) $*.c > $*.d
.cpp.$(OEXT):
$(CC) $(CFLAGS) -c $*.cpp
filelist:
@echo $(FLPSRC) $(TEMPSRC) $(PACKSRC) $(BLKSRC) $(GRIDSRC) $(MISCSRC) \
$(FLPHDR) $(TEMPHDR) $(PACKHDR) $(BLKHDR) $(GRIDHDR) $(MISCHDR) \
$(FLPIN) $(TEMPIN) $(PACKIN) $(BLKIN) $(GRIDIN) $(MISCIN) \
hotspot.h hotspot.c hotfloorplan.h hotfloorplan.c \
sim-template_block.c \
tofig.pl grid_thermal_map.pl \
Makefile
clean:
$(RM) *.$(OEXT) *.obj *.d core *~ Makefile.bak hotspot hotfloorplan libhotspot.$(LEXT)
cleano:
$(RM) *.$(OEXT) *.obj