[project @ 2005-03-02 09:48:16 by simonmar]
[ghc-hetmet.git] / ghc / includes / Makefile
index 563ae50..136bce7 100644 (file)
-#
-# ghc/includes
+# -----------------------------------------------------------------------------
+# $Id: Makefile,v 1.28 2005/03/02 09:48:16 simonmar 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
+H_CONFIG   = ghcautoconf.h
+H_PLATFORM = ghcplatform.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
+all :: $(H_CONFIG) $(H_PLATFORM)
 
-ALL_FILES = $(DELIT_H_FILES) $(H_FILES)
-ifeq ($(GhcWithNativeCodeGen),YES)
-ALL_FILES += $(TARGETPLATFORM).h
-endif
+# gmp.h is copied from the GMP directory
+gmp.h : $(FPTOOLS_TOP)/ghc/rts/gmp/gmp.h
+       $(CP) $< $@
 
+# The fptools configure script creates the configuration header file and puts it
+# in fptools/mk/config.h. We copy it down to here (without any PACKAGE_FOO
+# definitions to avoid clashes), prepending some make variables specifying cpp
+# platform variables.
 
-#
-# 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) : Makefile
+       @echo "#ifndef __GHCAUTOCONF_H__"  >$@
+       @echo "#define __GHCAUTOCONF_H__" >>$@
+#      Turn '#define PACKAGE_FOO "blah"' into '/* #undef PACKAGE_FOO */'.
+       @sed 's,^\([     ]*\)#[  ]*define[       ][      ]*\(PACKAGE_[A-Z]*\)[   ][     ]*".*".*$$,\1/* #undef \2 */,' $(FPTOOLS_TOP)/mk/config.h >> $@
+       @echo "#endif /* __GHCAUTOCONF_H__ */"          >> $@
+       @echo "Done."
 
-$(H_CONFIG) :
+$(H_PLATFORM) : Makefile
        @echo "Creating $@..."
        @$(RM) $@
-       @echo "#define HostPlatform_TYPE   $(HostPlatform_CPP)"  > $@
-       @echo "#define TargetPlatform_TYPE $(HostPlatform_CPP)" >> $@
+       @echo "#ifndef __GHCPLATFORM_H__"  >$@
+       @echo "#define __GHCPLATFORM_H__" >>$@
+       @echo >> $@
        @echo "#define BuildPlatform_TYPE  $(HostPlatform_CPP)" >> $@
+       @echo "#define HostPlatform_TYPE   $(TargetPlatform_CPP)" >> $@
        @echo >> $@
-       @echo "#define $(HostPlatform_CPP)_HOST         1" >> $@
-       @echo "#define $(HostPlatform_CPP)_TARGET       1" >> $@
-       @echo "#define $(HostPlatform_CPP)_BUILD        1" >> $@
+       @echo "#define $(HostPlatform_CPP)_BUILD  1" >> $@
+       @echo "#define $(TargetPlatform_CPP)_HOST  1" >> $@
+       @echo >> $@
+       @echo "#define $(HostArch_CPP)_BUILD_ARCH  1" >> $@
+       @echo "#define $(TargetArch_CPP)_HOST_ARCH  1" >> $@
+       @echo "#define BUILD_ARCH  \"$(HostArch_CPP)\"" >> $@
+       @echo "#define HOST_ARCH  \"$(TargetArch_CPP)\"" >> $@
+       @echo >> $@
+       @echo "#define $(HostOS_CPP)_BUILD_OS  1" >> $@
+       @echo "#define $(TargetOS_CPP)_HOST_OS  1" >> $@
+       @echo "#define BUILD_OS  \"$(HostOS_CPP)\"" >> $@
+       @echo "#define HOST_OS  \"$(TargetOS_CPP)\"" >> $@
+ifeq "$(HostOS_CPP)" "irix"
+       @echo "#ifndef $(IRIX_MAJOR)_HOST_OS" >> $@  
+       @echo "#define $(IRIX_MAJOR)_HOST_OS  1" >> $@  
+       @echo "#endif" >> $@  
+endif
        @echo >> $@
-       @echo "#define $(HostArch_CPP)_HOST_ARCH        1" >> $@
-       @echo "#define $(HostArch_CPP)_TARGET_ARCH      1" >> $@
-       @echo "#define $(HostArch_CPP)_BUILD_ARCH       1" >> $@
+       @echo "#define $(HostVendor_CPP)_BUILD_VENDOR  1" >> $@
+       @echo "#define $(TargetVendor_CPP)_HOST_VENDOR  1" >> $@
+       @echo "#define BUILD_VENDOR  \"$(HostVendor_CPP)\"" >> $@
+       @echo "#define HOST_VENDOR  \"$(TargetVendor_CPP)\"" >> $@
        @echo >> $@
-       @echo "#define $(HostOS_CPP)_HOST_OS            1" >> $@
-       @echo "#define $(HostOS_CPP)_TARGET_OS          1" >> $@  
-       @echo "#define $(HostOS_CPP)_BUILD_OS           1" >> $@
+       @echo "/* These TARGET macros are for backwards compatibily... DO NOT USE! */" >> $@
+       @echo "#define TargetPlatform_TYPE $(TargetPlatform_CPP)" >> $@
+       @echo "#define $(TargetPlatform_CPP)_TARGET  1" >> $@
+       @echo "#define $(TargetArch_CPP)_TARGET_ARCH  1" >> $@
+       @echo "#define TARGET_ARCH  \"$(TargetArch_CPP)\"" >> $@
+       @echo "#define $(TargetOS_CPP)_TARGET_OS  1" >> $@  
+       @echo "#define TARGET_OS  \"$(TargetOS_CPP)\"" >> $@
+       @echo "#define $(TargetVendor_CPP)_TARGET_VENDOR  1" >> $@
        @echo >> $@
-       @echo "#define $(HostVendor_CPP)_HOST_VENDOR    1" >> $@
-       @echo "#define $(HostVendor_CPP)_TARGET_VENDOR  1" >> $@
-       @echo "#define $(HostVendor_CPP)_BUILD_VENDOR   1" >> $@
-       @cat $(FPTOOLS_TOP)/mk/$@ >> $@
+       @echo "#endif /* __GHCPLATFORM_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
-       $(HC) -c mkNativeHdr.c
-       $(CC) $(CFLAGS) -o mkNativeHdr mkNativeHdr.c
+all :: DerivedConstants.h
+
+mkDerivedConstants.c : $(H_CONFIG)
+
+mkDerivedConstantsHdr : mkDerivedConstants.o
+       $(CC) -o $@ $(CC_OPTS) $(LD_OPTS) mkDerivedConstants.o
 
-all :: $(H_CONFIG) $(ALL_FILES)
+DerivedConstants.h : mkDerivedConstantsHdr
+       ./mkDerivedConstantsHdr >$@
 
+CLEAN_FILES += mkDerivedConstantsHdr$(exeext) DerivedConstants.h
+
+# -----------------------------------------------------------------------------
 #
+
+all :: GHCConstants.h
+
+mkGHCConstants.c : $(H_CONFIG)
+
+mkGHCConstants : mkGHCConstants.o
+       $(CC) -o $@ $(CC_OPTS) $(LD_OPTS) mkGHCConstants.o
+
+mkGHCConstants.o : mkDerivedConstants.c
+       $(CC) -o $@ -c $<  -DGEN_HASKELL
+
+GHCConstants.h : mkGHCConstants
+       ./mkGHCConstants >$@
+
+CLEAN_FILES += mkGHCConstants$(exeext) GHCConstants.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
 
@@ -95,17 +139,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) $(H_PLATFORM)
 
 #
 # `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) $(H_PLATFORM)
 
 #
 # Finally, slurp in the standard targets.