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

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

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

Simon Marlow's avatar
Simon Marlow committed
29
ALL_DIRS = hooks parallel sm eventlog
Ian Lynagh's avatar
Ian Lynagh committed
30

Ian Lynagh's avatar
Ian Lynagh committed
31
ifeq "$(HostOS_CPP)" "mingw32"
Ian Lynagh's avatar
Ian Lynagh committed
32 33 34 35 36
ALL_DIRS += win32
else
ALL_DIRS += posix
endif

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

41 42
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
43

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

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

rts_AUTO_APPLY_CMM = rts/dist/build/AutoApply.cmm

$(rts_AUTO_APPLY_CMM): $(GENAPPLY_INPLACE)
58
	"$(GENAPPLY_INPLACE)" >$@
Ian Lynagh's avatar
Ian Lynagh committed
59

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

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

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

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

77 78 79 80 81 82 83

# ----------------------------------------------------------------------------
# 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.
#
84
ifeq "$(HostOS_CPP)" "mingw32" 
85 86 87 88

ALL_RTS_DEF_LIBNAMES 	= base ghc-prim
ALL_RTS_DEF_LIBS	= \
	rts/dist/build/win32/libHSbase.dll.a \
89
	rts/dist/build/win32/libHSghc-prim.dll.a
90 91 92 93 94 95

# -- 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)/" \
96
		| sed "s/@ProjectVersion@/$$(ProjectVersion)/" \
97
		> rts/dist/build/win32/libHS$1.def
98

99 100 101 102 103 104 105
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))))
endif

106 107 108
ifneq "$(BINDIST)" "YES"
rts_ffi_objs_stamp = rts/dist/ffi/stamp
rts_ffi_objs       = rts/dist/ffi/*.o
109
$(rts_ffi_objs_stamp): $(libffi_STATIC_LIB) $(TOUCH_DEP) | $$(dir $$@)/.
110
	cd rts/dist/ffi && $(AR) x ../../../$(libffi_STATIC_LIB)
111
	"$(TOUCH_CMD)" $@
112 113 114 115 116

# This is a little hacky. We don't know the SO version, so we only
# depend on libffi.so, but copy libffi.so*
rts/dist/build/libffi$(soext): libffi/build/inst/lib/libffi$(soext)
	cp libffi/build/inst/lib/libffi$(soext)* rts/dist/build
117

Ian Lynagh's avatar
Ian Lynagh committed
118
rts/dist/build/$(LIBFFI_DLL): libffi/build/inst/bin/$(LIBFFI_DLL)
119
	cp $< $@
120
endif
121

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

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

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

137 138 139 140 141 142
ifneq "$$(findstring dyn, $1)" ""
ifeq "$$(HostOS_CPP)" "mingw32" 
rts_dist_$1_CC_OPTS += -DCOMPILING_WINDOWS_DLL
endif
endif

Ian Lynagh's avatar
Ian Lynagh committed
143 144 145 146 147 148 149
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)
150
$(call hs-suffix-rules-srcdir,rts,dist,$1,.)
151
# hs-suffix-rules-srcdir is needed when BootingFromHc to get the .hc rules
Ian Lynagh's avatar
Ian Lynagh committed
152

153 154
rts_$1_LIB_NAME = libHSrts$$($1_libsuf)
rts_$1_LIB = rts/dist/build/$$(rts_$1_LIB_NAME)
Ian Lynagh's avatar
Ian Lynagh committed
155 156 157

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))
158
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
159 160 161

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

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)
Ian Lynagh's avatar
Ian Lynagh committed
170
	$(DTRACE) -G -C $$(addprefix -I,$$(GHC_INCLUDE_DIRS)) -DDTRACE -s rts/RtsProbes.d -o \
171 172 173 174
		$$@ $$(rts_$1_OBJS)
endif
endif

175
rts_dist_$1_CC_OPTS += -DRtsWay=\"rts_$1\"
176

177
# Making a shared library for the RTS.
178
ifneq "$$(findstring dyn, $1)" ""
179
ifeq "$$(HostOS_CPP)" "mingw32" 
Ian Lynagh's avatar
Ian Lynagh committed
180
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(ALL_RTS_DEF_LIBS) rts/libs.depend rts/dist/build/$$(LIBFFI_DLL)
181
	"$$(RM)" $$(RM_OPTS) $$@
182
	"$$(rts_dist_HC)" -package-name rts -shared -dynamic -dynload deploy \
Ian Lynagh's avatar
Ian Lynagh committed
183
	  -no-auto-link-packages -Lrts/dist/build -l$(LIBFFI_WINDOWS_LIB) `cat rts/libs.depend` $$(rts_$1_OBJS) $$(ALL_RTS_DEF_LIBS) -o $$@
184
else
185
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS) rts/libs.depend rts/dist/build/libffi$$(soext)
186
	"$$(RM)" $$(RM_OPTS) $$@
187
	"$$(rts_dist_HC)" -package-name rts -shared -dynamic -dynload deploy \
188
	  -no-auto-link-packages -Lrts/dist/build -lffi `cat rts/libs.depend` $$(rts_$1_OBJS) \
189
	  $$(rts_$1_DTRACE_OBJS) -o $$@
190
endif
191
else
Ian Lynagh's avatar
Ian Lynagh committed
192
$$(rts_$1_LIB) : $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS) $$(rts_ffi_objs_stamp)
193
	"$$(RM)" $$(RM_OPTS) $$@
Ian Lynagh's avatar
Ian Lynagh committed
194
	echo $$(rts_ffi_objs) $$(rts_$1_OBJS) $$(rts_$1_DTRACE_OBJS) | "$$(XARGS)" $$(XARGS_OPTS) "$$(AR_STAGE1)" \
195
		$$(AR_OPTS_STAGE1) $$(EXTRA_AR_ARGS_STAGE1) $$@
196
endif
Ian Lynagh's avatar
Ian Lynagh committed
197

198 199
endif

Ian Lynagh's avatar
Ian Lynagh committed
200 201 202 203 204 205 206 207
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
208
# We like plenty of warnings.
209 210 211 212 213 214
WARNING_OPTS += -Wall
ifeq "$(GccLT34)" "YES"
WARNING_OPTS += -W
else
WARNING_OPTS += -Wextra
endif
Ian Lynagh's avatar
Ian Lynagh committed
215 216 217 218 219
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
220 221 222 223 224 225 226
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
227 228 229 230
#WARNING_OPTS += -Wbad-function-cast
#WARNING_OPTS += -Wshadow
#WARNING_OPTS += -Wcast-qual

231 232 233 234 235 236 237 238 239
# 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

Ian Lynagh's avatar
Ian Lynagh committed
240
STANDARD_OPTS += $(addprefix -I,$(GHC_INCLUDE_DIRS)) -Irts -Irts/dist/build
Ian Lynagh's avatar
Ian Lynagh committed
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 277
# 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
278 279
rts_CC_OPTS += -fno-common

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

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

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

293 294
rts/RtsMessages_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
rts/RtsUtils_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
295
rts/Trace_CC_OPTS += -DProjectVersion=\"$(ProjectVersion)\"
Ian Lynagh's avatar
Ian Lynagh committed
296
#
297 298 299 300
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
301
#
302 303 304 305
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
306
#
307 308 309 310
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
311
#
312 313
rts/RtsUtils_CC_OPTS += -DGhcUnregisterised=\"$(GhcUnregisterised)\"
rts/RtsUtils_CC_OPTS += -DGhcEnableTablesNextToCode=\"$(GhcEnableTablesNextToCode)\"
Ian Lynagh's avatar
Ian Lynagh committed
314

315 316 317 318
ifeq "$(DYNAMIC_BY_DEFAULT)" "YES"
rts/Linker_CC_OPTS += -DDYNAMIC_BY_DEFAULT
endif

319 320 321 322 323 324 325 326 327 328
# 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.
329
#
330 331
# This apparently doesn't work on OS X (Darwin) nor on Solaris.
# On Darwin we get errors of the form
332 333 334 335 336 337 338
#
#  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
#
339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357
# 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

358
ifeq "$(TargetArch_CPP)" "i386"
359
ifeq "$(i386_SPEED_HACK)" "YES"
360 361 362 363 364 365 366 367 368 369 370 371 372 373 374
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
375
endif
376

Ian Lynagh's avatar
Ian Lynagh committed
377
# ffi.h triggers prototype warnings, so disable them here:
378 379 380
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
381 382

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

Simon Marlow's avatar
Simon Marlow committed
385
# emits warnings about call-clobbered registers on x86_64
386
rts/StgCRun_CC_OPTS += -w
Simon Marlow's avatar
Simon Marlow committed
387

388 389
rts/RetainerProfile_CC_OPTS += -w
rts/RetainerSet_CC_OPTS += -Wno-format
Ian Lynagh's avatar
Ian Lynagh committed
390
# On Windows:
391 392
rts/win32/ConsoleHandler_CC_OPTS += -w
rts/win32/ThrIOManager_CC_OPTS += -w
Ian Lynagh's avatar
Ian Lynagh committed
393 394 395 396 397 398 399
# 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)
400
rts/sm/Compact_CC_OPTS += -finline-limit=2500
Ian Lynagh's avatar
Ian Lynagh committed
401 402

# -O3 helps unroll some loops (especially in copy() with a constant argument).
403 404
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
405 406 407

# These files are just copies of sm/Evac.c and sm/Scav.c respectively,
# but compiled with -DPARALLEL_GC.
408 409
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
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 437 438 439 440 441

#-----------------------------------------------------------------------------
# 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
442
rts_dist_depfile_base = rts/dist/build/.depend$(rts_WAYS_DASHED)
Ian Lynagh's avatar
Ian Lynagh committed
443

Simon Marlow's avatar
Simon Marlow committed
444
rts_dist_C_SRCS  = $(rts_C_SRCS) $(rts_thr_EXTRA_C_SRCS)
Ian Lynagh's avatar
Ian Lynagh committed
445
rts_dist_S_SRCS =  $(rts_S_SRCS)
Simon Marlow's avatar
Simon Marlow committed
446
rts_dist_C_FILES = $(rts_C_SRCS) $(rts_thr_EXTRA_C_SRCS) $(rts_S_SRCS)
Ian Lynagh's avatar
Ian Lynagh committed
447

448 449 450 451 452 453 454
# 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

455
ifeq "$(USE_DTRACE)" "YES"
456 457 458 459 460

rts_dist_MKDEPENDC_OPTS += -Irts/dist/build

endif

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

463
$(rts_dist_depfile_c_asm) : $(libffi_HEADERS) $(DTRACEPROBES_H)
Ian Lynagh's avatar
Ian Lynagh committed
464

465 466 467
# -----------------------------------------------------------------------------
# compile dtrace probes if dtrace is supported

468
ifeq "$(USE_DTRACE)" "YES"
469 470 471 472

rts_CC_OPTS		+= -DDTRACE
rts_HC_OPTS		+= -DDTRACE

473 474 475 476 477
# 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.

478 479 480 481 482 483
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
484

485 486 487
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 $<
488 489
endif

Ian Lynagh's avatar
Ian Lynagh committed
490 491 492 493 494 495 496 497 498 499 500 501 502 503
# -----------------------------------------------------------------------------
# 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))

504
ifneq "$(BootingFromHc)" "YES"
Ian Lynagh's avatar
Ian Lynagh committed
505
rts/package.conf.inplace : $(includes_H_CONFIG) $(includes_H_PLATFORM)
506
endif
Ian Lynagh's avatar
Ian Lynagh committed
507 508 509 510

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

511 512 513
RTS_INSTALL_LIBS += $(ALL_RTS_LIBS)
RTS_INSTALL_LIBS += $(wildcard rts/dist/build/libffi$(soext)*)
RTS_INSTALL_LIBS += $(wildcard rts/dist/build/$(LIBFFI_DLL))
Ian Lynagh's avatar
Ian Lynagh committed
514

515 516 517 518 519 520 521
install: install_libffi_headers

.PHONY: install_libffi_headers
install_libffi_headers :
	$(call INSTALL_DIR,"$(DESTDIR)$(ghcheaderdir)")
	$(call INSTALL_HEADER,$(INSTALL_OPTS),$(libffi_HEADERS),"$(DESTDIR)$(ghcheaderdir)/")

Ian Lynagh's avatar
Ian Lynagh committed
522 523 524 525 526 527 528
# -----------------------------------------------------------------------------
# cleaning

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

BINDIST_EXTRAS += rts/package.conf.in