ghc.mk 17.9 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
# -----------------------------------------------------------------------------
#
# (c) 2009 The University of Glasgow
#
# This file is part of the GHC build system.
#
# To understand how the build system works and how to modify it, see
#      http://hackage.haskell.org/trac/ghc/wiki/Building/Architecture
#      http://hackage.haskell.org/trac/ghc/wiki/Building/Modifying
#
# -----------------------------------------------------------------------------

Ian Lynagh's avatar
Ian Lynagh committed
13
14
15
16
17
18
# -----------------------------------------------------------------------------
# Building the RTS

# We build the RTS with stage 1
rts_dist_HC = $(GHC_STAGE1)

19
20
# merge GhcLibWays and GhcRTSWays but strip out duplicates
rts_WAYS = $(GhcLibWays) $(filter-out $(GhcLibWays),$(GhcRTSWays))
Ian Lynagh's avatar
Ian Lynagh committed
21
rts_dist_WAYS = $(rts_WAYS)
Ian Lynagh's avatar
Ian Lynagh committed
22

kili's avatar
kili committed
23
24
ALL_RTS_LIBS = rts/dist/build/libHSrtsmain.a \
	       $(foreach way,$(rts_WAYS),rts/dist/build/libHSrts$($(way)_libsuf))
Ian Lynagh's avatar
Ian Lynagh committed
25
26
27
28
29
all_rts : $(ALL_RTS_LIBS)

# -----------------------------------------------------------------------------
# Defining the sources

Simon Marlow's avatar
Simon Marlow committed
30
ALL_DIRS = hooks parallel sm eventlog
Ian Lynagh's avatar
Ian Lynagh committed
31
32
33
34
35
36
37

ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
ALL_DIRS += win32
else
ALL_DIRS += posix
endif

38
EXCLUDED_SRCS :=
39
EXCLUDED_SRCS += rts/Main.c
Ian Lynagh's avatar
Ian Lynagh committed
40
41
42
EXCLUDED_SRCS += rts/parallel/SysMan.c
EXCLUDED_SRCS += $(wildcard rts/Vis*.c)

43
44
rts_C_SRCS := $(filter-out $(EXCLUDED_SRCS),$(wildcard rts/*.c $(foreach dir,$(ALL_DIRS),rts/$(dir)/*.c)))
rts_CMM_SRCS := $(wildcard rts/*.cmm)
Ian Lynagh's avatar
Ian Lynagh committed
45

Ian Lynagh's avatar
Ian Lynagh committed
46
# Don't compile .S files when bootstrapping a new arch
Ian Lynagh's avatar
Ian Lynagh committed
47
ifneq "$(PORTING_HOST)" "YES"
48
ifneq "$(findstring $(TargetArch_CPP), i386 powerpc powerpc64)" ""
Ian Lynagh's avatar
Ian Lynagh committed
49
50
rts_S_SRCS += rts/AdjustorAsm.S
endif
Ian Lynagh's avatar
Ian Lynagh committed
51
endif
Ian Lynagh's avatar
Ian Lynagh committed
52
53
54
55
56
57
58
59

ifeq "$(GhcUnregisterised)" "YES"
GENAPPLY_OPTS = -u
endif

rts_AUTO_APPLY_CMM = rts/dist/build/AutoApply.cmm

$(rts_AUTO_APPLY_CMM): $(GENAPPLY_INPLACE)
60
	"$(GENAPPLY_INPLACE)" >$@
Ian Lynagh's avatar
Ian Lynagh committed
61

62
rts/dist/build/sm/Evac_thr.c : rts/sm/Evac.c | $$(dir $$@)/.
Ian Lynagh's avatar
Ian Lynagh committed
63
	cp $< $@
64
rts/dist/build/sm/Scav_thr.c : rts/sm/Scav.c | $$(dir $$@)/.
Ian Lynagh's avatar
Ian Lynagh committed
65
66
	cp $< $@

67
rts_H_FILES := $(wildcard rts/*.h)
Ian Lynagh's avatar
Ian Lynagh committed
68

69
ifeq "$(USE_DTRACE)" "YES"
70
71
72
73
DTRACEPROBES_H = rts/dist/build/RtsProbes.h
rts_H_FILES += $(DTRACEPROBES_H)
endif

74
75
# collect the -l flags that we need to link the rts dyn lib.
rts/libs.depend : $(GHC_PKG_INPLACE)
76
	"$(GHC_PKG_INPLACE)" field rts extra-libraries \
77
	  | sed -e 's/^extra-libraries: //' -e 's/\([a-z0-9]*\)[ ]*/-l\1 /g' > $@
78

79
80
81
82
83
84
85
86
87
88
89
90
91
92

# ----------------------------------------------------------------------------
# On Windows, as the RTS and base libraries have recursive imports,
# 	we have to break the loop with "import libraries".
# 	These are made from rts/win32/libHS*.def which contain lists of
# 	all the symbols in those libraries used by the RTS.
#
ifneq "$$(findstring dyn, $1)" ""
ifeq  "$(HOSTPLATFORM)" "i386-unknown-mingw32" 

ALL_RTS_DEF_LIBNAMES 	= base ghc-prim
ALL_RTS_DEF_LIBS	= \
	rts/dist/build/win32/libHSbase.dll.a \
	rts/dist/build/win32/libHSghc-prim.dll.a \
93
	rts/dist/build/win32/libHSffi.dll.a 
94
95
96
97
98
99
100
101

# -- import libs for the regular Haskell libraries
define make-importlib-def # args $1 = lib name
rts/dist/build/win32/libHS$1.def : rts/win32/libHS$1.def
	cat rts/win32/libHS$1.def \
		| sed "s/@LibVersion@/$$(libraries/$1_dist-install_VERSION)/" \
		| sed "s/@ProjectVersion@/$(ProjectVersion)/" \
		> rts/dist/build/win32/libHS$1.def
102

103
104
105
106
107
108
109
110
111
112
113
114
rts/dist/build/win32/libHS$1.dll.a : rts/dist/build/win32/libHS$1.def
	"$$(DLLTOOL)" 	-d rts/dist/build/win32/libHS$1.def \
			-l rts/dist/build/win32/libHS$1.dll.a
endef
$(foreach lib,$(ALL_RTS_DEF_LIBNAMES),$(eval $(call make-importlib-def,$(lib))))


# -- import libs for libffi
rts/dist/build/win32/libHSffi.def : rts/win32/libHSffi.def
	cat rts/win32/libHSffi.def \
		| sed "s/@ProjectVersion@/$(ProjectVersion)/" \
		> rts/dist/build/win32/libHSffi.def
115

116
117
118
119
120
121
122
rts/dist/build/win32/libHSffi.dll.a : rts/dist/build/win32/libHSffi.def
	"$(DLLTOOL)" 	-d rts/dist/build/win32/libHSffi.def \
			-l rts/dist/build/win32/libHSffi.dll.a
endif
endif


Ian Lynagh's avatar
Ian Lynagh committed
123
124
125
126
#-----------------------------------------------------------------------------
# Building one way
define build-rts-way # args: $1 = way

127
128
ifneq "$$(BINDIST)" "YES"

Ian Lynagh's avatar
Ian Lynagh committed
129
130
131
132
133
# The per-way CC_OPTS
ifneq "$$(findstring debug, $1)" ""
rts_dist_$1_HC_OPTS =
rts_dist_$1_CC_OPTS = -g -O0
else
134
135
rts_dist_$1_HC_OPTS = $$(GhcRtsHcOpts)
rts_dist_$1_CC_OPTS = $$(GhcRtsCcOpts)
Ian Lynagh's avatar
Ian Lynagh committed
136
137
138
139
140
141
142
143
144
endif

ifneq "$$(findstring thr, $1)" ""
rts_$1_EXTRA_C_SRCS  =  rts/dist/build/sm/Evac_thr.c rts/dist/build/sm/Scav_thr.c
endif

$(call distdir-way-opts,rts,dist,$1)
$(call c-suffix-rules,rts,dist,$1,YES)
$(call cmm-suffix-rules,rts,dist,$1)
145
$(call hs-suffix-rules-srcdir,rts,dist,$1,.)
146
# hs-suffix-rules-srcdir is needed when BootingFromHc to get the .hc rules
Ian Lynagh's avatar
Ian Lynagh committed
147

148
149
rts_$1_LIB_NAME = libHSrts$$($1_libsuf)
rts_$1_LIB = rts/dist/build/$$(rts_$1_LIB_NAME)
Ian Lynagh's avatar
Ian Lynagh committed
150
151
152

rts_$1_C_OBJS   = $$(patsubst rts/%.c,rts/dist/build/%.$$($1_osuf),$$(rts_C_SRCS)) $$(patsubst %.c,%.$$($1_osuf),$$(rts_$1_EXTRA_C_SRCS))
rts_$1_S_OBJS   = $$(patsubst rts/%.S,rts/dist/build/%.$$($1_osuf),$$(rts_S_SRCS))
153
rts_$1_CMM_OBJS = $$(patsubst rts/%.cmm,rts/dist/build/%.$$($1_osuf),$$(rts_CMM_SRCS)) $$(patsubst %.cmm,%.$$($1_osuf),$$(rts_AUTO_APPLY_CMM))
Ian Lynagh's avatar
Ian Lynagh committed
154
155
156

rts_$1_OBJS = $$(rts_$1_C_OBJS) $$(rts_$1_S_OBJS) $$(rts_$1_CMM_OBJS)

157
158
159
160
161
162
163
164
165
166
167
168
169
ifeq "$(USE_DTRACE)" "YES"
ifeq "$(TargetOS_CPP)" "solaris2"
# On Darwin we don't need to generate binary containing probes defined
# in DTrace script, but DTrace on Solaris expects generation of binary
# from the DTrace probes definitions
rts_$1_DTRACE_OBJS = rts/dist/build/RtsProbes.$$($1_osuf)

rts/dist/build/RtsProbes.$$($1_osuf) : $$(rts_$1_OBJS)
	$(DTRACE) -G -C -Iincludes -DDTRACE -s rts/RtsProbes.d -o \
		$$@ $$(rts_$1_OBJS)
endif
endif

170
rts_dist_$1_CC_OPTS += -DRtsWay=\"rts_$1\"
171

172
# Making a shared library for the RTS.
173
ifneq "$$(findstring dyn, $1)" ""
174
ifeq "$$(HOSTPLATFORM)" "i386-unknown-mingw32"
175
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(ALL_RTS_DEF_LIBS) rts/libs.depend
176
	"$$(RM)" $$(RM_OPTS) $$@
177
	"$$(rts_dist_HC)" -package-name rts -shared -dynamic -dynload deploy \
178
179
	  -no-auto-link-packages `cat rts/libs.depend` $$(rts_$1_OBJS) $$(ALL_RTS_DEF_LIBS) -o $$@
else
180
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS) rts/libs.depend
181
	"$$(RM)" $$(RM_OPTS) $$@
182
	"$$(rts_dist_HC)" -package-name rts -shared -dynamic -dynload deploy \
183
184
	  -no-auto-link-packages `cat rts/libs.depend` $$(rts_$1_OBJS) \
	  $$(rts_$1_DTRACE_OBJS) -o $$@
185
ifeq "$$(darwin_HOST_OS)" "1"
186
187
188
	# Ensure library's install name is correct before anyone links with it.
	install_name_tool -id $(ghclibdir)/$$(rts_$1_LIB_NAME) $$@
endif
189
endif
190
else
191
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS)
192
	"$$(RM)" $$(RM_OPTS) $$@
193
	echo $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS) | "$$(XARGS)" $$(XARGS_OPTS) "$$(AR_STAGE1)" \
194
		$$(AR_OPTS_STAGE1) $$(EXTRA_AR_ARGS_STAGE1) $$@
195
endif
Ian Lynagh's avatar
Ian Lynagh committed
196

197
198
endif

Ian Lynagh's avatar
Ian Lynagh committed
199
200
201
202
203
204
205
206
endef

# And expand the above for each way:
$(foreach way,$(rts_WAYS),$(eval $(call build-rts-way,$(way))))

#-----------------------------------------------------------------------------
# Flags for compiling every file

Simon Marlow's avatar
Simon Marlow committed
207
# We like plenty of warnings.
208
209
210
211
212
213
WARNING_OPTS += -Wall
ifeq "$(GccLT34)" "YES"
WARNING_OPTS += -W
else
WARNING_OPTS += -Wextra
endif
Ian Lynagh's avatar
Ian Lynagh committed
214
215
216
217
218
WARNING_OPTS += -Wstrict-prototypes 
WARNING_OPTS += -Wmissing-prototypes 
WARNING_OPTS += -Wmissing-declarations
WARNING_OPTS += -Winline
WARNING_OPTS += -Waggregate-return
Simon Marlow's avatar
Simon Marlow committed
219
220
221
222
223
224
225
WARNING_OPTS += -Wpointer-arith
WARNING_OPTS += -Wmissing-noreturn
WARNING_OPTS += -Wnested-externs
WARNING_OPTS += -Wredundant-decls 

# These ones are hard to avoid:
#WARNING_OPTS += -Wconversion
Ian Lynagh's avatar
Ian Lynagh committed
226
227
228
229
#WARNING_OPTS += -Wbad-function-cast
#WARNING_OPTS += -Wshadow
#WARNING_OPTS += -Wcast-qual

230
231
232
233
234
235
236
237
238
# This one seems buggy on GCC 4.1.2, which is the only GCC version we 
# have that can bootstrap the SPARC build. We end up with lots of supurious
# warnings of the form "cast increases required alignment of target type".
# Some legitimate warnings can be fixed by adding an intermediate cast to
# (void*), but we get others in rts/sm/GCUtils.c concerning the gct var
# that look innocuous to me. We could enable this again once we deprecate
# support for registerised builds on this arch. -- BL 2010/02/03
# WARNING_OPTS += -Wcast-align

Simon Marlow's avatar
Simon Marlow committed
239
STANDARD_OPTS += -Iincludes -Irts
Ian Lynagh's avatar
Ian Lynagh committed
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
# COMPILING_RTS is only used when building Win32 DLL support.
STANDARD_OPTS += -DCOMPILING_RTS

# HC_OPTS is included in both .c and .cmm compilations, whereas CC_OPTS is
# only included in .c compilations.  HC_OPTS included the WAY_* opts, which
# must be included in both types of compilations.

rts_CC_OPTS += $(WARNING_OPTS)
rts_CC_OPTS += $(STANDARD_OPTS)

rts_HC_OPTS += $(STANDARD_OPTS) -package-name rts

ifneq "$(GhcWithSMP)" "YES"
rts_CC_OPTS += -DNOSMP
rts_HC_OPTS += -optc-DNOSMP
endif

ifeq "$(UseLibFFIForAdjustors)" "YES"
rts_CC_OPTS += -DUSE_LIBFFI_FOR_ADJUSTORS
endif

# Mac OS X: make sure we compile for the right OS version
rts_CC_OPTS += $(MACOSX_DEPLOYMENT_CC_OPTS)
rts_HC_OPTS += $(addprefix -optc, $(MACOSX_DEPLOYMENT_CC_OPTS))
rts_LD_OPTS += $(addprefix -optl, $(MACOSX_DEPLOYMENT_LD_OPTS))

# We *want* type-checking of hand-written cmm.
rts_HC_OPTS += -dcmm-lint 

# -fno-strict-aliasing is required for the runtime, because we often
# use a variety of types to represent closure pointers (StgPtr,
# StgClosure, StgMVar, etc.), and without -fno-strict-aliasing gcc is
# allowed to assume that these pointers do not alias.  eg. without
# this flag we get problems in sm/Evac.c:copy() with gcc 3.4.3, the
# upd_evacee() assigments get moved before the object copy.
rts_CC_OPTS += -fno-strict-aliasing

Simon Marlow's avatar
Simon Marlow committed
277
278
rts_CC_OPTS += -fno-common

Ian Lynagh's avatar
Ian Lynagh committed
279
280
281
282
283
284
285
ifeq "$(BeConservative)" "YES"
rts_CC_OPTS += -DBE_CONSERVATIVE
endif

#-----------------------------------------------------------------------------
# Flags for compiling specific files

286
# If RtsMain.c is built with optimisation then the SEH exception stuff on
Ian Lynagh's avatar
Ian Lynagh committed
287
288
289
# Windows gets confused.
# This has to be in HC rather than CC opts, as otherwise there's a
# -optc-O2 that comes after it.
290
rts/RtsMain_HC_OPTS += -optc-O0
Ian Lynagh's avatar
Ian Lynagh committed
291

292
293
rts/RtsMessages_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
rts/RtsUtils_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
294
rts/Trace_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
Ian Lynagh's avatar
Ian Lynagh committed
295
#
296
297
298
299
rts/RtsUtils_CC_OPTS += -DHostPlatform=\"$(HOSTPLATFORM)\"
rts/RtsUtils_CC_OPTS += -DHostArch=\"$(HostArch_CPP)\"
rts/RtsUtils_CC_OPTS += -DHostOS=\"$(HostOS_CPP)\"
rts/RtsUtils_CC_OPTS += -DHostVendor=\"$(HostVendor_CPP)\"
Ian Lynagh's avatar
Ian Lynagh committed
300
#
301
302
303
304
rts/RtsUtils_CC_OPTS += -DBuildPlatform=\"$(BUILDPLATFORM)\"
rts/RtsUtils_CC_OPTS += -DBuildArch=\"$(BuildArch_CPP)\"
rts/RtsUtils_CC_OPTS += -DBuildOS=\"$(BuildOS_CPP)\"
rts/RtsUtils_CC_OPTS += -DBuildVendor=\"$(BuildVendor_CPP)\"
Ian Lynagh's avatar
Ian Lynagh committed
305
#
306
307
308
309
rts/RtsUtils_CC_OPTS += -DTargetPlatform=\"$(TARGETPLATFORM)\"
rts/RtsUtils_CC_OPTS += -DTargetArch=\"$(TargetArch_CPP)\"
rts/RtsUtils_CC_OPTS += -DTargetOS=\"$(TargetOS_CPP)\"
rts/RtsUtils_CC_OPTS += -DTargetVendor=\"$(TargetVendor_CPP)\"
Ian Lynagh's avatar
Ian Lynagh committed
310
#
311
312
rts/RtsUtils_CC_OPTS += -DGhcUnregisterised=\"$(GhcUnregisterised)\"
rts/RtsUtils_CC_OPTS += -DGhcEnableTablesNextToCode=\"$(GhcEnableTablesNextToCode)\"
Ian Lynagh's avatar
Ian Lynagh committed
313

314
315
316
317
318
319
320
321
322
323
# Compile various performance-critical pieces *without* -fPIC -dynamic
# even when building a shared library.  If we don't do this, then the
# GC runs about 50% slower on x86 due to the overheads of PIC.  The
# cost of doing this is a little runtime linking and less sharing, but
# not much.
#
# On x86_64 this doesn't work, because all objects in a shared library
# must be compiled with -fPIC (since the 32-bit relocations generated
# by the default small memory can't be resolved at runtime).  So we
# only do this on i386.
324
#
325
326
# This apparently doesn't work on OS X (Darwin) nor on Solaris.
# On Darwin we get errors of the form
327
328
329
330
331
332
333
#
#  ld: absolute addressing (perhaps -mdynamic-no-pic) used in _stg_ap_0_fast from rts/dist/build/Apply.dyn_o not allowed in slidable image
#
# and lots of these warnings:
#
#  ld: warning codegen in _stg_ap_pppv_fast (offset 0x0000005E) prevents image from loading in dyld shared cache
#
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
# On Solaris we get errors like:
#
# Text relocation remains                         referenced
#     against symbol                  offset      in file
# .rodata (section)                   0x11        rts/dist/build/Apply.dyn_o
#   ...
# ld: fatal: relocations remain against allocatable but non-writable sections
# collect2: ld returned 1 exit status

ifeq "$(TargetArch_CPP)" "i386"
i386_SPEED_HACK := "YES"
ifeq "$(TargetOS_CPP)" "darwin"
i386_SPEED_HACK := "NO"
endif
ifeq "$(TargetOS_CPP)" "solaris2"
i386_SPEED_HACK := "NO"
endif
endif

353
ifeq "$(TargetArch_CPP)" "i386"
354
ifeq "$(i386_SPEED_HACK)" "YES"
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
rts/sm/Evac_HC_OPTS           += -fno-PIC
rts/sm/Evac_thr_HC_OPTS       += -fno-PIC
rts/sm/Scav_HC_OPTS           += -fno-PIC
rts/sm/Scav_thr_HC_OPTS       += -fno-PIC
rts/sm/Compact_HC_OPTS        += -fno-PIC
rts/sm/GC_HC_OPTS             += -fno-PIC

# -static is also necessary for these bits, otherwise the NCG
# -generates dynamic references:
rts/Updates_HC_OPTS += -fno-PIC -static
rts/StgMiscClosures_HC_OPTS += -fno-PIC -static
rts/PrimOps_HC_OPTS += -fno-PIC -static
rts/Apply_HC_OPTS += -fno-PIC -static
rts/dist/build/AutoApply_HC_OPTS += -fno-PIC -static
endif
370
endif
371

Ian Lynagh's avatar
Ian Lynagh committed
372
# ffi.h triggers prototype warnings, so disable them here:
373
374
375
rts/Interpreter_CC_OPTS += -Wno-strict-prototypes
rts/Adjustor_CC_OPTS    += -Wno-strict-prototypes
rts/sm/Storage_CC_OPTS  += -Wno-strict-prototypes
Simon Marlow's avatar
Simon Marlow committed
376
377

# inlining warnings happen in Compact
378
rts/sm/Compact_CC_OPTS += -Wno-inline
Ian Lynagh's avatar
Ian Lynagh committed
379

Simon Marlow's avatar
Simon Marlow committed
380
# emits warnings about call-clobbered registers on x86_64
381
rts/StgCRun_CC_OPTS += -w
Simon Marlow's avatar
Simon Marlow committed
382

383
384
rts/RetainerProfile_CC_OPTS += -w
rts/RetainerSet_CC_OPTS += -Wno-format
Ian Lynagh's avatar
Ian Lynagh committed
385
# On Windows:
386
387
rts/win32/ConsoleHandler_CC_OPTS += -w
rts/win32/ThrIOManager_CC_OPTS += -w
Ian Lynagh's avatar
Ian Lynagh committed
388
389
390
391
392
393
394
# The above warning supression flags are a temporary kludge.
# While working on this module you are encouraged to remove it and fix
# any warnings in the module. See
#     http://hackage.haskell.org/trac/ghc/wiki/WorkingConventions#Warnings
# for details

# Without this, thread_obj will not be inlined (at least on x86 with GCC 4.1.0)
395
rts/sm/Compact_CC_OPTS += -finline-limit=2500
Ian Lynagh's avatar
Ian Lynagh committed
396
397

# -O3 helps unroll some loops (especially in copy() with a constant argument).
398
399
rts/sm/Evac_CC_OPTS += -funroll-loops
rts/dist/build/sm/Evac_thr_HC_OPTS += -optc-funroll-loops
Ian Lynagh's avatar
Ian Lynagh committed
400
401
402

# These files are just copies of sm/Evac.c and sm/Scav.c respectively,
# but compiled with -DPARALLEL_GC.
403
404
rts/dist/build/sm/Evac_thr_CC_OPTS += -DPARALLEL_GC -Irts/sm
rts/dist/build/sm/Scav_thr_CC_OPTS += -DPARALLEL_GC -Irts/sm
Ian Lynagh's avatar
Ian Lynagh committed
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436

#-----------------------------------------------------------------------------
# Add PAPI library if needed

ifeq "$(GhcRtsWithPapi)" "YES"

rts_CC_OPTS		+= -DUSE_PAPI

rts_PACKAGE_CPP_OPTS	+= -DUSE_PAPI
rts_PACKAGE_CPP_OPTS    += -DPAPI_INCLUDE_DIR=$(PapiIncludeDir)
rts_PACKAGE_CPP_OPTS    += -DPAPI_LIB_DIR=$(PapiLibDir)

ifneq "$(PapiIncludeDir)" ""
rts_HC_OPTS     += -I$(PapiIncludeDir)
rts_CC_OPTS     += -I$(PapiIncludeDir)
rts_HSC2HS_OPTS += -I$(PapiIncludeDir)
endif
ifneq "$(PapiLibDirs)" ""
rts_LD_OPTS     += -L$(PapiLibDirs)
endif

else # GhcRtsWithPapi==YES

rts_PACKAGE_CPP_OPTS += -DPAPI_INCLUDE_DIR=""
rts_PACKAGE_CPP_OPTS += -DPAPI_LIB_DIR=""

endif

# -----------------------------------------------------------------------------
# dependencies

rts_WAYS_DASHED = $(subst $(space),,$(patsubst %,-%,$(strip $(rts_WAYS))))
Ian Lynagh's avatar
Ian Lynagh committed
437
rts_dist_depfile_base = rts/dist/build/.depend$(rts_WAYS_DASHED)
Ian Lynagh's avatar
Ian Lynagh committed
438

Simon Marlow's avatar
Simon Marlow committed
439
rts_dist_C_SRCS  = $(rts_C_SRCS) $(rts_thr_EXTRA_C_SRCS)
Ian Lynagh's avatar
Ian Lynagh committed
440
rts_dist_S_SRCS =  $(rts_S_SRCS)
Simon Marlow's avatar
Simon Marlow committed
441
rts_dist_C_FILES = $(rts_C_SRCS) $(rts_thr_EXTRA_C_SRCS) $(rts_S_SRCS)
Ian Lynagh's avatar
Ian Lynagh committed
442

443
444
445
446
447
448
449
# Hack: we define every way-related option here, so that we get (hopefully)
# a superset of the dependencies.  To do this properly, we should generate
# a different set of dependencies for each way.  Further hack: PROFILING an

# TICKY_TICKY can't be used together, so we omit TICKY_TICKY for now.
rts_dist_MKDEPENDC_OPTS += -DPROFILING -DTHREADED_RTS -DDEBUG

450
ifeq "$(USE_DTRACE)" "YES"
451
452
453
454
455

rts_dist_MKDEPENDC_OPTS += -Irts/dist/build

endif

456
$(eval $(call dependencies,rts,dist,1))
Ian Lynagh's avatar
Ian Lynagh committed
457

458
$(rts_dist_depfile_c_asm) : libffi/dist-install/build/ffi.h $(DTRACEPROBES_H)
Ian Lynagh's avatar
Ian Lynagh committed
459
460
461
462

#-----------------------------------------------------------------------------
# libffi stuff

463
464
465
466
rts_CC_OPTS     += -Ilibffi/dist-install/build
rts_HC_OPTS     += -Ilibffi/dist-install/build
rts_HSC2HS_OPTS += -Ilibffi/dist-install/build
rts_LD_OPTS     += -Llibffi/dist-install/build
Ian Lynagh's avatar
Ian Lynagh committed
467

468
469
470
# -----------------------------------------------------------------------------
# compile dtrace probes if dtrace is supported

471
ifeq "$(USE_DTRACE)" "YES"
472
473
474
475

rts_CC_OPTS		+= -DDTRACE
rts_HC_OPTS		+= -DDTRACE

476
477
478
479
480
# Apple's dtrace (the only one supported by ghc at the moment) uses
# gcc as its preprocessor. If gcc isn't at /usr/bin/gcc, or we need
# to force it to use a different gcc, we need to give the path in
# the option cpppath.

481
482
483
484
485
486
ifeq "$(TargetOS_CPP)" "darwin"
# Darwin has a flag to tell dtrace which cpp to use.
# Unfortunately, this isn't supported on Solaris (See Solaris Dynamic Tracing
# Guide, Chapter 16, for the configuration variables available on Solaris)
DTRACE_FLAGS = -x cpppath=$(WhatGccIsCalled)
endif
487

488
489
490
DTRACEPROBES_SRC = rts/RtsProbes.d
$(DTRACEPROBES_H): $(DTRACEPROBES_SRC) includes/ghcplatform.h | $$(dir $$@)/.
	"$(DTRACE)" $(filter -I%,$(rts_CC_OPTS)) -C $(DTRACE_FLAGS) -h -o $@ -s $<
491
492
endif

493
494
495
# -----------------------------------------------------------------------------
# build the static lib containing the C main symbol

496
ifneq "$(BINDIST)" "YES"
497
rts/dist/build/libHSrtsmain.a : rts/dist/build/Main.o
498
	"$(RM)" $(RM_OPTS) $@
499
	"$(AR_STAGE1)" $(AR_OPTS_STAGE1) $(EXTRA_AR_ARGS_STAGE1) $@ $<
500
endif
501

Ian Lynagh's avatar
Ian Lynagh committed
502
503
504
505
506
507
508
509
510
511
512
513
514
515
# -----------------------------------------------------------------------------
# The RTS package config

# If -DDEBUG is in effect, adjust package conf accordingly..
ifneq "$(strip $(filter -optc-DDEBUG,$(GhcRtsHcOpts)))" ""
rts_PACKAGE_CPP_OPTS += -DDEBUG
endif

ifeq "$(HaveLibMingwEx)" "YES"
rts_PACKAGE_CPP_OPTS += -DHAVE_LIBMINGWEX
endif

$(eval $(call manual-package-config,rts))

516
ifneq "$(BootingFromHc)" "YES"
Ian Lynagh's avatar
Ian Lynagh committed
517
rts/package.conf.inplace : $(includes_H_CONFIG) $(includes_H_PLATFORM)
518
endif
Ian Lynagh's avatar
Ian Lynagh committed
519
520
521
522

# -----------------------------------------------------------------------------
# installing

523
INSTALL_LIBS += $(ALL_RTS_LIBS)
Ian Lynagh's avatar
Ian Lynagh committed
524
525
526
527
528
529
530
531

# -----------------------------------------------------------------------------
# cleaning

$(eval $(call clean-target,rts,dist,rts/dist))

BINDIST_EXTRAS += rts/package.conf.in