1 # -----------------------------------------------------------------------------
2 # Main compiler Makefile
6 # all builds stage1 compiler
8 # boot stage=N generate build dirs and dependencies for stage N.
9 # NB. Must be done before 'make stageN'.
10 # NB. Cannot 'make boot stage=2' until stage1 has
11 # been built (similarly for stage3).
13 # stage1 (or stage=1) builds stage1 compiler
14 # stage2 (or stage=2) builds stage2 compiler
15 # stage3 (or stage=3) builds stage3 compiler
20 # Use GHC for compiling C bits (NB. must be before boilerplate include)
24 # We don't want to compile stage1 in multiple ways
25 ifeq "$(findstring $(stage), 2 3)" ""
29 include $(TOP)/mk/boilerplate.mk
31 ifeq "$(GhcThreaded)$(GhcProfiled)" "YESYES"
32 $(error Cannot make GHC both threaded and profiled)
36 #-----------------------------------------------------------------------------
37 # Counting source code lines
39 USER_SRCS = $(filter-out $(DERIVED_SRCS),$(SRCS))
41 ./count_lines $(USER_SRCS)
43 # -----------------------------------------------------------------------------
46 # The stage1/stage2/stage3 business is quite delicate. Here's how it works:
48 # - the variable $(stage) holds the current stage number. To build a
49 # particular stage, you say 'make stage=N' where N is 1, 2, or 3.
52 # - for stage N, object files and .hi files are placed inside
53 # the directory stageN, in subdirectories as per the sources.
55 # - .hi-boot files are *linked* into the stageN tree, because in GHC 5.05+
56 # the .hi-boot file must reside in the same place as the .hi file.
58 # - we use explicit -o and -ohi options to direct the output from C &
59 # Haskell compilations.
61 # - we generate a different .depend file for each build. They need to be
62 # different, because each stage might include different files: stage1
63 # might not include GHCi, for example. For each stage, a normal .depend
64 # file is generated, and then post-processed to add the correct stageN/
65 # prefix to each object and .hi filename. The resulting .depend file
66 # is named .depend-$(stage). See the end of this Makefile for details.
68 # - normal implicit rules don't work any more, because they're of the form
72 # whereas we really need
76 # so suffix.mk now defines the appropriate suffix rules when
77 # $(odir) is set to a non-empty value. Here we set $(odir) to
78 # stage1, stage2, or stage3.
80 # There are other plausible designs that might work, but each has different
83 # - using -odir and -hidir: GHC <= 4.08 doesn't support -hidir, and
84 # anyway -odir puts all the objects in one directory (strips off the
85 # subdirectory part), which eventually forces us to use VPATH to find
86 # the sources. I have a really bad feeling about VPATH.
88 # - invoke make in the stageN subdirectory. This probably requires VPATH
91 # - create a link tree. The problem with requiring link trees is that
92 # Windows doesn't support symbolic links.
100 $(MKDIRHIER) stage$(stage)
101 for i in $(ALL_DIRS); do \
102 $(MKDIRHIER) stage$(stage)/$$i; \
108 ifneq "$(findstring $(stage), 2 3)" ""
116 # On Windows, we can't use symbolic links for the -hi-boot files
117 # because GHC itself is a Mingw program and does not understand
118 # symbolic links. So we have to copy the files instead of link them.
119 # That means that if you modify a .hi-boot file in Windows, you
120 # have to to say 'make boot' again.
122 # PS: 'ln -s foo baz' takes 'foo' relative to the path to 'baz'
123 # whereas 'cp foo baz' treats the two paths independently.
124 # Hence the "../.." in the ln command line
125 ifeq "$(UsingHsBoot)" "NO"
126 ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
127 for i in */*hi-boot*; do \
128 cp -u -f $$i stage$(stage)/$$i; \
131 for i in */*hi-boot*; do \
132 ($(RM) -f stage$(stage)/$$i \
133 && $(LN_S) ../../$$i stage$(stage)/$$i) || true ; \
161 SRC_HC_OPTS += $(patsubst %, -i$(odir)/%, $(ALL_DIRS))
163 SRC_HC_OPTS += -Wall -fno-warn-name-shadowing
164 # Turn off orphan warnings, but only if the flag exists (i.e. not if we
165 # are building stage 1 and using GHC < 6.3).
166 ifneq "$(stage)" "1 NO"
167 SRC_HC_OPTS += -fno-warn-orphans
170 HS_OBJS = $(patsubst %, $(odir)/%, $(addsuffix .$(way_)o,$(basename $(HS_SRCS))))
171 C_OBJS = $(patsubst %, $(odir)/%, $(addsuffix .$(way_)o,$(basename $(C_SRCS))))
173 # Our standard cleaning rules don't know that we're doing our output
174 # into $(odir), so we have to augment CLEAN_FILES appropriateliy.
176 CLEAN_FILES += $(odir)/*/*.$(way_)hi $(odir)/*/*.$(way_)hi-boot $(odir)/*/*.$(way_)o-boot
178 ifeq "$(UsingHsBoot)" "YES"
179 CLEAN_FILES += $(odir)/*/*.hi-boot $(odir)/*/*.o-boot
183 mostlyclean clean distclean maintainer-clean ::
188 # -----------------------------------------------------------------------------
191 # Note: there have been reports of people running up against the ARG_MAX limit
192 # when linking ghc with all its constituent object files. The likely source of
193 # the problem is that the environment is a bit too big, so a workaround could
194 # be to do `env PATH=$(PATH) make ghc' to minimise the environment. (or the
195 # equivalent of `env' if it doesn't exist locally).
197 ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
198 GHC_PROG=$(odir)/ghc$(_way)-$(ProjectVersion)
200 GHC_PROG=$(odir)/ghc$(_way)
204 HS_PROG = $(GHC_PROG)
207 # -----------------------------------------------------------------------------
208 # Create compiler configuration
210 # The 'echo' commands simply spit the values of various make variables
211 # into Config.hs, whence they can be compiled and used by GHC itself
213 CONFIG_HS = main/Config.hs
216 $(CONFIG_HS) : $(FPTOOLS_TOP)/mk/config.mk
217 @$(RM) -f $(CONFIG_HS)
218 @echo "Creating $(CONFIG_HS) ... "
219 @echo "module Config where" >>$(CONFIG_HS)
220 @echo "cProjectName :: String" >> $(CONFIG_HS)
221 @echo "cProjectName = \"$(ProjectName)\"" >> $(CONFIG_HS)
222 @echo "cProjectVersion :: String" >> $(CONFIG_HS)
223 @echo "cProjectVersion = \"$(ProjectVersion)\"" >> $(CONFIG_HS)
224 @echo "cProjectVersionInt :: String" >> $(CONFIG_HS)
225 @echo "cProjectVersionInt = \"$(ProjectVersionInt)\"" >> $(CONFIG_HS)
226 @echo "cProjectPatchLevel :: String" >> $(CONFIG_HS)
227 @echo "cProjectPatchLevel = \"$(ProjectPatchLevel)\"" >> $(CONFIG_HS)
228 @echo "cBooterVersion :: String" >> $(CONFIG_HS)
229 @echo "cBooterVersion = \"$(GhcVersion)\"" >> $(CONFIG_HS)
230 @echo "cStage :: String" >> $(CONFIG_HS)
231 @echo "cStage = STAGE" >> $(CONFIG_HS)
232 @echo "cHscIfaceFileVersion :: String" >> $(CONFIG_HS)
233 @echo "cHscIfaceFileVersion = \"$(HscIfaceFileVersion)\"" >> $(CONFIG_HS)
234 @echo "cSplitObjs :: String" >> $(CONFIG_HS)
235 @echo "cSplitObjs = \"$(SplitObjs)\"" >> $(CONFIG_HS)
236 @echo "cGhcWithInterpreter :: String" >> $(CONFIG_HS)
237 @echo "cGhcWithInterpreter = \"$(GhcWithInterpreter)\"" >> $(CONFIG_HS)
238 @echo "cGhcWithNativeCodeGen :: String" >> $(CONFIG_HS)
239 @echo "cGhcWithNativeCodeGen = \"$(GhcWithNativeCodeGen)\"" >> $(CONFIG_HS)
240 @echo "cGhcWithSMP :: String" >> $(CONFIG_HS)
241 @echo "cGhcWithSMP = \"$(GhcWithSMP)\"" >> $(CONFIG_HS)
242 @echo "cGhcRTSWays :: String" >> $(CONFIG_HS)
243 @echo "cGhcRTSWays = \"$(GhcRTSWays)\"" >> $(CONFIG_HS)
244 @echo "cGhcUnregisterised :: String" >> $(CONFIG_HS)
245 @echo "cGhcUnregisterised = \"$(GhcUnregisterised)\"" >> $(CONFIG_HS)
246 @echo "cGhcEnableTablesNextToCode :: String" >> $(CONFIG_HS)
247 @echo "cGhcEnableTablesNextToCode = \"$(GhcEnableTablesNextToCode)\"" >> $(CONFIG_HS)
248 @echo "cLeadingUnderscore :: String" >> $(CONFIG_HS)
249 @echo "cLeadingUnderscore = \"$(LeadingUnderscore)\"" >> $(CONFIG_HS)
250 @echo "cRAWCPP_FLAGS :: String" >> $(CONFIG_HS)
251 @echo "cRAWCPP_FLAGS = \"$(RAWCPP_FLAGS)\"" >> $(CONFIG_HS)
252 @echo "cGCC :: String" >> $(CONFIG_HS)
253 @echo "cGCC = \"$(WhatGccIsCalled)\"" >> $(CONFIG_HS)
254 @echo "cMKDLL :: String" >> $(CONFIG_HS)
255 @echo "cMKDLL = \"$(BLD_DLL)\"" >> $(CONFIG_HS)
256 @echo "cLdIsGNULd :: String" >> $(CONFIG_HS)
257 @echo "cLdIsGNULd = \"$(LdIsGNULd)\"" >> $(CONFIG_HS)
258 @echo "cLD_X :: String" >> $(CONFIG_HS)
259 @echo "cLD_X = \"$(LD_X)\"" >> $(CONFIG_HS)
260 @echo "cGHC_DRIVER_DIR_REL :: String" >> $(CONFIG_HS)
261 @echo "cGHC_DRIVER_DIR_REL = \"$(GHC_DRIVER_DIR_REL)\"" >> $(CONFIG_HS)
262 @echo "cGHC_TOUCHY_PGM :: String" >> $(CONFIG_HS)
263 @echo "cGHC_TOUCHY_PGM = \"$(GHC_TOUCHY_PGM)\"" >> $(CONFIG_HS)
264 @echo "cGHC_TOUCHY_DIR_REL :: String" >> $(CONFIG_HS)
265 @echo "cGHC_TOUCHY_DIR_REL = \"$(GHC_TOUCHY_DIR_REL)\"" >> $(CONFIG_HS)
266 @echo "cGHC_UNLIT_PGM :: String" >> $(CONFIG_HS)
267 @echo "cGHC_UNLIT_PGM = \"$(GHC_UNLIT_PGM)\"" >> $(CONFIG_HS)
268 @echo "cGHC_UNLIT_DIR_REL :: String" >> $(CONFIG_HS)
269 @echo "cGHC_UNLIT_DIR_REL = \"$(GHC_UNLIT_DIR_REL)\"" >> $(CONFIG_HS)
270 @echo "cGHC_MANGLER_PGM :: String" >> $(CONFIG_HS)
271 @echo "cGHC_MANGLER_PGM = \"$(GHC_MANGLER_PGM)\"" >> $(CONFIG_HS)
272 @echo "cGHC_MANGLER_DIR_REL :: String" >> $(CONFIG_HS)
273 @echo "cGHC_MANGLER_DIR_REL = \"$(GHC_MANGLER_DIR_REL)\"" >> $(CONFIG_HS)
274 @echo "cGHC_SPLIT_PGM :: String" >> $(CONFIG_HS)
275 @echo "cGHC_SPLIT_PGM = \"$(GHC_SPLIT_PGM)\"" >> $(CONFIG_HS)
276 @echo "cGHC_SPLIT_DIR_REL :: String" >> $(CONFIG_HS)
277 @echo "cGHC_SPLIT_DIR_REL = \"$(GHC_SPLIT_DIR_REL)\"" >> $(CONFIG_HS)
278 @echo "cGHC_SYSMAN_PGM :: String" >> $(CONFIG_HS)
279 @echo "cGHC_SYSMAN_PGM = \"$(GHC_SYSMAN)\"" >> $(CONFIG_HS)
280 @echo "cGHC_SYSMAN_DIR_REL :: String" >> $(CONFIG_HS)
281 @echo "cGHC_SYSMAN_DIR_REL = \"$(GHC_SYSMAN_DIR)\"" >> $(CONFIG_HS)
282 @echo "cGHC_CP :: String" >> $(CONFIG_HS)
283 @echo "cGHC_CP = \"$(GHC_CP)\"" >> $(CONFIG_HS)
284 @echo "cGHC_PERL :: String" >> $(CONFIG_HS)
285 @echo "cGHC_PERL = \"$(GHC_PERL)\"" >> $(CONFIG_HS)
286 ifeq ($(GhcWithIlx),YES)
287 @echo "cILX2IL :: String" >> $(CONFIG_HS)
288 @echo "cILX2IL = \"$(ILX2IL)\"" >> $(CONFIG_HS)
289 @echo "cILASM :: String" >> $(CONFIG_HS)
290 @echo "cILASM = \"$(ILASM)\"" >> $(CONFIG_HS)
292 @echo "cEnableWin32DLLs :: String" >> $(CONFIG_HS)
293 @echo "cEnableWin32DLLs = \"$(EnableWin32DLLs)\"" >> $(CONFIG_HS)
294 @echo "cCONTEXT_DIFF :: String" >> $(CONFIG_HS)
295 @echo "cCONTEXT_DIFF = \"$(CONTEXT_DIFF)\"" >> $(CONFIG_HS)
296 @echo "cUSER_WAY_NAMES :: String" >> $(CONFIG_HS)
297 @echo "cUSER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> $(CONFIG_HS)
298 @echo "cUSER_WAY_OPTS :: String" >> $(CONFIG_HS)
299 @echo "cUSER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> $(CONFIG_HS)
300 @echo "cDEFAULT_TMPDIR :: String" >> $(CONFIG_HS)
301 @echo "cDEFAULT_TMPDIR = \"$(DEFAULT_TMPDIR)\"" >> $(CONFIG_HS)
302 @echo "cRelocatableBuild :: Bool" >> $(CONFIG_HS)
303 ifeq "$(RelocatableBuild)" "YES"
304 @echo "cRelocatableBuild = True" >> $(CONFIG_HS)
306 @echo "cRelocatableBuild = False" >> $(CONFIG_HS)
308 @echo "cLibFFI :: Bool" >> $(CONFIG_HS)
309 ifeq "$(UseLibFFIForAdjustors)" "YES"
310 @echo "cLibFFI = True" >> $(CONFIG_HS)
312 @echo "cLibFFI = False" >> $(CONFIG_HS)
316 CLEAN_FILES += $(CONFIG_HS)
318 # -----------------------------------------------------------------------------
319 # Create platform includes
321 # Here we generate a little header file containing CPP symbols that GHC
322 # uses to determine which platform it is building on/for. The platforms
323 # can differ between stage1 and stage2 if we're cross-compiling, so we
324 # need one of these header files per stage.
326 PLATFORM_H = ghc_boot_platform.h
328 stage1/$(PLATFORM_H) : stage_dirs $(FPTOOLS_TOP)/mk/config.mk
329 @echo "Creating $@..."
331 @echo "#ifndef __PLATFORM_H__" >$@
332 @echo "#define __PLATFORM_H__" >>$@
334 @echo "#define BuildPlatform_NAME \"$(BUILDPLATFORM)\"" >> $@
335 @echo "#define HostPlatform_NAME \"$(HOSTPLATFORM)\"" >> $@
336 @echo "#define TargetPlatform_NAME \"$(TARGETPLATFORM)\"" >> $@
338 @echo "#define $(BuildPlatform_CPP)_BUILD 1" >> $@
339 @echo "#define $(HostPlatform_CPP)_HOST 1" >> $@
340 @echo "#define $(TargetPlatform_CPP)_TARGET 1" >> $@
342 @echo "#define $(BuildArch_CPP)_BUILD_ARCH 1" >> $@
343 @echo "#define $(HostArch_CPP)_HOST_ARCH 1" >> $@
344 @echo "#define $(TargetArch_CPP)_TARGET_ARCH 1" >> $@
345 @echo "#define BUILD_ARCH \"$(BuildArch_CPP)\"" >> $@
346 @echo "#define HOST_ARCH \"$(HostArch_CPP)\"" >> $@
347 @echo "#define TARGET_ARCH \"$(TargetArch_CPP)\"" >> $@
349 @echo "#define $(BuildOS_CPP)_BUILD_OS 1" >> $@
350 @echo "#define $(HostOS_CPP)_HOST_OS 1" >> $@
351 @echo "#define $(TargetOS_CPP)_TARGET_OS 1" >> $@
352 @echo "#define BUILD_OS \"$(BuildOS_CPP)\"" >> $@
353 @echo "#define HOST_OS \"$(HostOS_CPP)\"" >> $@
354 @echo "#define TARGET_OS \"$(TargetOS_CPP)\"" >> $@
355 ifeq "$(HostOS_CPP)" "irix"
356 @echo "#ifndef $(IRIX_MAJOR)_TARGET_OS " >> $@
357 @echo "#define $(IRIX_MAJOR)_TARGET_OS 1" >> $@
358 @echo "#endif " >> $@
361 @echo "#define $(BuildVendor_CPP)_BUILD_VENDOR 1" >> $@
362 @echo "#define $(HostVendor_CPP)_HOST_VENDOR 1" >> $@
363 @echo "#define $(TargetVendor_CPP)_TARGET_VENDOR 1" >> $@
364 @echo "#define BUILD_VENDOR \"$(BuildVendor_CPP)\"" >> $@
365 @echo "#define HOST_VENDOR \"$(HostVendor_CPP)\"" >> $@
366 @echo "#define TARGET_VENDOR \"$(TargetVendor_CPP)\"" >> $@
368 @echo "#endif /* __PLATFORM_H__ */" >> $@
371 # For stage2 and above, the BUILD platform is the HOST of stage1, and
372 # the HOST platform is the TARGET of stage1. The TARGET remains the same
373 # (stage1 is the cross-compiler, not stage2).
374 stage2/$(PLATFORM_H) : stage_dirs $(FPTOOLS_TOP)/mk/config.mk
375 @echo "Creating $@..."
377 @echo "#ifndef __PLATFORM_H__" >$@
378 @echo "#define __PLATFORM_H__" >>$@
380 @echo "#define BuildPlatform_NAME \"$(HOSTPLATFORM)\"" >> $@
381 @echo "#define HostPlatform_NAME \"$(TARGETPLATFORM)\"" >> $@
382 @echo "#define TargetPlatform_NAME \"$(TARGETPLATFORM)\"" >> $@
384 @echo "#define $(HostPlatform_CPP)_BUILD 1" >> $@
385 @echo "#define $(TargetPlatform_CPP)_HOST 1" >> $@
386 @echo "#define $(TargetPlatform_CPP)_TARGET 1" >> $@
388 @echo "#define $(HostArch_CPP)_BUILD_ARCH 1" >> $@
389 @echo "#define $(TargetArch_CPP)_HOST_ARCH 1" >> $@
390 @echo "#define $(TargetArch_CPP)_TARGET_ARCH 1" >> $@
391 @echo "#define BUILD_ARCH \"$(HostArch_CPP)\"" >> $@
392 @echo "#define HOST_ARCH \"$(TargetArch_CPP)\"" >> $@
393 @echo "#define TARGET_ARCH \"$(TargetArch_CPP)\"" >> $@
395 @echo "#define $(HostOS_CPP)_BUILD_OS 1" >> $@
396 @echo "#define $(TargetOS_CPP)_HOST_OS 1" >> $@
397 @echo "#define $(TargetOS_CPP)_TARGET_OS 1" >> $@
398 @echo "#define BUILD_OS \"$(HostOS_CPP)\"" >> $@
399 @echo "#define HOST_OS \"$(TargetOS_CPP)\"" >> $@
400 @echo "#define TARGET_OS \"$(TargetOS_CPP)\"" >> $@
401 ifeq "$(HostOS_CPP)" "irix"
402 @echo "#ifndef $(IRIX_MAJOR)_TARGET_OS " >> $@
403 @echo "#define $(IRIX_MAJOR)_TARGET_OS 1" >> $@
404 @echo "#endif " >> $@
407 @echo "#define $(HostVendor_CPP)_BUILD_VENDOR 1" >> $@
408 @echo "#define $(TargetVendor_CPP)_HOST_VENDOR 1" >> $@
409 @echo "#define $(TargetVendor_CPP)_TARGET_VENDOR 1" >> $@
410 @echo "#define BUILD_VENDOR \"$(HostVendor_CPP)\"" >> $@
411 @echo "#define HOST_VENDOR \"$(TargetVendor_CPP)\"" >> $@
412 @echo "#define TARGET_VENDOR \"$(TargetVendor_CPP)\"" >> $@
414 @echo "#endif /* __PLATFORM_H__ */" >> $@
417 stage3/$(PLATFORM_H) : stage_dirs stage2/$(PLATFORM_H)
418 $(CP) stage2/$(PLATFORM_H) stage3/$(PLATFORM_H)
420 STAGE_PLATFORM_H = stage$(stage)/$(PLATFORM_H)
422 boot :: $(STAGE_PLATFORM_H)
424 SRC_HC_OPTS += -Istage$(stage)
426 # -----------------------------------------------------------------------------
429 # First figure out ALL_DIRS, the source sub-directories
432 utils basicTypes types hsSyn prelude rename typecheck deSugar coreSyn \
433 vectorise specialise simplCore stranal stgSyn simplStg codeGen main \
434 profiling parser cprAnalysis iface cmm
436 # Make sure we include Config.hs even if it doesn't exist yet...
437 ALL_SRCS += $(CONFIG_HS)
439 # HsGeneric.hs is not used just now
440 EXCLUDED_SRCS += hsSyn/HsGeneric.hs
442 ifeq ($(GhcWithNativeCodeGen),YES)
443 ALL_DIRS += nativeGen
445 SRC_HC_OPTS += -DOMIT_NATIVE_CODEGEN
448 ifeq ($(GhcWithIlx),YES)
453 ifeq ($(GhcWithJavaGen),YES)
455 SRC_HC_OPTS += -DJAVA
458 ifeq "$(BootingFromHc)" "YES"
459 # HC files are always from a self-booted compiler
462 ifneq "$(findstring $(stage), 2 3)" ""
469 # Beyond stage 1, honour any Mac OS X depolyment target options. If we use
470 # these options in stage 1 we get a linker error if the bootstrap compiler is
471 # for a more recent OS version
472 ifneq "$(findstring $(stage), 2 3)" ""
473 SRC_CC_OPTS += $(MACOSX_DEPLOYMENT_CC_OPTS)
474 SRC_HC_OPTS += $(addprefix -optc, $(MACOSX_DEPLOYMENT_CC_OPTS))
475 SRC_LD_OPTS += $(addprefix -optl, $(MACOSX_DEPLOYMENT_LD_OPTS))
478 # -----------------------------------------------------------------------------
479 # Building a compiler with interpreter support
481 # The interpreter, GHCi interface, Template Haskell and Hpc are only
482 # enabled when we are bootstrapping with the same version of GHC, and
483 # the interpreter is supported on this platform.
485 ifeq "$(bootstrapped)" "YES"
486 SRC_HC_OPTS += -package bytestring
487 PKG_DEPENDS += bytestring
490 SRC_HC_OPTS += -package hpc
493 ifeq "$(GhcWithInterpreter) $(bootstrapped)" "YES YES"
495 # Yes, include the interepreter and Template Haskell extensions
496 SRC_HC_OPTS += -DGHCI -package template-haskell
497 PKG_DEPENDS += template-haskell
499 # Should GHCI be building info tables in the TABLES_NEXT_TO_CODE style
501 ifeq "$(GhcEnableTablesNextToCode) $(GhcUnregisterised)" "YES NO"
502 SRC_HC_OPTS += -DGHCI_TABLES_NEXT_TO_CODE
505 ifeq "$(GhcThreaded)" "YES"
506 # Use threaded RTS with GHCi, so threads don't get blocked at the prompt.
507 SRC_LD_OPTS += -threaded
509 ifeq "$(GhcProfiled)" "YES"
512 ifeq "$(GhcDebugged)" "YES"
513 SRC_LD_OPTS += -debug
516 SRC_HC_OPTS += -I$(FPTOOLS_TOP)/libffi/build/include
517 SRC_HSC2HS_OPTS += -I$(FPTOOLS_TOP)/libffi/build/include
521 # If we are going to use dynamic libraries instead of .o files for ghci,
522 # we will need to always retain CAFs in the compiler.
523 # ghci/keepCAFsForGHCi contains a GNU C __attribute__((constructor))
524 # function which sets the keepCAFs flag for the RTS before any Haskell
526 ifeq "$(GhcBuildDylibs)" "YES"
528 EXCLUDED_SRCS += ghci/keepCAFsForGHCi.c
531 # Enable editline if either:
532 # - we're building stage 1 and $(GhcHasEditline)="YES"
533 # - we're building stage 2/3, and we have built the editline package
535 # But we don't enable editline on Windows, as Windows terminals have
536 # editline-like support builtin.
538 ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
540 ifeq "$(GhcHasEditline)" "YES"
541 SRC_HC_OPTS += -package editline -DUSE_EDITLINE
542 PKG_DEPENDS += editline
545 ifeq "$(wildcard $(FPTOOLS_TOP_ABS)/libraries/editline/unbuildable)" ""
546 SRC_HC_OPTS += -package editline -DUSE_EDITLINE
547 PKG_DEPENDS += editline
554 # No interpreter, so exclude Template Haskell modules
555 EXCLUDED_SRCS += deSugar/DsMeta.hs typecheck/TcSplice.lhs hsSyn/Convert.lhs
557 endif # bootstrapped with interpreter
559 # -----------------------------------------------
562 # Big Fudge to get around inherent problem that Makefile setup
563 # has got with 'mkdependC'.
565 SRC_MKDEPENDC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt)
567 # XXX not really correct, hschooks.c actually gets include files like
568 # RtsFlags.c from the installed GHC, but we can't tell mkdependC about that.
569 SRC_MKDEPENDC_OPTS += -I$(GHC_INCLUDE_DIR)
571 # -----------------------------------------------------------------------------
572 # Haskell compilations
574 SRC_HC_OPTS += -cpp -fglasgow-exts -Rghc-timing -I. -Iparser -Iutil
576 ifeq "$(ghc_ge_609)" "NO"
577 SRC_HC_OPTS += -fno-generics
579 SRC_HC_OPTS += -XNoGenerics
582 # Omitted: -I$(GHC_INCLUDE_DIR)
583 # We should have -I$(GHC_INCLUDE_DIR) in SRC_HC_OPTS,
584 # to avoid the use of an explicit path in GHC source files
585 # (include "../includes/config.h"
586 # But alas GHC 4.08 (and others for all I know) uses this very
587 # same include path when compiling the .hc files it generates.
588 # Disaster! Then the hc file sees the GHC 5.02 (or whatever)
589 # include files. For the moment we've reverted to using
590 # an explicit path in the .hs sources
592 # For the benefit of <5.00 compilers, do include GHC_INCLUDE_DIR
593 # when generating dependencies. (=> it gets passed onto mkdependHS,
595 SRC_MKDEPENDHS_OPTS += -I$(GHC_INCLUDE_DIR)
597 # We need System.Posix (or Posix when ghc < 6.2)
598 ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
599 ifeq "$(bootstrapped)" "YES"
600 SRC_HC_OPTS += -package Win32
604 SRC_HC_OPTS += -package unix
608 SRC_HC_OPTS += -package Cabal
611 # Ignore lang, to avoid potential clash with the Generics module if
612 # lang happens to be a dependency of some exposed package in the local
613 # GHC installation (eg. wxHaskell did this around 6.4).
614 SRC_HC_OPTS += -ignore-package lang
616 SRC_CC_OPTS += -Iparser -I. -O
617 SRC_HC_OPTS += $(GhcHcOpts) $(GhcStage$(stage)HcOpts)
620 ifeq "$(BootingFromHc)" "YES"
621 SRC_CC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt)
624 # Special flags for particular modules
625 # The standard suffix rule for compiling a Haskell file
626 # adds these flags to the command line
628 # There used to be a -fforce-recomp flag on PrimOp, but why?
629 # It's an expensive module to recompile!
630 prelude/PrimOp_HC_OPTS = -H80m
633 main/ParsePkgConf_HC_OPTS += -fno-warn-incomplete-patterns
634 parser/Parser_HC_OPTS += -fno-warn-incomplete-patterns
636 # Careful optimisation of the parser: we don't want to throw everything
637 # at it, because that takes too long and doesn't buy much, but we do want
638 # to inline certain key external functions, so we instruct GHC not to
639 # throw away inlinings as it would normally do in -O0 mode:
640 parser/Parser_HC_OPTS += -O0 -fno-ignore-interface-pragmas
642 ifeq "$(HOSTPLATFORM)" "hppa1.1-hp-hpux9"
643 rename/RnMonad_HC_OPTS = -O2 -O2-for-C
646 # basicTypes/SrcLoc_HC_OPTS = -funbox-strict-fields
648 # ---- Profiling ----
649 #simplCore/Simplify_HC_OPTS = -auto-all
650 #simplCore/SimplEnv_HC_OPTS = -auto-all
651 #simplCore/SimplUtils_HC_OPTS = -auto-all
653 # CSE interacts badly with top-level IORefs (reportedly in DriverState and
654 # DriverMkDepend), causing some of them to be commoned up. We have a fix for
655 # this in 5.00+, but earlier versions of the compiler will need CSE turned off.
656 # To be on the safe side, we disable CSE in *all* modules with top-level IORefs.
657 ghci/InteractiveUI_HC_OPTS = -fno-cse
658 main/CmdLineOpts_HC_OPTS = -fno-cse
659 main/DriverMkDepend_HC_OPTS = -fno-cse
660 main/DriverPipeline_HC_OPTS = -fno-cse
661 main/Finder_HC_OPTS = -fno-cse
662 main/SysTools_HC_OPTS = -fno-cse
663 main/StaticFlags_HC_OPTS = -fno-cse
665 # The #include is vital for the via-C route, else the C
666 # compiler doesn't realise that the stcall foreign imports are indeed
667 # stdcall, and doesn't generate the Foo@8 name for them
668 ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
669 main/SysTools_HC_OPTS += '-\#include <windows.h>' '-\#include <process.h>'
672 parser/Lexer_HC_OPTS += -funbox-strict-fields
674 # ghc_strlen percolates through so many modules that it is easier to get its
675 # prototype via a global option instead of a myriad of per-file OPTIONS
676 SRC_HC_OPTS += '-\#include "cutils.h"'
678 ifeq "$(ghc_ge_605)" "NO"
679 utils/LazyUniqFM_HC_OPTS += -fallow-undecidable-instances
682 # ----------------------------------------------------------------------------
683 # Generate supporting stuff for prelude/PrimOp.lhs
684 # from prelude/primops.txt
686 PRIMOP_BITS=primop-data-decl.hs-incl \
688 primop-list.hs-incl \
689 primop-has-side-effects.hs-incl \
690 primop-out-of-line.hs-incl \
691 primop-commutable.hs-incl \
692 primop-needs-wrapper.hs-incl \
693 primop-can-fail.hs-incl \
694 primop-strictness.hs-incl \
695 primop-primop-info.hs-incl
697 CLEAN_FILES += prelude/primops.txt
698 CLEAN_FILES += $(PRIMOP_BITS)
700 SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR)
701 SRC_CPP_OPTS += ${GhcCppOpts}
703 ifneq "$(BootingFromHc)" "YES"
704 prelude/PrimOp.lhs $(odir)/prelude/PrimOp.o: $(PRIMOP_BITS)
707 ifneq "$(BootingFromHc)" "YES"
708 depend :: $(PRIMOP_BITS)
711 # This is an ugly hack: we need stage1/$(PLATFORM_H) built before we
712 # preprocess primops.txt.pp, but we don't want to just add that
713 # dependency because we don't want $(PLATFORM_H) built during normal
714 # operations, because we don't have have dependencies from the .hs
715 # sources on it, and we don't want those dependencies because that
716 # would cause everything to be rebuilt every time the Makefile
717 # changed. So here we add the required dependency only when making
719 ifneq "$(findstring boot, $(MAKECMDGOALS))$(findstring depend, $(MAKECMDGOALS))" ""
720 prelude/primops.txt.pp : stage1/$(PLATFORM_H)
723 primop-data-decl.hs-incl: prelude/primops.txt
724 $(GENPRIMOP) --data-decl < $< > $@
725 primop-tag.hs-incl: prelude/primops.txt
726 $(GENPRIMOP) --primop-tag < $< > $@
727 primop-list.hs-incl: prelude/primops.txt
728 $(GENPRIMOP) --primop-list < $< > $@
729 primop-has-side-effects.hs-incl: prelude/primops.txt
730 $(GENPRIMOP) --has-side-effects < $< > $@
731 primop-out-of-line.hs-incl: prelude/primops.txt
732 $(GENPRIMOP) --out-of-line < $< > $@
733 primop-commutable.hs-incl: prelude/primops.txt
734 $(GENPRIMOP) --commutable < $< > $@
735 primop-needs-wrapper.hs-incl: prelude/primops.txt
736 $(GENPRIMOP) --needs-wrapper < $< > $@
737 primop-can-fail.hs-incl: prelude/primops.txt
738 $(GENPRIMOP) --can-fail < $< > $@
739 primop-strictness.hs-incl: prelude/primops.txt
740 $(GENPRIMOP) --strictness < $< > $@
741 primop-primop-info.hs-incl: prelude/primops.txt
742 $(GENPRIMOP) --primop-primop-info < $< > $@
744 # Usages aren't used any more; but the generator
745 # can still generate them if we want them back
746 primop-usage.hs-incl: prelude/primops.txt
747 $(GENPRIMOP) --usage < $< > $@
750 #-----------------------------------------------------------------------------
753 ifeq "$(GhcUnregisterised)" "NO"
754 ifeq "$(HOSTPLATFORM)" "ia64-unknown-linux"
755 # needed for generating proper relocation in large binaries: trac #856
756 SRC_LD_OPTS += -optl-Wl,--relax
760 # -----------------------------------------------------------------------------
761 # create ghc-inplace, a convenient way to run ghc from the build tree...
762 # See comments in $(FPTOOLS_TOP)/utils/ghc-pkg/Makefile for why we use
763 # a real binary here rather than a shell script.
765 INPLACE_SRC = $(odir)/ghc-inplace.c
766 INPLACE_PROG = $(odir)/ghc-inplace$(_way)$(exeext)
767 INPLACE_EXTRA_FLAGS = -I$(TOP)/includes
768 EXCLUDED_C_SRCS += ghc-inplace.c
770 CLEAN_FILES += $(INPLACE_SRC)
772 GHC_PATH=$(FPTOOLS_TOP_ABS)/$(GHC_COMPILER_DIR_REL)/$(GHC_PROG)$(exeext)
774 $(INPLACE_PROG): ghc-inplace.c
775 $(SED) -e "s@GHC_PATH@$(GHC_PATH)@g" -e "s@TOP_ABS@$(FPTOOLS_TOP_ABS)@g" < $< > $(INPLACE_SRC)
776 $(HC) -cpp $(INPLACE_EXTRA_FLAGS) $(INPLACE_SRC) -o $@
778 all :: $(INPLACE_PROG)
780 CLEAN_FILES += $(INPLACE_PROG)
783 ghc-inplace : $(INPLACE_PROG)
784 $(RM) -f $@ && $(LN_S) $< $@
788 CLEAN_FILES += ghc-inplace
791 #-----------------------------------------------------------------------------
794 # We don't want ghc treated as an ordinary executable,
795 # but put it together with the libraries.
796 # Also don't want any interface files installed
798 DESTDIR = $(INSTALL_LIBRARY_DIR_GHC)
800 ifneq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
801 INSTALL_LIBEXECS += $(GHC_PROG)
803 INSTALL_PROGS += $(GHC_PROG)
806 # ----------------------------------------------------------------------------
809 # rename/RnBinds_HC_OPTS += -auto-all
810 # rename/RnEnv_HC_OPTS += -auto-all
811 # rename/RnExpr_HC_OPTS += -auto-all
812 # rename/RnHiFiles_HC_OPTS += -auto-all
813 # rename/RnHsSyn_HC_OPTS += -auto-all
814 # rename/Rename_HC_OPTS += -auto-all
815 # rename/RnIfaces_HC_OPTS += -auto-all
816 # rename/RnNames_HC_OPTS += -auto-all
817 # rename/RnSource_HC_OPTS += -auto-all
818 # rename/RnTypes_HC_OPTS += -auto-all
820 # typecheck/Inst_HC_OPTS += -auto-all
821 # typecheck/TcBinds_HC_OPTS += -auto-all
822 # typecheck/TcClassDcl_HC_OPTS += -auto-all
823 # typecheck/TcDefaults_HC_OPTS += -auto-all
824 # typecheck/TcDeriv_HC_OPTS += -auto-all
825 # typecheck/TcEnv_HC_OPTS += -auto-all
826 # typecheck/TcExpr_HC_OPTS += -auto-all
827 # typecheck/TcForeign_HC_OPTS += -auto-all
828 # typecheck/TcGenDeriv_HC_OPTS += -auto-all
829 # typecheck/TcHsSyn_HC_OPTS += -auto-all
830 # typecheck/TcIfaceSig_HC_OPTS += -auto-all
831 # typecheck/TcInstDcls_HC_OPTS += -auto-all
832 # typecheck/TcMatches_HC_OPTS += -auto-all
833 # typecheck/TcMonoType_HC_OPTS += -auto-all
834 # typecheck/TcMType_HC_OPTS += -auto-all
835 # typecheck/TcPat_HC_OPTS += -auto-all
836 # typecheck/TcRnDriver_HC_OPTS += -auto-all
837 # #typecheck/TcRnMonad_HC_OPTS += -auto-all
838 # #typecheck/TcRnTypes_HC_OPTS += -auto-all
839 # typecheck/TcRules_HC_OPTS += -auto-all
840 # typecheck/TcSimplify_HC_OPTS += -auto-all
841 # typecheck/TcSplice_HC_OPTS += -auto-all
842 # typecheck/TcTyClsDecls_HC_OPTS += -auto-all
843 # typecheck/TcTyDecls_HC_OPTS += -auto-all
844 # typecheck/TcType_HC_OPTS += -auto-all
845 # typecheck/TcUnify_HC_OPTS += -auto-all
847 # coreSyn/CorePrep_HC_OPTS += -auto-all
849 #-----------------------------------------------------------------------------
850 # Building the GHC package
852 # The GHC package is made from the stage 2 build and later.
853 # Fortunately the package build system framework more or less does the
854 # right thing for us here.
856 ifneq "$(findstring $(stage), 2 3)" ""
857 BUILD_GHC_PACKAGE=YES
860 ifeq "$(BUILD_GHC_PACKAGE)" "YES"
862 HIERARCHICAL_LIB = NO
863 VERSION = $(ProjectVersion)
864 PKG_DEPENDS += base haskell98
865 LIB_LD_OPTS += $(foreach pkg,$(PKG_DEPENDS),-package $(pkg))
866 # We have to expand each package dependency with its version, which we
867 # can do by calling "ghc-pkg list $pkg --simple-output".
868 PACKAGE_CPP_OPTS += -DPKG_DEPENDS='$(foreach pkg,$(PKG_DEPENDS),$(shell $(GHC_PKG_INPLACE) latest --global $(pkg)))'
869 # We want to define STAGE to be like "2" in the Haskell code, so we need
870 # to quote the "s so that they don't get interpreted by the shell.
871 PACKAGE_CPP_OPTS += -DSTAGE='"$(stage)"'
873 # Omit Main from the library, the client will want to plug their own Main in
874 LIBOBJS = $(filter-out $(odir)/main/Main.$(way_)o $(odir)/parser/hschooks.$(way_)o, $(OBJS))
876 # disable splitting: it won't really help with GHC, and the specialised
877 # build system for compiler/ isn't set up to handle it.
880 # the package build system likes to set WAYS=$(GhcLibWays), but we don't
881 # really want to build the whole of GHC multiple ways... if you do,
882 # set GhcCompilerWays instead.
883 GhcLibWays = $(GhcCompilerWays)
885 # override $(GhcLibHcOpts): we want GhcStage2HcOpts to take precedence
888 ifeq "$(DOING_BIN_DIST)" "YES"
889 # This is derived from the sources when we are in a source tree, but we
890 # don't have any sources in a bindist, so we have to shortcut it
891 HS_IFACES := $(wildcard stage$(stage)/*/*.hi)
893 # override default definition of HS_IFACES so we can add $(odir)
894 HS_IFACES = $(addsuffix .$(way_)hi,$(basename $(HS_OBJS)))
897 # Haddock can't handle recursive modules currently, so we disable it for now.
898 override HADDOCK_DOCS = NO
900 # Tell package.mk not to set $(HC)
903 # The stage 2 GHC binary itself is built by compiling main/Main.hs
904 # (the same as used in stage 1) against the GHC package.
906 # This is done by compiling Main.hs separately and linking it with
907 # -package ghc. This is done using a separate Makefile, Makefile.ghcbin
908 # Why? See comments in Makefile.ghcbin
910 # The stage 2 and stage 3 package.conf.in files are different, because they
911 # point to either the stage2/ or stage3/ dirs in import-dirs. Hence before
912 # linking the ghc binary we must install the correct version of the package
913 # configuration. Yeuch... maybe one day this will all be done more cleanly.
914 STAMP_PKG_CONF = $(GHC_DRIVER_DIR)/stamp-pkg-conf-$(PACKAGE)
916 # Propagate standard targets to Makefile.ghcbin
917 docs runtests $(BOOT_TARGET) TAGS clean distclean mostlyclean maintainer-clean $(INSTALL_TARGET) $(INSTALL_DOCS_TARGET) html chm HxS ps dvi txt::
918 $(MAKE) -f Makefile.ghcbin $(MFLAGS) $@
921 #-----------------------------------------------------------------------------
924 MAINTAINER_CLEAN_FILES += parser/Parser.info main/ParsePkgConf.info
926 #-----------------------------------------------------------------------------
927 # Include target-rule boilerplate
929 # Don't use the default MKDEPENDHS stuff... we'll do our own, below
933 # Make doesn't work this out for itself, it seems
934 parser/Parser.y : parser/Parser.y.pp
935 EXTRA_SRCS += parser/Parser.y
938 #-----------------------------------------------------------------------------
939 # Source files for tags file generation
941 # We want to excluded derived sources, because they won't be in the source
942 # tree, which is where we are going to move the TAGS file to.a
944 TAGS_HS_SRCS = parser/Parser.y.pp $(filter-out $(DERIVED_SRCS) main/Config.hs parser/Parser.y, $(sort $(SRCS)))
946 WRONG_GHCTAGS_HS_SRCS = $(filter-out $(DERIVED_SRCS) main/Config.hs parser/Parser.y, $(sort $(SRCS)))
947 # above is wrong because of the following problem:
948 # module `main:DataCon' is defined in multiple files: basicTypes/DataCon.lhs
949 # basicTypes/DataCon.lhs-boot
951 GHCTAGS_HS_SRCS = $(HS_SRCS)
952 GHCTAGS_HC_OPTS = $(patsubst -i$(odir)/%, -i%, $(HC_OPTS))
953 GHCTAGS_HC_OPTS += -DSTAGE='"$(stage)"'
955 #------------------------------------------------------------
960 ghctags :: $(GHCTAGS_HS_SRCS) $(TAGS_C_SRCS)
961 @if [ "$(stage)" != 2 ]; then echo "Must use 'make stage=2 ghctags'"; exit 1; fi
964 @echo SOURCES ARE "$(GHCTAGS_HS_SRCS)"
965 : ifneq "$(GHCTAGS_HS_SRCS)" ""
966 @echo TIME TO ROCK AND ROLL
967 # $(GHCTAGS_INPLACE) -- $(MKDEPENDHS_OPTS) $(filter-out -split-objs, $(MKDEPENDHS_HC_OPTS)) -- $(GHCTAGS_HS_SRCS)
968 $(GHCTAGS_INPLACE) -- $(GHCTAGS_HC_OPTS) -- $(GHCTAGS_HS_SRCS)
970 ifneq "$(TAGS_C_SRCS)" ""
971 etags -a $(TAGS_C_SRCS)
973 @( DEREFFED=`ls -l Makefile | sed -e 's/.*-> \(.*\)/\1/g'` && $(RM) `dirname $$DEREFFED`/TAGS && $(CP) TAGS `dirname $$DEREFFED` ) 2>/dev/null || echo TAGS file generated, perhaps copy over to source tree?
975 include $(TOP)/mk/target.mk
977 ifeq "$(BUILD_GHC_PACKAGE)" "YES"
981 $(odir)/main/Config.$(way_)o: SRC_HC_OPTS+=-DSTAGE='"$(stage)"'
983 ifneq "$(findstring $(stage), 2 3)" ""
984 $(warning LIBRARY is $(LIBRARY))
986 ifneq "$(DOING_BIN_DIST)" "YES"
987 $(GHC_PROG) : $(LIBRARY) main/Main.hs
988 $(RM) package.conf.inplace
989 $(RM) $(STAMP_PKG_CONF)
990 $(MAKE) way="" $(STAMP_PKG_CONF)
991 $(MAKE) -f Makefile.ghcbin $(MFLAGS) HS_PROG=$(GHC_PROG) $@
996 #-----------------------------------------------------------------------------
1000 $(INSTALL_DIR) $(BIN_DIST_DIR)/compiler
1001 $(INSTALL_DIR) $(BIN_DIST_DIR)/compiler/stage$(stage)
1002 echo "stage=$(stage)" > $(BIN_DIST_DIR)/compiler/Makefile
1003 cat Makefile >> $(BIN_DIST_DIR)/compiler/Makefile
1004 $(INSTALL_DATA) package.conf.in $(BIN_DIST_DIR)/compiler/
1005 set -e; for d in stage$(stage)/*/; do $(INSTALL_DIR) $(BIN_DIST_DIR)/compiler/$$d; done
1006 set -e; for f in $(HS_IFACES); do $(INSTALL_DATA) $$f $(BIN_DIST_DIR)/compiler/$$f; done
1007 ifneq "$(INSTALL_LIBS)" ""
1008 set -e; for f in $(INSTALL_LIBS); do $(INSTALL_DATA) $$f $(BIN_DIST_DIR)/compiler/$$f; done
1010 ifneq "$(INSTALL_PROGS)" ""
1011 set -e; for f in $(INSTALL_PROGS); do $(INSTALL_PROGRAM) $$f $(BIN_DIST_DIR)/compiler/$$f; done
1013 ifneq "$(INSTALL_LIBEXECS)" ""
1014 set -e; for f in $(INSTALL_LIBEXECS); do $(INSTALL_PROGRAM) $$f $(BIN_DIST_DIR)/compiler/$$f; done
1017 # -----------------------------------------------------------------------------
1018 # Explicit dependencies
1020 # Some .hs files #include other source files, but since ghc -M doesn't spit out
1021 # these dependencies we have to include them manually.
1023 # We don't add dependencies on HsVersions.h, ghcautoconf.h, or ghc_boot_platform.h,
1024 # because then modifying one of these files would force recompilation of everything,
1025 # which is probably not what you want. However, it does mean you have to be
1026 # careful to recompile stuff you need if you reconfigure or change HsVersions.h.
1028 # Aargh, these don't work properly anyway, because GHC's recompilation checker
1029 # just reports "compilation NOT required". Do we have to add -fforce-recomp for each
1030 # of these .hs files? I haven't done anything about this yet.
1032 $(odir)/codeGen/Bitmap.$(way_)o : ../includes/MachDeps.h
1033 $(odir)/codeGen/CgCallConv.$(way_)o : ../includes/StgFun.h
1034 $(odir)/codeGen/CgProf.$(way_)o : ../includes/MachDeps.h
1035 $(odir)/codeGen/CgProf.$(way_)o : ../includes/Constants.h
1036 $(odir)/codeGen/CgProf.$(way_)o : ../includes/DerivedConstants.h
1037 $(odir)/codeGen/CgTicky.$(way_)o : ../includes/DerivedConstants.h
1038 $(odir)/codeGen/ClosureInfo.$(way_)o : ../includes/MachDeps.h
1039 $(odir)/codeGen/SMRep.$(way_)o : ../includes/MachDeps.h
1040 $(odir)/codeGen/SMRep.$(way_)o : ../includes/ClosureTypes.h
1041 $(odir)/ghci/ByteCodeAsm.$(way_)o : ../includes/Bytecodes.h
1042 $(odir)/ghci/ByteCodeFFI.$(way_)o : nativeGen/NCG.h
1043 $(odir)/ghci/ByteCodeInstr.$(way_)o : ../includes/MachDeps.h
1044 $(odir)/ghci/ByteCodeItbls.$(way_)o : ../includes/ClosureTypes.h
1045 $(odir)/ghci/ByteCodeItbls.$(way_)o : nativeGen/NCG.h
1046 $(odir)/main/Constants.$(way_)o : ../includes/MachRegs.h
1047 $(odir)/main/Constants.$(way_)o : ../includes/Constants.h
1048 $(odir)/main/Constants.$(way_)o : ../includes/MachDeps.h
1049 $(odir)/main/Constants.$(way_)o : ../includes/DerivedConstants.h
1050 $(odir)/main/Constants.$(way_)o : ../includes/GHCConstants.h
1051 $(odir)/nativeGen/AsmCodeGen.$(way_)o : nativeGen/NCG.h
1052 $(odir)/nativeGen/MachCodeGen.$(way_)o : nativeGen/NCG.h
1053 $(odir)/nativeGen/MachCodeGen.$(way_)o : ../includes/MachDeps.h
1054 $(odir)/nativeGen/MachInstrs.$(way_)o : nativeGen/NCG.h
1055 $(odir)/nativeGen/MachRegs.$(way_)o : nativeGen/NCG.h
1056 $(odir)/nativeGen/MachRegs.$(way_)o : ../includes/MachRegs.h
1057 $(odir)/nativeGen/PositionIndependentCode.$(way_)o : nativeGen/NCG.h
1058 $(odir)/nativeGen/PprMach.$(way_)o : nativeGen/NCG.h
1059 $(odir)/nativeGen/RegAllocInfo.$(way_)o : nativeGen/NCG.h
1060 $(odir)/typecheck/TcForeign.$(way_)o : nativeGen/NCG.h
1061 $(odir)/utils/Binary.$(way_)o : ../includes/MachDeps.h
1062 $(odir)/utils/FastMutInt.$(way_)o : ../includes/MachDeps.h
1064 # -----------------------------------------------------------------------------
1067 MKDEPENDHS_HC_OPTS = $(patsubst -i$(odir)/%, -i%, $(HC_OPTS))
1071 # Must do this *after* including target.mk, because $(HS_SRCS) isn't set yet.
1072 depend :: $(STAGE_PLATFORM_H) $(HS_SRCS) $(C_SRCS)
1074 ifneq "$(BootingFromHc)" "YES"
1075 $(MKDEPENDHS) -M -optdep-f -optdep.depend-BASE $(foreach way,$(WAYS),-optdep-s -optdep$(way)) $(foreach obj,$(MKDEPENDHS_OBJ_SUFFICES),-osuf $(obj)) $(MKDEPENDHS_OPTS) $(filter-out -split-objs, $(MKDEPENDHS_HC_OPTS)) $(HS_SRCS)
1077 $(MKDEPENDC) -f .depend-BASE $(MKDEPENDC_OPTS) $(foreach way,$(WAYS),-s $(way)) -- $(CC_OPTS) -- $(C_SRCS)
1078 $(PERL) -pe 'binmode(stdin); binmode(stdout); s@(\S*[._]o)@stage$(stage)/$$1@g; s@(\S*[._]hi)@stage$(stage)/$$1@g;' <.depend-BASE >.depend-$(stage)
1079 # The binmode stuff tells perl not to add stupid ^M's to the output
1081 ifeq "$(MakefileDeps)" "YES"
1082 $(CONFIG_HS) : Makefile
1083 stage1/$(PLATFORM_H) : Makefile
1084 stage2/$(PLATFORM_H) : Makefile
1087 -include .depend-$(stage)