X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fincludes%2FMakefile;h=132c07cd1996cf3732d8fb2b8adc1b2360d02612;hb=3db151b4334c3af02aaaa5f8f1b233805ee90086;hp=e396f4f38312e2ed258a166dc383dde9bcc3d9c5;hpb=e8671b619ca8f87c2b5eaee935b6e9ddd3e3fc34;p=ghc-hetmet.git diff --git a/ghc/includes/Makefile b/ghc/includes/Makefile index e396f4f..132c07c 100644 --- a/ghc/includes/Makefile +++ b/ghc/includes/Makefile @@ -1,59 +1,48 @@ -# -# ghc/includes +# ----------------------------------------------------------------------------- +# $Id: Makefile,v 1.20 2002/03/02 17:49:42 sof Exp $ # TOP = .. include $(TOP)/mk/boilerplate.mk # -# Just to make sure, no ways stuff in here, please. +# All header files # -override WAYS= - -# De-litted header files -LH_FILES=$(wildcard *.lh) +H_FILES = $(filter-out gmp.h,$(wildcard *.h)) gmp.h -DELIT_H_FILES = $(patsubst %.lh, %.h, $(LH_FILES)) +# +# Options -- if we're building unregisterised, add a couple of -D's +# +ifeq "$(GhcUnregisterised)" "YES" +SRC_CC_OPTS += -DNO_REGS -DUSE_MINIINTERPRETER +endif # # Header file built from the configure script's findings # H_CONFIG = config.h +boot :: gmp.h -# Everything else -H_FILES = stgdefs.h rtsdefs.h StgDirections.h StgMachDeps.h error.h \ - ieee-flpt.h gmp.h LLC.h HLC.h - -MKDEPENDC_SRCS=mkNativeHdr.c - -ALL_FILES = $(DELIT_H_FILES) $(H_FILES) -ifeq ($(GhcWithNativeCodeGen),YES) -ALL_FILES += $(TARGETPLATFORM).h -endif +all :: $(H_CONFIG) NativeDefs.h +# gmp.h is copied from the GMP directory +gmp.h : $(FPTOOLS_TOP)/ghc/rts/gmp/gmp.h + $(CP) $< $@ -# -# In main/Signals we need to distinguish between irix5 and irix6, -# so we suitably mangle HostOS_FULL to get at the major version. -# (A hack, for sure - ToDo: consider systematically adding more -# fine-grained OS info to this Makefile/configure soup ) - -ifeq "$(HostOS_CPP)" "irix" -IRIX_MAJOR = $(shell echo $(HostOS_Full) | sed 's/\(irix[^.]*\).*$$/\1/' ) -endif - -# # The fptools configure script creates the configuration header file # and puts it in fptools/mk/config.h. We copy it down to here, prepending # some make variables specifying cpp platform variables. # -$(H_CONFIG) : $(FPTOOLS_TOP)/mk/config.h +$(H_CONFIG) : $(FPTOOLS_TOP)/mk/config.h $(FPTOOLS_TOP)/mk/config.mk $(H_CONFIG) : @echo "Creating $@..." @$(RM) $@ - @echo "#define HostPlatform_TYPE $(HostPlatform_CPP)" > $@ + @echo "#ifndef __FPTOOLS_CONFIG_H__" >$@ + @echo "#define __FPTOOLS_CONFIG_H__" >>$@ + @echo >> $@ + @echo "#define HostPlatform_TYPE $(HostPlatform_CPP)" >> $@ @echo "#define TargetPlatform_TYPE $(HostPlatform_CPP)" >> $@ @echo "#define BuildPlatform_TYPE $(HostPlatform_CPP)" >> $@ @echo >> $@ @@ -80,27 +69,43 @@ endif @echo "#define $(HostVendor_CPP)_TARGET_VENDOR 1" >> $@ @echo "#define $(HostVendor_CPP)_BUILD_VENDOR 1" >> $@ @cat $(FPTOOLS_TOP)/mk/$@ >> $@ + @echo "#endif /* __FPTOOLS_CONFIG_H__ */" >> $@ @echo "Done." -$(TARGETPLATFORM).h : mkNativeHdr - $(RM) $@ - ./mkNativeHdr > $@ || ( rm $@ && exit 1 ) +# --------------------------------------------------------------------------- +# Make DerivedConstants.h for the compiler -# -# Building mkNativeHdr using the Haskell compiler -# to do it (ghc really). -# -mkNativeHdr : $(HLIT) $(HFILES) mkNativeHdr.c - $(CC) -o mkNativeHdr mkNativeHdr.c +all :: DerivedConstants.h -all :: $(H_CONFIG) $(ALL_FILES) +mkDerivedConstants.c : $(H_CONFIG) -# +mkDerivedConstantsHdr : mkDerivedConstants.o + $(CC) -o $@ $(CC_OPTS) $(LD_OPTS) mkDerivedConstants.o + +DerivedConstants.h : mkDerivedConstantsHdr + ./mkDerivedConstantsHdr >DerivedConstants.h + +CLEAN_FILES += mkDerivedConstantsHdr DerivedConstants.h + +# --------------------------------------------------------------------------- +# Make NativeDefs.h for the NCG + +all :: NativeDefs.h + +mkNativeHdr.o : DerivedConstants.h + +mkNativeHdr : mkNativeHdr.o + $(CC) -o $@ $(CC_OPTS) $(LD_OPTS) mkNativeHdr.o + +NativeDefs.h : mkNativeHdr + ./mkNativeHdr >NativeDefs.h + +CLEAN_FILES += mkNativeHdr NativeDefs.h + +# --------------------------------------------------------------------------- # boot setup: # -# When building the dependencies in runtime/ , lib/ we need to get -# at the de-litted versions of includes/, hence we arrange the -# `depend' target to depend on `all'. +# Need config.h to make dependencies in the runtime system source. # boot :: all @@ -113,17 +118,13 @@ boot :: all # (ditto for interface files). This is not *really* needed, but # it gives (perhaps) a cleaner binary dist structure..might change. # -override datadir:=$(libdir)/includes -INSTALL_DATAS += $(DELIT_H_FILES) $(H_FILES) $(TARGETPLATFORM).h $(H_CONFIG) +override datadir:=$(libdir)/include +INSTALL_DATAS += $(H_FILES) $(H_CONFIG) # # `make clean' settings: # -CLEAN_FILES += $(DELIT_H_FILES) $(H_CONFIG) mkNativeHdr.o mkNativeHdr - -ifeq ($(GhcWithNativeCodeGen),YES) -CLEAN_FILES += $(TARGETPLATFORM).h -endif +CLEAN_FILES += $(H_CONFIG) # # Finally, slurp in the standard targets.