projects
/
ghc-hetmet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[project @ 2001-05-25 13:50:39 by simonmar]
[ghc-hetmet.git]
/
ghc
/
includes
/
Makefile
diff --git
a/ghc/includes/Makefile
b/ghc/includes/Makefile
index
d5335fa
..
1481c35
100644
(file)
--- a/
ghc/includes/Makefile
+++ b/
ghc/includes/Makefile
@@
-1,42
+1,33
@@
-#
-# ghc/includes
+# -----------------------------------------------------------------------------
+# $Id: Makefile,v 1.14 2000/12/08 11:47:00 rrt Exp $
#
TOP = ..
include $(TOP)/mk/boilerplate.mk
#
#
TOP = ..
include $(TOP)/mk/boilerplate.mk
#
-# Just to make sure, no ways stuff in here, please.
+# All header files
#
#
-WAYS=
-
-# De-litted header files
-LH_FILES=$(wildcard *.lh)
-
-DELIT_H_FILES = $(patsubst %.lh, %.h, $(LH_FILES))
+H_FILES = $(filter-out gmp.h,$(wildcard *.h)) gmp.h
#
# Header file built from the configure script's findings
#
H_CONFIG = config.h
#
# 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
-
-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) $< $@
-#
# 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.
#
# 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 $@..."
$(H_CONFIG) :
@echo "Creating $@..."
@@
-52,10
+43,17
@@
$(H_CONFIG) :
@echo "#define $(HostArch_CPP)_HOST_ARCH 1" >> $@
@echo "#define $(HostArch_CPP)_TARGET_ARCH 1" >> $@
@echo "#define $(HostArch_CPP)_BUILD_ARCH 1" >> $@
@echo "#define $(HostArch_CPP)_HOST_ARCH 1" >> $@
@echo "#define $(HostArch_CPP)_TARGET_ARCH 1" >> $@
@echo "#define $(HostArch_CPP)_BUILD_ARCH 1" >> $@
+ @echo "#define HOST_ARCH \"$(HostArch_CPP)\"" >> $@
@echo >> $@
@echo "#define $(HostOS_CPP)_HOST_OS 1" >> $@
@echo "#define $(HostOS_CPP)_TARGET_OS 1" >> $@
@echo "#define $(HostOS_CPP)_BUILD_OS 1" >> $@
@echo >> $@
@echo "#define $(HostOS_CPP)_HOST_OS 1" >> $@
@echo "#define $(HostOS_CPP)_TARGET_OS 1" >> $@
@echo "#define $(HostOS_CPP)_BUILD_OS 1" >> $@
+ @echo "#define HOST_OS \"$(HostOS_CPP)\"" >> $@
+ifeq "$(HostOS_CPP)" "irix"
+ @echo "#ifndef $(IRIX_MAJOR)_TARGET_OS " >> $@
+ @echo "#define $(IRIX_MAJOR)_TARGET_OS 1" >> $@
+ @echo "#endif " >> $@
+endif
@echo >> $@
@echo "#define $(HostVendor_CPP)_HOST_VENDOR 1" >> $@
@echo "#define $(HostVendor_CPP)_TARGET_VENDOR 1" >> $@
@echo >> $@
@echo "#define $(HostVendor_CPP)_HOST_VENDOR 1" >> $@
@echo "#define $(HostVendor_CPP)_TARGET_VENDOR 1" >> $@
@@
-63,26
+61,21
@@
$(H_CONFIG) :
@cat $(FPTOOLS_TOP)/mk/$@ >> $@
@echo "Done."
@cat $(FPTOOLS_TOP)/mk/$@ >> $@
@echo "Done."
-$(TARGETPLATFORM).h : mkNativeHdr
- $(RM) $@
- ./mkNativeHdr > $@ || ( rm $@ && exit 1 )
+# ---------------------------------------------------------------------------
+# Make NativeDefs.h for the NCG
-#
-# 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
+C_PROG = mkNativeHdr
+C_SRCS = mkNativeHdr.c
-all :: $(H_CONFIG) $(ALL_FILES)
+NativeDefs.h : mkNativeHdr
+ ./mkNativeHdr >NativeDefs.h
-#
+CLEAN_FILES += NativeDefs.h
+
+# ---------------------------------------------------------------------------
# boot setup:
#
# 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
#
boot :: all
@@
-90,25
+83,18
@@
boot :: all
# Install all header files
#
# Hackily set the install destination here:
# Install all header files
#
# Hackily set the install destination here:
-INSTALL_DATAS += $(DELIT_H_FILES) $(H_FILES) $(TARGETPLATFORM).h
-
#
#
-# We want the configuration header files for the different platforms
-# to be put inside the lib/../$(HOSTPLATFORM)/ directory
+# Note: we keep per-platform copies of all the include files
+# (ditto for interface files). This is not *really* needed, but
+# it gives (perhaps) a cleaner binary dist structure..might change.
#
#
-install :: $(H_CONFIG)
- $(INSTALL_DIR) $(libdir)/includes
- $(INSTALL_DATA) $(INSTALL_OPTS) $(H_CONFIG) $(libdir)/includes
-
+override datadir:=$(libdir)/includes
+INSTALL_DATAS += $(H_FILES) $(H_CONFIG)
#
# `make clean' settings:
#
#
# `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.
#
# Finally, slurp in the standard targets.