X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2FMakefile;h=13a5bf332f40c6f3c71c44f497c936527ef26a33;hb=c00120a25c064f01e272cd5d1972caa760809d94;hp=10d59259854ff37ae8424677b16667250bdb24ca;hpb=0fed73cc0c26f03cb80b9b63228bc272372b257e;p=ghc-hetmet.git diff --git a/ghc/compiler/Makefile b/ghc/compiler/Makefile index 10d5925..13a5bf3 100644 --- a/ghc/compiler/Makefile +++ b/ghc/compiler/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.144 2001/03/16 14:36:19 sewardj Exp $ +# $Id: Makefile,v 1.151 2001/04/03 12:55:01 rrt Exp $ TOP = .. include $(TOP)/mk/boilerplate.mk @@ -23,8 +23,6 @@ else HS_PROG=ghc-$(ProjectVersion) endif -LINK = ghc - # ----------------------------------------------------------------------------- # Create compiler configuration @@ -65,12 +63,7 @@ $(CONFIG_HS) : $(FPTOOLS_TOP)/mk/config.mk Makefile @echo "cHaveLibGmp = \"$(HaveLibGmp)\"" >> $(CONFIG_HS) @echo "cUSER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> $(CONFIG_HS) @echo "cUSER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> $(CONFIG_HS) - @echo "clibdir = \"$(libdir)\"" >> $(CONFIG_HS) - @echo "clibexecdir = \"$(libexecdir)\"" >> $(CONFIG_HS) - @echo "cdatadir = \"$(datadir)\"" >> $(CONFIG_HS) - @echo "cbindir = \"$(bindir)\"" >> $(CONFIG_HS) @echo "cDEFAULT_TMPDIR = \"$(DEFAULT_TMPDIR)\"" >> $(CONFIG_HS) - @echo "cFPTOOLS_TOP_ABS = \"$(FPTOOLS_TOP_ABS)\"" >> $(CONFIG_HS) @echo "cRAWCPP = \"$(RAWCPP)\"" >> $(CONFIG_HS) @echo done. @@ -92,13 +85,19 @@ ifeq ($(GhcWithNativeCodeGen),YES) DIRS += nativeGen else SRC_HC_OPTS += -DOMIT_NATIVE_CODEGEN +endif + ifeq ($(GhcWithIlx),YES) DIRS += ilxGen SRC_HC_OPTS += -DILX endif -endif +ifeq "$(BootingFromHc)" "YES" +# HC files are always from a self-booted compiler +ghc_411_at_least = 1 +else ghc_411_at_least = $(shell expr "$(GhcMinVersion)" \>= 11) +endif # Only include GHCi if we're bootstrapping with at least version 411 ifeq "$(GhcWithInterpreter)" "YES" @@ -119,7 +118,7 @@ endif HCS = $(patsubst %.lhs, %.hc, $(patsubst %.hs, %.hc, $(HS_SRCS))) ifeq "$(BootingFromHc)" "YES" -HCS += rename/ParseIface.hc parser/Parser.hc main/ParsePkgConf.hs +HCS += rename/ParseIface.hc parser/Parser.hc main/ParsePkgConf.hc endif HS_OBJS = \ @@ -137,7 +136,7 @@ C_SRCS += parser/hschooks.c # Big Fudge to get around inherent problem that Makefile setup # has got with 'mkdependC'. # -SRC_MKDEPENDC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt) +SRC_MKDEPENDC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt) -I$(GHC_INCLUDES) # ----------------------------------------------------------------------------- # Haskell compilations @@ -151,8 +150,12 @@ HC=$(GHC) # # Use GHC for compiling C bits # +ifeq "$(BootingFromHc)" "YES" +SRC_CC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt) +else CC = $(HC) CC_OPTS := $(addprefix -optc, $(CC_OPTS)) +endif # magic from GNU make manual to convert a list of values # into a colon-separated list @@ -168,6 +171,7 @@ ifneq "$(mingw32_TARGET_OS)" "1" SRC_HC_OPTS += -package concurrent -package posix -package text -package util else SRC_HC_OPTS += -package concurrent -package text -package util +main/TmpFiles_HC_OPTS += -Dmingw32_TARGET_OS endif SRC_CC_OPTS += -Iparser -I. -I$(TOP)/includes -O @@ -210,16 +214,16 @@ utils/Digraph_HC_OPTS = -fglasgow-exts # because it contains a 'ccall strlen', which gets inlined by # gcc, causing a lack of registers. # -# -optC-funfolding-interface-threshold7 -# To stop the definition of 'strLength', which calls strlen, getting -# into the interface file and spreading the -monly-3-regs virus. -# We need -optC here because the driver before 3.02 didn't understand -# the -funfolding flags. utils/PrimPacked_HC_OPTS = -fvia-C -monly-3-regs # ByteCodeItbls uses primops that the NCG doesn't support yet. ghci/ByteCodeItbls_HC_OPTS = -fvia-C +# CSE interacts badly with the top-level IORefs in DriverState, causing some +# of them to be commoned up. We have a fix for this in 5.00+, but earlier +# versions of the compiler will need CSE turned off on this module. +main/DriverState_HC_OPTS = -fno-cse + # ---------------------------------------------------------------------------- # C compilations @@ -244,9 +248,13 @@ PRIMOP_BITS=primop-data-decl.hs-incl \ primop-usage.hs-incl \ primop-primop-info.hs-incl +ifneq "$(BootingFromHc)" "YES" prelude/PrimOp.lhs prelude/PrimOp.o: $(PRIMOP_BITS) +endif +ifneq "$(BootingFromHc)" "YES" depend :: $(PRIMOP_BITS) +endif primop-data-decl.hs-incl: prelude/primops.txt $(GENPOC) --data-decl < $< > $@ @@ -288,10 +296,10 @@ SRC_LD_OPTS += -no-link-chk all :: ghc-inplace -ghc-inplace : ghc +ghc-inplace : $(HS_PROG) @$(RM) $@ echo '#!/bin/sh' >>$@ - echo exec $(FPTOOLS_TOP_ABS)/ghc/compiler/ghc -B$(FPTOOLS_TOP_ABS) '"$$@"' >>$@ + echo exec $(FPTOOLS_TOP_ABS_UNIX)/ghc/compiler/$(HS_PROG) -B$(FPTOOLS_TOP_ABS) '"$$@"' >>$@ chmod 755 $@ CLEAN_FILES += ghc-inplace @@ -303,7 +311,7 @@ CLEAN_FILES += ghc-inplace # but put it together with the libraries. # Also don't want any interface files intstalled -INSTALL_PROGS += $(HS_PROG) +INSTALL_LIBEXECS += $(HS_PROG) #----------------------------------------------------------------------------- # clean