1 # -----------------------------------------------------------------------------
2 # Main ghc/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 include $(TOP)/mk/boilerplate.mk
26 #-----------------------------------------------------------------------------
27 # Counting source code lines
29 USER_SRCS = $(filter-out $(DERIVED_SRCS),$(SRCS))
31 ./count_lines $(USER_SRCS)
33 #-----------------------------------------------------------------------------
34 # Building ghc different ways (default is just `normal' sequential)
36 WAYS=$(GhcCompilerWays)
38 # -----------------------------------------------------------------------------
41 # The stage1/stage2/stage3 business is quite delicate. Here's how it works:
43 # - the variable $(stage) holds the current stage number. To build a
44 # particular stage, you say 'make stage=N' where N is 1, 2, or 3.
47 # - for stage N, object files and .hi files are placed inside
48 # the directory stageN, in subdirectories as per the sources.
50 # - .hi-boot files are *linked* into the stageN tree, because in GHC 5.05+
51 # the .hi-boot file must reside in the same place as the .hi file.
53 # - we use explicit -o and -ohi options to direct the output from C &
54 # Haskell compilations.
56 # - we generate a different .depend file for each build. They need to be
57 # different, because each stage might include different files: stage1
58 # might not include GHCi, for example. For each stage, a normal .depend
59 # file is generated, and then post-processed to add the correct stageN/
60 # prefix to each object and .hi filename. The resulting .depend file
61 # is named .depend-$(stage). See the end of this Makefile for details.
63 # - normal implicit rules don't work any more, because they're of the form
67 # whereas we really need
71 # so suffix.mk now defines the appropriate suffix rules when
72 # $(odir) is set to a non-empty value. Here we set $(odir) to
73 # stage1, stage2, or stage3.
75 # There are other plausible designs that might work, but each has different
78 # - using -odir and -hidir: GHC <= 4.08 doesn't support -hidir, and
79 # anyway -odir puts all the objects in one directory (strips off the
80 # subdirectory part), which eventually forces us to use VPATH to find
81 # the sources. I have a really bad feeling about VPATH.
83 # - invoke make in the stageN subdirectory. This probably requires VPATH
86 # - create a link tree. The problem with requiring link trees is that
87 # Windows doesn't support symbolic links.
90 $(MKDIRHIER) stage$(stage)
91 for i in $(ALL_DIRS); do \
92 $(MKDIRHIER) stage$(stage)/$$i; \
94 # On Windows, we can't use symbolic links for the -hi-boot files
95 # because GHC itself is a Mingw program and does not understand
96 # symbolic links. So we have to copy the files instead of link them.
97 # That means that if you modify a .hi-boot file in Windows, you
98 # have to to say 'make boot' again.
100 # PS: 'ln -s foo baz' takes 'foo' relative to the path to 'baz'
101 # whereas 'cp foo baz' treats the two paths independently.
102 # Hence the "../.." in the ln command line
103 ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
104 for i in */*hi-boot*; do \
105 cp -u -f $$i stage$(stage)/$$i; \
108 for i in */*hi-boot*; do \
109 $(LN_S) -f ../../$$i stage$(stage)/$$i || true ; \
140 SRC_HC_OPTS += $(patsubst %, -i$(odir)/%, $(ALL_DIRS))
142 HS_OBJS = $(patsubst %, $(odir)/%, $(addsuffix .$(way_)o,$(basename $(HS_SRCS))))
143 C_OBJS = $(patsubst %, $(odir)/%, $(addsuffix .$(way_)o,$(basename $(C_SRCS))))
145 CLEAN_FILES += $(odir)/*/*.hi
148 mostlyclean clean distclean maintainer-clean ::
153 # -----------------------------------------------------------------------------
156 # Note: there have been reports of people running up against the ARG_MAX limit
157 # when linking ghc with all its constituent object files. The likely source of
158 # the problem is that the environment is a bit too big, so a workaround could
159 # be to do `env PATH=$(PATH) make ghc' to minimise the environment. (or the
160 # equivalent of `env' if it doesn't exist locally).
163 ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
164 HS_PROG=$(odir)/ghc$(_way)-$(ProjectVersion)
166 HS_PROG=$(odir)/ghc$(_way)
169 HS_PROG=$(odir)/ghc-$(ProjectVersion)
172 # -----------------------------------------------------------------------------
173 # Create compiler configuration
175 # The 'echo' commands simply spit the values of various make variables
176 # into Config.hs, whence they can be compiled and used by GHC itself
178 CONFIG_HS = main/Config.hs
181 $(CONFIG_HS) : $(FPTOOLS_TOP)/mk/config.mk Makefile
182 @$(RM) -f $(CONFIG_HS)
183 @echo "Creating $(CONFIG_HS) ... "
184 @echo "module Config where" >>$(CONFIG_HS)
185 @echo "cProjectName = \"$(ProjectName)\"" >> $(CONFIG_HS)
186 @echo "cProjectVersion = \"$(ProjectVersion)\"" >> $(CONFIG_HS)
187 @echo "cProjectVersionInt = \"$(ProjectVersionInt)\"" >> $(CONFIG_HS)
188 @echo "cProjectPatchLevel = \"$(ProjectPatchLevel)\"" >> $(CONFIG_HS)
189 @echo "cBooterVersion = \"$(GhcVersion)\"" >> $(CONFIG_HS)
190 @echo "cHscIfaceFileVersion = \"$(HscIfaceFileVersion)\"" >> $(CONFIG_HS)
191 @echo "cHOSTPLATFORM = \"$(HOSTPLATFORM)\"" >> $(CONFIG_HS)
192 @echo "cTARGETPLATFORM = \"$(TARGETPLATFORM)\"" >> $(CONFIG_HS)
193 @echo "cGhcWithNativeCodeGen = \"$(GhcWithNativeCodeGen)\"" >> $(CONFIG_HS)
194 @echo "cGhcUnregisterised = \"$(GhcUnregisterised)\"" >> $(CONFIG_HS)
195 @echo "cLeadingUnderscore = \"$(LeadingUnderscore)\"" >> $(CONFIG_HS)
196 @echo "cRAWCPP_FLAGS = \"$(RAWCPP_FLAGS)\"" >> $(CONFIG_HS)
197 @echo "cGCC = \"$(WhatGccIsCalled)\"" >> $(CONFIG_HS)
198 @echo "cMKDLL = \"$(BLD_DLL)\"" >> $(CONFIG_HS)
199 @echo "cPROJECT_DIR = \"$(PROJECT_DIR)\"" >> $(CONFIG_HS)
200 @echo "cGHC_DRIVER_DIR_REL = \"$(GHC_DRIVER_DIR_REL)\"" >> $(CONFIG_HS)
201 @echo "cGHC_TOUCHY_PGM = \"$(GHC_TOUCHY_PGM)\"" >> $(CONFIG_HS)
202 @echo "cGHC_TOUCHY_DIR_REL = \"$(GHC_TOUCHY_DIR_REL)\"" >> $(CONFIG_HS)
203 @echo "cGHC_UNLIT_PGM = \"$(GHC_UNLIT_PGM)\"" >> $(CONFIG_HS)
204 @echo "cGHC_UNLIT_DIR_REL = \"$(GHC_UNLIT_DIR_REL)\"" >> $(CONFIG_HS)
205 @echo "cGHC_MANGLER_PGM = \"$(GHC_MANGLER_PGM)\"" >> $(CONFIG_HS)
206 @echo "cGHC_MANGLER_DIR_REL = \"$(GHC_MANGLER_DIR_REL)\"" >> $(CONFIG_HS)
207 @echo "cGHC_SPLIT_PGM = \"$(GHC_SPLIT_PGM)\"" >> $(CONFIG_HS)
208 @echo "cGHC_SPLIT_DIR_REL = \"$(GHC_SPLIT_DIR_REL)\"" >> $(CONFIG_HS)
209 @echo "cGHC_SYSMAN_PGM = \"$(GHC_SYSMAN)\"" >> $(CONFIG_HS)
210 @echo "cGHC_SYSMAN_DIR_REL = \"$(GHC_SYSMAN_DIR)\"" >> $(CONFIG_HS)
211 @echo "cGHC_CP = \"$(GHC_CP)\"" >> $(CONFIG_HS)
212 @echo "cGHC_PERL = \"$(GHC_PERL)\"" >> $(CONFIG_HS)
213 ifeq ($(GhcWithIlx),YES)
214 @echo "cILX2IL = \"$(ILX2IL)\"" >> $(CONFIG_HS)
215 @echo "cILASM = \"$(ILASM)\"" >> $(CONFIG_HS)
217 @echo "cEnableWin32DLLs = \"$(EnableWin32DLLs)\"" >> $(CONFIG_HS)
218 @echo "cCONTEXT_DIFF = \"$(CONTEXT_DIFF)\"" >> $(CONFIG_HS)
219 @echo "cUSER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> $(CONFIG_HS)
220 @echo "cUSER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> $(CONFIG_HS)
221 @echo "cDEFAULT_TMPDIR = \"$(DEFAULT_TMPDIR)\"" >> $(CONFIG_HS)
224 CLEAN_FILES += $(CONFIG_HS)
226 # -----------------------------------------------------------------------------
229 # First figure out ALL_DIRS, the source sub-directories
232 utils basicTypes types hsSyn prelude rename typecheck deSugar coreSyn \
233 specialise simplCore stranal stgSyn simplStg codeGen absCSyn main \
234 profiling parser cprAnalysis compMan ndpFlatten cbits iface
236 # Make sure we include Config.hs even if it doesn't exist yet...
237 ALL_SRCS += $(CONFIG_HS)
239 # HsGeneric.hs is not used just now
240 EXCLUDED_SRCS += hsSyn/HsGeneric.hs
242 ifeq ($(GhcWithNativeCodeGen),YES)
243 ALL_DIRS += nativeGen
245 SRC_HC_OPTS += -DOMIT_NATIVE_CODEGEN
248 ifeq ($(GhcWithIlx),YES)
253 ifeq ($(GhcWithJavaGen),YES)
255 SRC_HC_OPTS += -DJAVA
258 ifeq "$(BootingFromHc)" "YES"
259 # HC files are always from a self-booted compiler
261 compiling_with_4xx=NO
263 ifneq "$(findstring $(stage), 2 3)" ""
265 compiling_with_4xx = NO
267 bootstrapped = $(shell if (test $(GhcCanonVersion) -ge $(ProjectVersionInt) -a $(GhcPatchLevel) -ge $(ProjectPatchLevel)); then echo YES; else echo NO; fi)
268 compiling_with_4xx = $(shell if (test $(GhcCanonVersion) -lt 500); then echo YES; else echo NO; fi)
272 # Only include GHCi if we're bootstrapping with at least version 411
273 ifeq "$(GhcWithInterpreter) $(bootstrapped)" "YES YES"
274 # Yes, include the interepreter, readline, and Template Haskell extensions
275 SRC_HC_OPTS += -DGHCI -package haskell-src
276 ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
277 SRC_HC_OPTS += -package unix
278 ifeq "$(GhcLibsWithReadline)" "YES"
279 SRC_HC_OPTS += -package readline
284 # No interpreter, so exclude Template Haskell modules
285 EXCLUDED_SRCS += deSugar/DsMeta.hs typecheck/TcSplice.lhs hsSyn/Convert.lhs
288 # There are some C files to include in HS_PROG, so add these to HS_OBJS
291 # -----------------------------------------------
294 # Big Fudge to get around inherent problem that Makefile setup
295 # has got with 'mkdependC'.
297 SRC_MKDEPENDC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt)
299 # XXX not really correct, hschooks.c actually gets include files like
300 # RtsFlags.c from the installed GHC, but we can't tell mkdependC about that.
301 SRC_MKDEPENDC_OPTS += -I$(GHC_INCLUDE_DIR)
303 # -----------------------------------------------------------------------------
304 # Haskell compilations
307 -cpp -fglasgow-exts -Rghc-timing \
308 -I. -IcodeGen -InativeGen -Iparser
310 # Omitted: -I$(GHC_INCLUDE_DIR)
311 # We should have -I$(GHC_INCLUDE_DIR) in SRC_HC_OPTS,
312 # to avoid the use of an explicit path in GHC source files
313 # (include "../includes/config.h"
314 # But alas GHC 4.08 (and others for all I know) uses this very
315 # same include path when compiling the .hc files it generates.
316 # Disaster! Then the hc file sees the GHC 5.02 (or whatever)
317 # include files. For the moment we've reverted to using
318 # an explicit path in the .hs sources
320 # For the benefit of <5.00 compilers, do include GHC_INCLUDE_DIR
321 # when generating dependencies. (=> it gets passed onto mkdependHS,
323 SRC_MKDEPENDHS_OPTS += -I$(GHC_INCLUDE_DIR)
325 # When bootstrapped, we don't make use of *any* packages
326 # (except possibly readline if GHCi is enabled, see above)
327 ifneq "$(bootstrapped)" "YES"
328 ifneq "$(mingw32_HOST_OS)" "1"
329 SRC_HC_OPTS += -package concurrent -package posix -package util
331 SRC_HC_OPTS += -package concurrent -package util
335 SRC_CC_OPTS += -Iparser -I. -O
336 SRC_HC_OPTS += -recomp $(GhcHcOpts) $(GhcStage$(stage)HcOpts)
339 ifeq "$(BootingFromHc)" "YES"
340 SRC_CC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt)
343 # Special flags for particular modules
344 # The standard suffix rule for compiling a Haskell file
345 # adds these flags to the command line
347 # There used to be a -no-recomp flag on PrimOp, but why?
348 # It's an expensive module to recompile!
349 prelude/PrimOp_HC_OPTS = -H80m
351 # because the NCG can't handle the 64-bit math in here
352 prelude/PrelRules_HC_OPTS = -fvia-C
354 main/ParsePkgConf_HC_OPTS += -fno-warn-incomplete-patterns
355 # Use -fvia-C since the NCG can't handle the narrow16Int# (and intToInt16#?)
356 # primops on all platforms.
357 parser/Parser_HC_OPTS += -Onot -fno-warn-incomplete-patterns -fvia-C
359 # The latest GHC version doesn't have a -K option yet, and it doesn't
360 # seem to be necessary anymore for the modules below.
361 ifeq "$(compiling_with_4xx)" "YES"
362 parser/Parser_HC_OPTS += -K2m
365 ifeq "$(HOSTPLATFORM)" "hppa1.1-hp-hpux9"
366 rename/RnMonad_HC_OPTS = -O2 -O2-for-C
369 utils/Digraph_HC_OPTS = -fglasgow-exts
371 ifeq "$(bootstrapped)" "YES"
372 utils/Binary_HC_OPTS = -funbox-strict-fields
375 # 4.08.2's NCG can't cope with Binary
376 ifeq "$(compiling_with_4xx)" "YES"
377 utils/Binary_HC_OPTS += -fvia-C
380 # ByteCodeItbls uses primops that the NCG doesn't support yet.
381 ghci/ByteCodeItbls_HC_OPTS += -fvia-C
382 ghci/ByteCodeLink_HC_OPTS += -fvia-C -monly-3-regs
384 # BinIface and Binary take ages to both compile and run if you don's use -O
385 main/BinIface_HC_OPTS += -O
386 utils/Binary_HC_OPTS += -O
387 utils/FastMutInt_HC_OPTS += -O
390 # CSE interacts badly with top-level IORefs (reportedly in DriverState and
391 # DriverMkDepend), causing some of them to be commoned up. We have a fix for
392 # this in 5.00+, but earlier versions of the compiler will need CSE turned off.
393 # To be on the safe side, we disable CSE in *all* modules with top-level IORefs.
394 compMan/CompManager_HC_OPTS = -fno-cse
395 ghci/InteractiveUI_HC_OPTS = -fno-cse
396 main/CmdLineOpts_HC_OPTS = -fno-cse
397 main/DriverFlags_HC_OPTS = -fno-cse
398 main/DriverMkDepend_HC_OPTS = -fno-cse
399 main/DriverPipeline_HC_OPTS = -fno-cse
400 main/DriverState_HC_OPTS = -fno-cse
401 main/DriverUtil_HC_OPTS = -fno-cse
402 main/Finder_HC_OPTS = -fno-cse
403 main/SysTools_HC_OPTS = -fno-cse
405 # The #include is vital for the via-C route, else the C
406 # compiler doesn't realise that the stcall foreign imports are indeed
407 # stdcall, and doesn't generate the Foo@8 name for them
408 ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
409 main/SysTools_HC_OPTS += '-\#include <windows.h>' '-\#include <process.h>'
412 # Required due to use of Concurrent.myThreadId
413 utils/Panic_HC_OPTS += -fvia-C
415 parser/Lexer_HC_OPTS += -funbox-strict-fields
417 # ghc_strlen percolates through so many modules that it is easier to get its
418 # prototype via a global option instead of a myriad of per-file OPTIONS
419 SRC_HC_OPTS += '-\#include "hschooks.h"'
421 # ----------------------------------------------------------------------------
422 # Generate supporting stuff for prelude/PrimOp.lhs
423 # from prelude/primops.txt
425 GENPOC=$(TOP)/utils/genprimopcode/genprimopcode
427 PRIMOP_BITS=primop-data-decl.hs-incl \
429 primop-list.hs-incl \
430 primop-has-side-effects.hs-incl \
431 primop-out-of-line.hs-incl \
432 primop-commutable.hs-incl \
433 primop-needs-wrapper.hs-incl \
434 primop-can-fail.hs-incl \
435 primop-strictness.hs-incl \
436 primop-primop-info.hs-incl
438 CLEAN_FILES += prelude/primops.txt
439 CLEAN_FILES += $(PRIMOP_BITS)
441 SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR)
442 SRC_CPP_OPTS += ${GhcCppOpts}
444 ifneq "$(BootingFromHc)" "YES"
445 prelude/PrimOp.lhs $(odir)/prelude/PrimOp.o: $(PRIMOP_BITS)
448 ifneq "$(BootingFromHc)" "YES"
449 depend :: $(PRIMOP_BITS)
452 primop-data-decl.hs-incl: prelude/primops.txt
453 $(GENPOC) --data-decl < $< > $@
454 primop-tag.hs-incl: prelude/primops.txt
455 $(GENPOC) --primop-tag < $< > $@
456 primop-list.hs-incl: prelude/primops.txt
457 $(GENPOC) --primop-list < $< > $@
458 primop-has-side-effects.hs-incl: prelude/primops.txt
459 $(GENPOC) --has-side-effects < $< > $@
460 primop-out-of-line.hs-incl: prelude/primops.txt
461 $(GENPOC) --out-of-line < $< > $@
462 primop-commutable.hs-incl: prelude/primops.txt
463 $(GENPOC) --commutable < $< > $@
464 primop-needs-wrapper.hs-incl: prelude/primops.txt
465 $(GENPOC) --needs-wrapper < $< > $@
466 primop-can-fail.hs-incl: prelude/primops.txt
467 $(GENPOC) --can-fail < $< > $@
468 primop-strictness.hs-incl: prelude/primops.txt
469 $(GENPOC) --strictness < $< > $@
470 primop-primop-info.hs-incl: prelude/primops.txt
471 $(GENPOC) --primop-primop-info < $< > $@
473 # Usages aren't used any more; but the generator
474 # can still generate them if we want them back
475 primop-usage.hs-incl: prelude/primops.txt
476 $(GENPOC) --usage < $< > $@
479 #-----------------------------------------------------------------------------
482 SRC_LD_OPTS += -no-link-chk
484 # -----------------------------------------------------------------------------
485 # create ghc-inplace, a convenient way to run ghc from the build tree...
487 all :: $(odir)/ghc-inplace ghc-inplace
489 $(odir)/ghc-inplace : $(HS_PROG)
491 echo '#!/bin/sh' >>$@
492 echo exec $(FPTOOLS_TOP_ABS)/ghc/compiler/$(HS_PROG) '-B$(subst \,\\,$(FPTOOLS_TOP_ABS_PLATFORM))' '"$$@"' >>$@
495 ghc-inplace : stage1/ghc-inplace
498 CLEAN_FILES += $(odir)/ghc-inplace ghc-inplace
500 #-----------------------------------------------------------------------------
503 # We don't want ghc treated as an ordinary executable,
504 # but put it together with the libraries.
505 # Also don't want any interface files installed
507 DESTDIR = $(INSTALL_LIBRARY_DIR_GHC)
509 ifneq "$(HOSTPLATFORM)" "i386-unknown-mingw32"
510 INSTALL_LIBEXECS += $(HS_PROG)
512 INSTALL_PROGS += $(HS_PROG)
515 # ----------------------------------------------------------------------------
518 # rename/RnBinds_HC_OPTS += -auto-all
519 # rename/RnEnv_HC_OPTS += -auto-all
520 # rename/RnExpr_HC_OPTS += -auto-all
521 # rename/RnHiFiles_HC_OPTS += -auto-all
522 # rename/RnHsSyn_HC_OPTS += -auto-all
523 # rename/Rename_HC_OPTS += -auto-all
524 # rename/RnIfaces_HC_OPTS += -auto-all
525 # rename/RnNames_HC_OPTS += -auto-all
526 # rename/RnSource_HC_OPTS += -auto-all
527 # rename/RnTypes_HC_OPTS += -auto-all
529 # typecheck/Inst_HC_OPTS += -auto-all
530 # typecheck/TcBinds_HC_OPTS += -auto-all
531 # typecheck/TcClassDcl_HC_OPTS += -auto-all
532 # typecheck/TcDefaults_HC_OPTS += -auto-all
533 # typecheck/TcDeriv_HC_OPTS += -auto-all
534 # typecheck/TcEnv_HC_OPTS += -auto-all
535 # typecheck/TcExpr_HC_OPTS += -auto-all
536 # typecheck/TcForeign_HC_OPTS += -auto-all
537 # typecheck/TcGenDeriv_HC_OPTS += -auto-all
538 # typecheck/TcHsSyn_HC_OPTS += -auto-all
539 # typecheck/TcIfaceSig_HC_OPTS += -auto-all
540 # typecheck/TcInstDcls_HC_OPTS += -auto-all
541 # typecheck/TcMatches_HC_OPTS += -auto-all
542 # typecheck/TcMonoType_HC_OPTS += -auto-all
543 # typecheck/TcMType_HC_OPTS += -auto-all
544 # typecheck/TcPat_HC_OPTS += -auto-all
545 # typecheck/TcRnDriver_HC_OPTS += -auto-all
546 # #typecheck/TcRnMonad_HC_OPTS += -auto-all
547 # #typecheck/TcRnTypes_HC_OPTS += -auto-all
548 # typecheck/TcRules_HC_OPTS += -auto-all
549 # typecheck/TcSimplify_HC_OPTS += -auto-all
550 # typecheck/TcSplice_HC_OPTS += -auto-all
551 # typecheck/TcTyClsDecls_HC_OPTS += -auto-all
552 # typecheck/TcTyDecls_HC_OPTS += -auto-all
553 # typecheck/TcType_HC_OPTS += -auto-all
554 # typecheck/TcUnify_HC_OPTS += -auto-all
556 # absCSyn/PprAbsC_HC_OPTS += -auto-all
558 coreSyn/CorePrep_HC_OPTS += -auto-all
560 #-----------------------------------------------------------------------------
563 MAINTAINER_CLEAN_FILES += parser/Parser.info main/ParsePkgConf.info
565 #-----------------------------------------------------------------------------
566 # Include target-rule boilerplate
568 # Don't use the default MKDEPENDHS stuff... we'll do our own, below
572 include $(TOP)/mk/target.mk
574 # -----------------------------------------------------------------------------
577 MKDEPENDHS_HC_OPTS = $(patsubst -i$(odir)/%, -i%, $(HC_OPTS))
581 # Must do this *after* including target.mk, because $(HS_SRCS) isn't set yet.
582 depend :: $(HS_SRCS) $(C_SRCS)
584 ifneq "$(BootingFromHc)" "YES"
585 $(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)
587 $(MKDEPENDC) -f .depend-BASE $(MKDEPENDC_OPTS) $(foreach way,$(WAYS),-s $(way)) -- $(CC_OPTS) -- $(C_SRCS)
588 $(PERL) -pe 'binmode(stdin); binmode(stdout); s@^(\S*\.o)@stage$(stage)/$$1@g; s@(\S*\.hi)@stage$(stage)/$$1@g' <.depend-BASE >.depend-$(stage)
589 # The binmode stuff tells perl not to add stupid ^M's to the output
591 -include .depend-$(stage)