X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=mk%2Fconfig.mk.in;h=8ddf3e2df430687e070e605aea4cf55c34a0446c;hb=c0be61743a875b59a1ffe6f0af6a50d4f9d091ef;hp=3b065c38123d6a735348fea4e38385d430e3918a;hpb=71cf5ac8dd7392e90aeadf470f0ae89e49ff1c56;p=ghc-hetmet.git diff --git a/mk/config.mk.in b/mk/config.mk.in index 3b065c3..0b54097 100644 --- a/mk/config.mk.in +++ b/mk/config.mk.in @@ -1,35 +1,30 @@ -# +# -*-makefile-*- # @configure_input@ # -################################################################################# -# -# config.mk.in-template +################################################################################ # -# This file defines all the variables that set the configuration of -# a particular build. +# config.mk.in # +# This file supplies defaults for many tweakable build configuration +# options. Some of the defaults are filled in by the autoconf-generated +# configure script. # -################################################################################# - -# The configuration is defined in two steps: +# DO NOT EDIT THIS FILE! # -# 1. The builder (i.e. the person doing the build) -# copies this file, config.mk.in-template -# to config.mk.in +# - config.mk is auto-generated from config.mk.in by configure. +# This may be triggered automatically by the build system (say +# if config.mk.in has changed more recently than config.mk), +# so if you edit config.mk your changes will be spammed. # -# 2. S/he then edits it manually (gasp) to reflect any configuration -# options s/he wants. +# - Settings in this file may be overriden by giving replacement +# definitions in build.mk. See build.mk.sample for a good +# starting point for a build.mk file. # -# 3. Then s/he runs "configure", which generates config.mk from -# config.mk.in, substituting for system/platform-dependent things -# enclosed in @at-signs@. +# If you don't have a build.mk file then you get defaults for everything. +# The defaults should provide a reasonable vanilla build. # # This is one of only two files that configure generates (the other is config.h) # -# Note that after subsequent edits of config.mk.in for a build, the configure script -# will have to be re-run manually to have the change reflected in config.mk. -# - # There is a section below for each project within the fptools suite # # PLUS @@ -38,89 +33,175 @@ # included by boilerplate.mk (see boilerplate.mk for a list). +################################################################################ +# +# Project-wide platform variables +# +################################################################################ + +# A "platform" is the GNU cpu-type/manufacturer/operating-system target machine +# specifier. E.g. sparc-sun-solaris2 +# +# Build platform: the platform on which we are doing this build +# Host platform: the platform on which these binaries will run +# Target platform: the platform for which this compiler will generate code +# +# We don't support build & host being different, because the build +# process creates binaries that are run during the build, and also +# installed. +# +# If host & target are different, then we are building a compiler +# which will generate intermediate .hc files to port to the target +# architecture for bootstrapping. The libraries and stage 2 compiler +# will be built as HC files for the target system, and likely won't +# build on this host platform. +# +# Guidelines for when to use HOST vs. TARGET: +# +# - In the build system (Makefile, foo.mk), normally we should test +# $(HOSTPLATFORM). There are some cases (eg. installation), where +# we expect $(HOSTPLATFORM)==$(TARGETPLATFORM), so in those cases it +# doesn't matter which is used. +# +# - In the compiler itself, we should test HOST or TARGET depending +# on whether the conditional relates to the code being generated, or +# the platform on which the compiler is running. For stage 2, +# HOSTPLATFORM should be reset to be TARGETPLATFORM (we currently +# don't do this, but we should). +# +# - In the RTS and library code, we should be testing TARGET only. +# +# NOTE: cross-compiling is not well supported by the build system. +# You have to do a lot of work by hand to cross compile: see the +# section on "Porting GHC" in the Building Guide. + +HOSTPLATFORM = @HostPlatform@ +TARGETPLATFORM = @TargetPlatform@ +BUILDPLATFORM = @BuildPlatform@ -################################################################################# +# Hack alert: +# in one or two places, we need to get at the OS version (major and +# perhaps even minor), HostOS_Full is the OS name reported by +# AC_CANONICAL_SYSTEM. +# +HostPlatform_CPP = @HostPlatform_CPP@ +HostArch_CPP = @HostArch_CPP@ +HostOS_CPP = @HostOS_CPP@ +HostOS_Full = @HostOS_Full@ +HostVendor_CPP = @HostVendor_CPP@ + +TargetPlatform_CPP = @TargetPlatform_CPP@ +TargetArch_CPP = @TargetArch_CPP@ +TargetOS_CPP = @TargetOS_CPP@ +TargetVendor_CPP = @TargetVendor_CPP@ + +BuildPlatform_CPP = @BuildPlatform_CPP@ +BuildArch_CPP = @BuildArch_CPP@ +BuildOS_CPP = @BuildOS_CPP@ +BuildVendor_CPP = @BuildVendor_CPP@ + +@HostPlatform_CPP@_HOST = 1 +@TargetPlatform_CPP@_TARGET = 1 +@BuildPlatform_CPP@_BUILD = 1 + +@HostArch_CPP@_HOST_ARCH = 1 +@TargetArch_CPP@_TARGET_ARCH = 1 +@BuildArch_CPP@_BUILD_ARCH = 1 + +@HostOS_CPP@_HOST_OS = 1 +@TargetOS_CPP@_TARGET_OS = 1 +@BuildOS_CPP@_BUILD_OS = 1 + +@HostVendor_CPP@_HOST_VENDOR = 1 +@TargetVendor_CPP@_TARGET_VENDOR = 1 +@BuildVendor_CPP@_BUILD_VENDOR = 1 + +# Leading underscores on symbol names in object files +# Valid options: YES/NO +# +LeadingUnderscore=@LeadingUnderscore@ + +# Pin a suffix on executables? If so, what (Windows only). +exeext=@exeext@ + +# Windows=YES if on a Windows platform +ifneq "$(findstring $(HostOS_CPP), mingw32 cygwin32)" "" +Windows=YES +else +Windows=NO +endif + +################################################################################ # # project-wide flags # # Set of options applicable to all fptools projects # -################################################################################# +################################################################################ + +# BootingFromHc - build GHC and the libraries from .hc files? +BootingFromHc = @BootingFromHc@ +# BootingFromUnregisterisedHc - treat .hc files as containing unregisterised +# rather than registerised code, i.e., disable the mangler? +BootingFromUnregisterisedHc = @BootingFromUnregisterisedHc@ + +# Build Order: we build Happy, Haddock and Alex before GHC if they are +# in this source tree, just in case our GHC build depends on these +# local builds rather than installed versions of the tools. # -# What parts to build: An fptools build tree does not have to be built -# all in one go. By setting the list of ProjectsToBuild in build.mk you can -# control which projects are built. +# Build the libs first if we're bootstrapping from .hc files. +ifeq "$(BootingFromHc)" "YES" +AllProjects = glafp-utils happy alex haddock libraries hslibs ghc greencard hdirect hood nofib docs +else +AllProjects = glafp-utils happy alex haddock ghc libraries hslibs greencard hdirect hood nofib docs +endif + # -# Caution: the projects are built in the order given here, so if some -# projects use others you must list them in the correct order. +# (OPTIONAL) set ProjectsToBuild to a list of projects to be built. If this +# list is empty, then all projects present in the source tree will be built. # -# Generally: * glafp-utils should be first -# * literate next -# * happy next -# * ghc&hslibs next -# then it's up to you +ProjectsToBuild = -ProjectsToBuild = glafp-utils literate ghc hslibs # -# Make a distinction between building and installing, ProjectsToInstall -# does not include the literate bits.. +# set ProjectsDontInstall to a list of projects which are normally built but +# not installed. # -ProjectsToInstall = glafp-utils ghc hslibs +ProjectsDontInstall = glafp-utils nofib # # Should the various project tests directories be built? # IncludeTestDirsInBuild=NO -################################################################################# # -# GHC project -# -# Set of (configurable) options needed by the ghc tree -# plus their default options (if any). +# Should the various project example directories be built? # -################################################################################# +IncludeExampleDirsInBuild=NO # -# Name variables for ghc: -# -GhcProjectName =The Glorious Glasgow Haskell Compilation System -GhcProjectNameShort =ghc -GhcProjectVersion =2.04 -GhcProjectPatchLevel =0 -GhcBuildeeVersion =204 -GhcBuilderVersion =29 +# Which ways should DocBook XML documents be built? +# options are: dvi ps pdf html +# +XMLDocWays= +################################################################################ # -# Name variables for the fptools, for now equal to the above -# ghc stuff +# GHC project +# +# Set of (configurable) options needed by the ghc tree +# plus their default options (if any). # -ProjectName =$(GhcProjectName) -ProjectNameShort =$(GhcProjectNameShort) -ProjectVersion =$(GhcProjectVersion) -ProjectPatchLevel =$(GhcProjectPatchLevel) - +################################################################################ #--------------------------------------------------------------- # # Variables that control how the compiler itself is built +# +#--------------------------------------------------------------- -# Specify the Haskell compiler to be used to compile the compiler itself -# WithGhcHc Path name of the compiler to use -# Ghc2_0 Whether this compiler is GHC 2.0 or later -# (which affects gruesome details about -# how mutually recursive modules are handled) -# WithGhcHcType What "type" of compiler is being used -# Valid options: -# HC_CHALMERS_HBC -# HC_GLASGOW_GHC -# HC_ROJEMO_NHC -# HC_UNSPECIFIED -WithGhcHc = ghc-0.29 -Ghc2_0=NO -# Unused, we think -# WithGhcHcType=HC_GLASGOW_GHC +# The compiler used to build GHC is $(GHC). To change the actual compiler +# used, re-configure with --with-ghc=. # Extra ways in which to build the compiler (for example, you might want to # build a profiled compiler so you can see where it spends its time) @@ -128,129 +209,263 @@ GhcCompilerWays= # Extra option flags to pass to the compiler that compiles the compiler # (Ones that are essential are wired into ghc/compiler/Makefile) -# Typical ones: -# -O compiler an optimised compiler -# -DDEBUG include consistency/assertion checks in the compiled compiler -# -fshow-import-specs show import specialisations -GhcHcOpts= - -# GhcWithHscBuiltViaC - build GHC compiler proper (\`hsc') from .hc files? -GhcWithHscBuiltViaC=NO - -# Build hsc with -O and turn optimising flag on when compiling -# the intermediate C file -GhcUseGccForOptAsm=YES +# Typical options to use here: +# +# -DDEBUG include debugging code and assertions (will make the +# compiler slower and produce debugging output, but useful +# for development) +# +# -dcore-lint check the types after every pass of the compiler; +# a pretty strong internal check of the compiler being +# used to compile GHC. Useful when bootstrapping. +GhcHcOpts=-Rghc-timing -# Compile intermediate C file with debugging options set. -GhcUseGccForDebuggingAsm=YES +# Extra options added to specific stages of the compiler bootstrap. +# These are placed later on the command line, and may therefore +# override options from $(GhcHcOpts). +GhcStage1HcOpts= +GhcStage2HcOpts= +GhcStage3HcOpts= -# Build a registerised version of hsc and runtime -# (you'd be desperate or silly not to). -GhcWithRegisterised=YES +# Build a compiler that will build *unregisterised* libraries and +# binaries by default. Unregisterised code is supposed to compile and +# run without any support for architecture-specific assembly mangling, +# register assignment or tail-calls, and is therefore a good way to get +# started when porting GHC to new architectures. +# +# If this is set to NO, you can still use the unregisterised way +# (way 'u') to get unregisterised code, but the default way will be +# registerised. +# +# NOTE: the stage1 compiler will be a registerised binary (assuming +# the compiler you build with is generating registerised binaries), but +# the stage2 compiler will be an unregisterised binary. +# +GhcUnregisterised=NO # Build a compiler with a native code generator backend # (as well as a C backend) # # Target platforms supported: -# i386, alpha & sparc +# i386, sparc & powerpc +ifneq "$(findstring $(HostArch_CPP), i386 sparc powerpc)" "" GhcWithNativeCodeGen=YES +else +GhcWithNativeCodeGen=NO +endif + +# Include support for generating Java +GhcWithJavaGen=NO -# Build the compiler with the deforester included? -GhcWithDeforester=NO +HaveLibDL = @HaveLibDL@ +HaveRtldNext = @HaveRtldNext@ +HaveRtldLocal = @HaveRtldLocal@ + +# Include GHCi in the compiler. Default to NO for the time being. + +ifneq "$(findstring $(HostOS_CPP), mingw32 cygwin32 linux solaris2 freebsd netbsd openbsd darwin)" "" +GhcWithInterpreter=YES +else +GhcWithInterpreter=NO +endif # # Building various ways? # (right now, empty if not). BuildingParallel=$(subst mp,YES,$(filter mp,$(WAYS))) -BuildingConcurrent=$(subst mc,YES,$(filter mc,$(WAYS))) -BuildingProfiling=$(subst p,YES,$(filter p,$(WAYS))) BuildingGranSim=$(subst mg,YES,$(filter mg,$(WAYS))) -BuildingProfilingConcurrent=$(subst mr,YES,$(filter mr,$(WAYS))) -#--------------------------------------------------------------- -# -# Variables that control how the prelude libraries and runtime system are built +#------------------------------------------------------------------------------ +# Options for Libraries # What extra ways to build the libraries in # In addition to the normal sequential way, the default is to also build # profiled prelude libraries. +# When booting from .hc files, turn this off. +ifeq "$(BootingFromHc)" "YES" +GhcLibWays= +else GhcLibWays=p +endif + +# In addition, the RTS is built in some further variations. Ways that +# make sense here: +# +# thr : threaded +# thr_p : threaded profiled +# debug : debugging (compile with -g for the C compiler, and -DDEBUG) +# debug_p : debugging profiled +# thr_debug : debugging threaded +# thr_debug_p : debugging threaded profiled +# +ifeq "$(BootingFromHc)" "YES" +GhcRTSWays= +else +GhcRTSWays=thr thr_p debug +endif + +# Option flags to pass to GHC when it's compiling modules in +# fptools/libraries. Typically these are things like -O or +# -dcore-lint or -H32m. The ones that are *essential* are wired into +# the build system. +# +# -O is pretty desirable, otherwise no inlining of prelude +# things (incl "+") happens when compiling with this compiler -# Option flags to pass to GHC when it's compiling prelude modules -# Typically these are things like -O or -dcore-lint -# The ones that are *essential* are wired into ghc/lib/Makefile -GhcLibHcOpts= -split-objs -odir $(basename $*) +GhcLibHcOpts=-O -Rghc-timing +# Win32 only: Enable the RTS and libraries to be built as DLLs +DLLized=@EnableWin32DLLs@ -################################################################################# +# Win32 only: are we building a compiler that tries to reduce external +# dependencies? i.e., one that doesn't assume that the user has got +# the cygwin toolchain installed on his/her Win32 box. # -# hslibs project +# GHC is still dependent on GNU tools in the backend (gcc to further process +# .c/.hc/.s/.o files + 'perl' to mangle and split), but using this +# option a GHC distribution can be put together which includes a minimal +# set of these open source tools. # -# Set of (configurable) options needed by the Haskell libraries (hslibs) -# plus their default options (if any). +MinimalUnixDeps=@MinimalUnixDeps@ + +# Strip local symbols from libraries? This can make the libraries smaller, +# but makes debugging somewhat more difficult. Doesn't work with all ld's. # -################################################################################# +StripLibraries=NO -# Build the Haskell Readline bindings? + +# ---------------------------------------------------------------------------- +# Object-file splitting # -HsLibsWithReadline=NO +# Set SplitObjs=YES or NO in your build.mk # +# Don't use -split-objs in in GhcLibHcOpts, because the build +# system needs to do other special magic if you are +# doing object-file splitting + +# Don't split object files for libs if we're building DLLs, or booting from +# .hc files. +SplitObjs=YES + +ifeq "$(DLLized)" "YES" +SplitObjs=NO +endif +ifeq "$(BootingFromHc)" "YES" +SplitObjs=NO +endif +ifeq "$(GhcUnregisterised)" "YES" +SplitObjs=NO +endif +ifeq "$(TARGETPLATFORM)" "ia64-unknown-linux" +SplitObjs=NO +endif + +# ---------------------------------------------------------------------------- +# Options for GHC's RTS + +# For an optimised RTS (you probably don't want to change these; we build +# a debugging RTS by default now. Use -package rts_debug to get it). +GhcRtsHcOpts=-O2 +GhcRtsCcOpts=-fomit-frame-pointer + +# Include the front panel code? Needs GTK+. +GhcRtsWithFrontPanel = NO + +################################################################################ +# +# libraries project +# +################################################################################ + +# Build the Haskell Readline bindings? +# +GhcLibsWithReadline=@GhcLibsWithReadline@ + +# Libraries needed for linking with readline +LibsReadline=@LibsReadline@ + # Include path to readline.h # (no path == in standard include path) # ReadlineIncludePath= -# Build the socket libraries? +# Math library +LIBM=@LIBM@ + +# Build the ObjectIO ? # -HsLibsWithSockets=YES +GhcLibsWithObjectIO=@GhcLibsWithObjectIO@ +# Build the Haskell OpenGL binding? # -# The different ways to build hslibs. Default is just to mirror -# what is done for the ghc prelude libraries. +GhcLibsWithOpenGL=@GhcLibsWithOpenGL@ +GLU_CFLAGS=@GLU_CFLAGS@ +GLU_LIBS=@GLU_LIBS@ + +# Build the Haskell OpenAL binding? # -HsLibWays=$(GhcLibWays) +GhcLibsWithOpenAL=@GhcLibsWithOpenAL@ -# Option flags for hslibs are by default the same as for the options -# used for the prelude libs (see above). -HsLibHcOpts=$(GhcLibHcOpts) +# Build the Haskell GLUT binding? +# +GhcLibsWithGLUT=@GhcLibsWithGLUT@ +GLUT_LIBS=@GLUT_LIBS@ + +# X11 stuff +# +GhcLibsWithX11=@GhcLibsWithX11@ +X_CFLAGS=@X_CFLAGS@ +X_LIBS=@X_LIBS@ -################################################################################# +# .NET interop support? +# +DotnetSupport=@DotnetSupport@ + +# Build unix package? +# +GhcLibsWithUnix=@GhcLibsWithUnix@ + +################################################################################ # # happy project # # Happy specific options # -################################################################################# +################################################################################ +# The compiler you'd like to use to compile Happy +WithHappyHc = @WithHc@ +# HappyHcOpts gives the flags to pass to the Haskell compiler used +# to compile the Happy sources with. +# +HappyHcOpts = -O -################################################################################# +################################################################################ # # haggis project # # Haggis specific options # -################################################################################# +################################################################################ - - -################################################################################# +################################################################################ # -# green-card project +# greencard project # -# Green-card specific options +# GreenCard specific options # -################################################################################# +################################################################################ - -################################################################################# +################################################################################ # # nofib project # # nofib specific options # -################################################################################# +################################################################################ +WithNofibHc = $(GHC_INPLACE) # NoFibSubDirs controls which set of tests should be run # You can run one or more of @@ -259,18 +474,17 @@ HsLibHcOpts=$(GhcLibHcOpts) # real # parallel # PRIVATE -# GHC_ONLY # PENDING # UNUSED -NoFibSubDirs = imaginary spectral real GHC_ONLY PRIVATE +NoFibSubDirs = imaginary spectral real # The different ways to build nofib. Default is just to mirror # what is done for the ghc prelude libraries. # -NoFibWays=$(GhcLibWays) +NoFibWays = $(GhcLibWays) # Haskell compiler options for nofib -NoFibHcOpts= +NoFibHcOpts = -O # ============================================================================== # @@ -280,37 +494,74 @@ NoFibHcOpts= # # ============================================================================== -################################################################################# +################################################################################ # # Paths (see paths.mk) # -################################################################################# +################################################################################ -TMPDIR = /tmp +# Directory used by GHC (and possibly other tools) for storing +# temporary files. If your TMPDIR isn't big enough, either override +# this in build.mk or set your environment variable "TMPDIR" to point +# to somewhere with more space. (TMPDIR=. is a good choice). -# FPTOOLS_TOP: the top of the fptools hierarchy, absolute path. +# DEFAULT_TMPDIR isn't called TMPDIR because GNU make tends to +# override an environment variable with the value of the make variable +# of the same name (if it exists) when executing sub-processes, so +# setting the TMPDIR env var would have no effect in the build tree. +DEFAULT_TMPDIR = /tmp +ifeq "$(TARGETPLATFORM)" "i386-unknown-cygwin32" +DEFAULT_TMPDIR = C:/TEMP +endif +ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +DEFAULT_TMPDIR = C:/TEMP +endif + +# FPTOOLS_TOP: the top of the fptools hierarchy, absolute path. (POSIX / unix-style path). FPTOOLS_TOP_ABS = @hardtop@ +# The platform specific version of 'hardtop'. +FPTOOLS_TOP_ABS_PLATFORM = @hardtop_plat@ # # Installation directories, we don't use half of these, # but since the configure script has them on offer while # passing through, we might as well set them. -prefix = @prefix@ -exec_prefix = @exec_prefix@ -bindir = @bindir@ -#UNUSED, see below: libexecdir = @libexecdir@ -datadir = @datadir@ -#sysconfdir = @datadir@ -#sharedstatedir = @sharedstatedir@ -#localstatedir = @localstatedir@ -libdir = @libdir@ -infodir = @infodir@ -includedir = @includedir@ -oldincludedir = @oldincludedir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ +bindir = @bindir@ +datadir0 = @datadir@ +libdir0 = @libdir@ +includedir = @includedir@ +oldincludedir = @oldincludedir@ mandir = @mandir@ -#UNUSED:srcdir = @srcdir@ + +ifeq "$(Windows)" "YES" + +ifeq "$(strip $(prefix))" "" +prefix = c:/ghc +endif + +# Hack: our directory layouts tend to be different on Windows, so +# hack around configure's bogus assumptions here. +datadir = $(prefix) +libdir = $(prefix) + +else + +# +# Unix: override libdir and datadir to put project-specific stuff in +# a subdirectory with the version number included. +# +libdir = $(if $(ProjectNameShort),$(libdir0)/$(ProjectNameShort)-$(ProjectVersion),$(libdir0)) +datadir = $(if $(ProjectNameShort),$(datadir0)/$(ProjectNameShort)-$(ProjectVersion),$(datadir0)) + +endif # Windows + +# Default place for putting interface files is $(libdir) +# (overriden for packages in package.mk) +ifacedir = $(libdir) # # Default values for most of the above are only set if @@ -339,9 +590,6 @@ endif ifeq "$(strip $(libdir))" "" libdir = $(exec_prefix)/lib endif -ifeq "$(strip $(infodir))" "" -infodir = $(prefix)/info -endif ifeq "$(strip $(includedir))" "" includedir = $(prefix)/include endif @@ -351,13 +599,32 @@ endif ifeq "$(strip $(mandir))" "" mandir = $(prefix)/man endif - -################################################################################# +#----------------------------------------------------------------------------- +# install configuration + +# +# Set this to have files installed with a specific owner +# +INSTALL_OWNER = + +# +# Set this to have files installed with a specific group +# +INSTALL_GROUP = + # -# Utilities programs: flags +# Invocations of `install' for the four different classes +# of targets: # -################################################################################# +INSTALL_PROGRAM = $(INSTALL) -m 755 +INSTALL_SCRIPT = $(INSTALL) -m 755 +INSTALL_SHLIB = $(INSTALL) -m 755 +INSTALL_DATA = $(INSTALL) -m 644 +INSTALL_DIR = $(MKDIRHIER) + +# ----------------------------------------------------------------------------- +# Utilities programs: flags # If you want to give any standard flags to pretty much any utility # (see utils.mk for a complete list), by adding a line here @@ -369,60 +636,29 @@ endif # # SRC_HC_OPTS += -O +SRC_HC_OPTS += -H16m -O -################################################################################# -# -# Platform -# -################################################################################# - -# A "platform" is the GNU cpu-type/manufacturer/operating-system target machine -# specifier. E.g. sparc-sun-solaris2 - -HOSTPLATFORM = @HostPlatform@ -TARGETPLATFORM = @TargetPlatform@ -BUILDPLATFORM = @HostPlatform@ +# These flags make flex 8-bit +SRC_FLEX_OPTS += -8 -# Hack alert: -# in one or two places, we need to get at the OS version (major and perhaps even minor), -# HOSTPLATFORM_GNU is the cpu-manufacturer-os name reported by AC_CANONICAL_SYSTEM. -# -HostPlatform_GNU = @HostPlatformFull@ -HostPlatform_CPP = @HostPlatform_CPP@ -HostArch_CPP = @HostArch_CPP@ -HostOS_CPP = @HostOS_CPP@ -HostVendor_CPP = @HostVendor_CPP@ +SRC_INSTALL_BIN_OPTS += -s -# -# ToDo: check if these can be purged now. -- sof -# +# lint gets all CPP's flags too +SRC_LINT_OPTS += -axz -DLINT $(SRC_CPP_OPTS) +WAY$(_way)_LINT_OPTS += WAY$(_way)_CPP_OPTS -@HostPlatform_CPP@_HOST = 1 -@HostPlatform_CPP@_TARGET = 1 -@HostPlatform_CPP@_BUILD = 1 +# Default fptools options for dllwrap. +SRC_BLD_DLL_OPTS += -mno-cygwin --target=i386-mingw32 -@HostArch_CPP@_HOST_ARCH = 1 -@HostArch_CPP@_TARGET_ARCH = 1 -@HostArch_CPP@_BUILD_ARCH = 1 +# Flags for CPP when running GreenCard on .pgc files +GC_CPP_OPTS += -P -E -x c -traditional -D__GLASGOW_HASKELL__ -@HostOS_CPP@_HOST_OS = 1 -@HostOS_CPP@_TARGET_OS = 1 -@HostOS_CPP@_BUILD_OS = 1 -@HostVendor_CPP@_HOST_VENDOR = 1 -@HostVendor_CPP@_TARGET_VENDOR = 1 -@HostVendor_CPP@_BUILD_VENDOR = 1 - -# Leading underscores on symbol names in object files -# Valid options: YES/NO -# -LeadingUnderscore=@LeadingUnderscore@ - -################################################################################# +################################################################################ # # Utilities programs: where to find them # -################################################################################# +################################################################################ #----------------------------------------------------------------------------- # FPtools Utility locations @@ -438,93 +674,159 @@ LeadingUnderscore=@LeadingUnderscore@ # override the various *_PREFIX in build.mk, i.e., having the following # in build.mk: # -# FASTMAKE_PREFIX= +# MKDEPENDC_PREFIX= # -# will force `make' to rummage around in your PATH to find `fastmake' (not +# will force `make' to rummage around in your PATH to find `mkdependC' (not # sure it would need it in the first place, but still). # GLAFP_UTILS = $(FPTOOLS_TOP)/glafp-utils SCRIPT_PREFIX = $(GLAFP_UTILS)/scripts/ -FASTMAKE_PREFIX = $(GLAFP_UTILS)/fastmake/ MKDEPENDC_PREFIX = $(GLAFP_UTILS)/mkdependC/ LTX_PREFIX = $(GLAFP_UTILS)/ltx/ RUNTEST_PREFIX = $(GLAFP_UTILS)/runstdtest/ VERBATIM_PREFIX = $(GLAFP_UTILS)/verbatim/ +SGMLVERB_PREFIX = $(GLAFP_UTILS)/sgmlverb/ ETAGS_PREFIX = $(GLAFP_UTILS)/etags/ -MSUB_PREFIX = $(GLAFP_UTILS)/msub/ LNDIR_PREFIX = $(GLAFP_UTILS)/lndir/ MKDIRHIER_PREFIX = $(GLAFP_UTILS)/mkdirhier/ +DOCBOOK_PREFIX = $(GLAFP_UTILS)/docbook/ -# Still used? -LITERATE = $(FPTOOLS_TOP)/literate +HADDOCK_PREFIX = $(FPTOOLS_TOP)/haddock/ LITERATE_PREFIX = $(FPTOOLS_TOP)/literate/ -INFO_PREFIX = $(FPTOOLS_TOP)/literate/info-utils/ -TEXI2HTML_PREFIX = $(LITERATE_PREFIX)texi2html/ - -HAPPY_PREFIX = $(FPTOOLS_TOP)/happy/src/ UNLIT_PREFIX = $(FPTOOLS_TOP)/ghc/utils/unlit/ -UGEN_PREFIX = $(FPTOOLS_TOP)/ghc/utils/ugen/ -STAT2RESID_PREFIX = $(FPTOOLS_TOP)/ghc/utils/stat2resid/ HP2PS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hp2ps/ -HSCPP_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hscpp/ -HSTAGS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hstags/ - +HSTAGS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hasktags/ +HSC2HS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hsc2hs/ #----------------------------------------------------------------------------- -# Haskell compiler and mkdependHS - -HC = $(FPTOOLS_TOP)/ghc/driver/ghc -MKDEPENDHS = $(HC) +# Haskell compilers and mkdependHS +# $(GHC), $(HBC) and $(NHC) point to installed versions of the relevant +# compilers, if available. # -# The compiler proper is built with the 1.2 compiler, -# so when building the dependencies, we need mkdependHS -# for the 1.2 compiler. +# $(HC) is a generic Haskell 98 compiler, set to $(GHC) by default. +# $(MKDEPENDHS) is the Haskell dependency generator (ghc -M). # -MKDEPENDHS_1_2 = mkdependHS-1.2 +# NOTE: Don't override $(GHC) in build.mk, use configure --with-ghc instead +# (because the version numbers have to be calculated). + +GHC = @WithGhc@ +GhcDir = $(dir $(GHC)) +GhcVersion = @GhcVersion@ +GhcMajVersion = @GhcMajVersion@ +GhcMinVersion = @GhcMinVersion@ +GhcPatchLevel = @GhcPatchLevel@ + +# Canonicalised ghc version number, used for easy (integer) version +# comparisons. We must expand $(GhcMinVersion) to two digits by +# adding a leading zero if necessary: +ifneq "$(findstring $(GhcMinVersion), 0 1 2 3 4 5 6 7 8 9)" "" +GhcCanonVersion = $(GhcMajVersion)0$(GhcMinVersion) +else +GhcCanonVersion = $(GhcMajVersion)$(GhcMinVersion) +endif + +HBC = @HBC@ +NHC = @NHC@ + +HC = @WithHc@ +MKDEPENDHS = $(GHC) + +# Sometimes we want to invoke ghc from the build tree in different +# projects (eg. it's handy to have a nofib & a ghc build in the same +# tree). We can refer to "this ghc" as $(GHC_INPLACE): + +GHC_INPLACE = $(FPTOOLS_TOP)/ghc/compiler/ghc-inplace +GHC_STAGE1 = $(FPTOOLS_TOP)/ghc/compiler/stage1/ghc-inplace +GHC_STAGE2 = $(FPTOOLS_TOP)/ghc/compiler/stage2/ghc-inplace +GHC_STAGE3 = $(FPTOOLS_TOP)/ghc/compiler/stage3/ghc-inplace #----------------------------------------------------------------------------- # C compiler # -# +# NB. Don't override $(WhatGccIsCalled) using build.mk, re-configure using +# the flag --with-gcc= instead. The reason is that the configure script +# needs to know which gcc you're using in order to perform its tests. + HaveGcc = @HaveGcc@ UseGcc = YES -WhatGccIsCalled = gcc +WhatGccIsCalled = @WhatGccIsCalled@ +GccVersion = @GccVersion@ ifeq "$(strip $(HaveGcc))" "YES" ifneq "$(strip $(UseGcc))" "YES" CC = cc else CC = $(WhatGccIsCalled) + GccDir = $(dir $(WhatGccIsCalled)) +endif endif + +# default C compiler flags +SRC_CC_OPTS = @SRC_CC_OPTS@ + +ifeq "$(TARGETPLATFORM)" "ia64-unknown-linux" +SRC_CC_OPTS += -G0 endif +# Solaris2 strikes again. +unix_SRC_HSC2HS_OPTS += @unix_SRC_HSC2HS_OPTS@ + #----------------------------------------------------------------------------- -# Flex +# GMP Library (version 2.0.x or above) +# +HaveLibGmp = @HaveLibGmp@ +LibGmp = @LibGmp@ -FLEX = @LEX@ -FLEX_LIB = @LEXLIB@ +#----------------------------------------------------------------------------- +# Mingwex Library +# +HaveLibMingwEx = @HaveLibMingwEx@ + +#----------------------------------------------------------------------------- +# HaskellSupport framework (Mac OS X) +# +HaveFrameworkHaskellSupport = @HaveFrameworkHaskellSupport@ + +#----------------------------------------------------------------------------- +# Regex library +# (if present in libc use that one, otherwise use the one in the tree) +# +HavePosixRegex = @HavePosixRegex@ + +#----------------------------------------------------------------------------- +# GTK+ + +GTK_CONFIG = @GTK_CONFIG@ + +#----------------------------------------------------------------------------- +# Flex (currently unused, could be moved to glafp-utils) + +# FLEX = @LEX@ +# Don't bother with -lfl, we define our own yywrap()s anyway. +# FLEX_LIB = +#WAS:FLEX_LIB = @LEXLIB@ #----------------------------------------------------------------------------- # Other standard (ha!) Unix utilities AR = @ArCmd@ +ArSupportsInput = @ArSupportsInput@ # Yuckage: for ghc/utils/parallel -- todo: nuke this dependency!! BASH = /usr/local/bin/bash -# -# Could be either gzip or compress -# -COMPRESS = @CompressCmd@ -COMPRESS_SUFFIX = @CompressSuffix@ CONTEXT_DIFF = @ContextDiffCmd@ CP = cp -CPP = @RAWCPP@ +CPP = @CPP@ @CPPFLAGS@ CTAGS = $(ETAGS) -RAWCPP = @RAWCPP@ -GNUCPP = @GNUCPP@ +# +# RAWCPP_FLAGS are the flags to give to cpp (viz, gcc -E) to persuade it to +# behave plausibly on Haskell sources. +# +RAWCPP_FLAGS = -undef -traditional +FIND = @FindCmd@ INSTALL = @INSTALL@ # # Sigh - the autoconf macro for INSTALL will subst a relative path to the fallback @@ -533,19 +835,28 @@ INSTALL = @INSTALL@ # INSTALL := $(subst .././install-sh,$(FPTOOLS_TOP_ABS)/install-sh,$(INSTALL)) LATEX = latex +HEVEA = hevea +HACHA = hacha LN_S = @LN_S@ MANMACROS = -man MSMACROS = -ms MV = mv NROFF = nroff PERL = @PerlCmd@ +PYTHON = @PythonCmd@ PIC = pic PREPROCESSCMD = $(CC) -E -PRINTER = lpr RANLIB = @RANLIB@ RM = rm -f SED = @SedCmd@ SHELL = /bin/sh + +# Some ld's support the -x flag and some don't, so the configure +# script detects which we have and sets LdXFlag to "-x" or "" +# respectively. +LD = @LdCmd@ +LD_X = @LdXFlag@ + # # In emergency situations, REAL_SHELL is used to perform shell commands # from within the ghc driver script, by scribbling the command line to @@ -560,8 +871,8 @@ SHELL = /bin/sh # We do not use SHELL to execute long commands, as `make' will more than likely # override whatever setting you have in your environment while executing. -# By default, REAL_SHELL is set equal SHELL, which is not really a smart move -# as it SHELL that will show up the bogosity in the first place, but setting +# By default, REAL_SHELL is set equal to SHELL, which is not really a smart move +# as it is SHELL that will show up the bogosity in the first place, but setting # it to anything else isn't really portable. # # ====> If long command lines cause you trouble, invoke `ghc' (via `make' or otherwise) @@ -572,6 +883,8 @@ REAL_SHELL=$(SHELL) SIZE = size STRIP = strip TAR = @TarCmd@ +ZIP = zip + # # This is special to literate/, ToDo: add literate-specific # configure setup to literate/. @@ -585,59 +898,109 @@ TIB = tib TIME = @TimeCmd@ TROFF = troff UNAME = uname -YACC = @YaccCmd@ +#----------------------------------------------------------------------------- +# DocBook XML stuff + +XSLTPROC = @XsltprocCmd@ +XMLLINT = @XmllintCmd@ +FOP = @FopCmd@ +XMLTEX = @XmltexCmd@ +PDFXMLTEX = @PdfxmltexCmd@ +DVIPS = @DvipsCmd@ + +DIR_DOCBOOK_XSL = @DIR_DOCBOOK_XSL@ + +XSLTPROC_LABEL_OPTS = --stringparam toc.section.depth 3 \ + --stringparam section.autolabel 1 \ + --stringparam section.label.includes.component.label 1 #----------------------------------------------------------------------------- # FPtools support software # Stuff from fptools/glafp-utils MKDEPENDC = $(MKDEPENDC_PREFIX)mkdependC -FASTMAKE = $(FASTMAKE_PREFIX)fastmake LTX = $(LTX_PREFIX)ltx MKDIRHIER = $(MKDIRHIER_PREFIX)mkdirhier LNDIR = $(LNDIR_PREFIX)lndir -MSUB = $(MSUB_PREFIX)msub ETAGS = $(ETAGS_PREFIX)etags VERBATIM = $(VERBATIM_PREFIX)verbatim +SGMLVERB = $(SGMLVERB_PREFIX)sgmlverb RUNTEST = $(RUNTEST_PREFIX)runstdtest -HAPPY = @HappyCmd@ LX = @LxCmd@ -ifeq "$(HAPPY)" "" -HAPPY = $(HAPPY_PREFIX)happy -endif +BLD_DLL = dllwrap + +# +# .NET support software +# +ILX2IL = ilx2il +ILASM = ilasm + +# +# ghc-pkg +# +GHC_PKG = @GhcPkgCmd@ + +# +# GreenCard +# +GREENCARD = @GreenCardCmd@ +GREENCARD_VERSION = @GreenCardVersion@ + +# +# Happy +# +HAPPY = @HappyCmd@ +HAPPY_VERSION = @HappyVersion@ +# +# Options to pass to Happy when we're going to compile the output with GHC +# +GHC_HAPPY_OPTS = -agc + +# Temp. to work around performance problems in the HEAD around 8/12/2003, +# A Happy compiled with this compiler needs more stack. +SRC_HAPPY_OPTS = +RTS -K2m -RTS + +# +# Alex +# +ALEX = @AlexCmd@ +ALEX_VERSION = @AlexVersion@ +# +# Options to pass to Happy when we're going to compile the output with GHC +# +GHC_ALEX_OPTS = -g + +# +# Haddock +# +HADDOCK = @HaddockCmd@ +HADDOCK_INPLACE = $(HADDOCK_PREFIX)/src/haddock-inplace # # Stuff from fptools/literate # -INFO = $(UTIL_PREFIX)info -MAKEINFO = $(INFO_PREFIX)makeinfo -POSTMAKEINFO = $(INFO_PREFIX)postmakeinfo LIT2PGM = $(LITERATE_PREFIX)lit2pgm -LIT2TEXI = $(LITERATE_PREFIX)lit2texi LIT2HTML = $(LITERATE_PREFIX)lit2html LIT2LATEX = $(LITERATE_PREFIX)lit2latex MKDEPENDLIT = $(LITERATE_PREFIX)mkdependlit LIT2CHANGELOG = $(LITERATE_PREFIX)lit2changelog LIT2TEXT = $(LITERATE_PREFIX)lit2text -TEXI2HTML = $(TEXI2HTML_PREFIX)texi2html # # Stuff from fptools/ghc/utils # -UNLIT = $(UNLIT_PREFIX)unlit -UGEN = $(UGEN_PREFIX)ugen -STAT2RESID = $(STAT2RESID_PREFIX)stat2resid -HP2PS = $(HP2PS_PREFIX)hp2ps -HSCPP = $(HSCPP_PREFIX)hscpp -HSTAGS = $(HSTAGS_PREFIX)hstags +UNLIT = $(UNLIT_PREFIX)unlit$(exeext) +HP2PS = $(HP2PS_PREFIX)hp2ps$(exeext) +HSTAGS = $(HSTAGS_PREFIX)hasktags +HSC2HS = $(HSC2HS_PREFIX)hsc2hs-inplace # # Options for the compiling different `ways'. Various projects within # the glorious fptools tree support building in various user-configured # ways. For instance, you could set up one `way' such that the prelude -# libraries and hslibs all were built with the option -ffoldr-build-on. +# libraries all were built with the option -ffoldr-build-on. # # To configure up your own way, have a look at some of the standard ways # such as profiling, and create your own set of WAY_*_OPTS defs below. @@ -669,60 +1032,72 @@ HSTAGS = $(HSTAGS_PREFIX)hstags # # The ways currently defined. # -ALL_WAYS=p t u mc mr mt mp mg 1s 2s du a b c d e f g h i j k l m n o A B +ALL_WAYS=p t u s mp mg a b c d e f g h i j k l m n o A B +USER_WAYS=a b c d e f g h j k l m n o A B # -# The following ways currently have treated specially, p u t mc mt my mp mg 1s 2d du, +# The following ways currently have treated specially, p u t mg, # as the driver script treats these guys specially and needs to carefully be told # about the options for these. Hence, we hide the required command line options # for these in the ghc/driver, as this is the only place they are needed. # # If you want to add to these default options, fill in the variables below: -# + +# Way 'i': +WAY_i_NAME=ILX +WAY_i_HC_OPTS= -filx -fruntime-types + +# Way 'p': WAY_p_NAME=profiling WAY_p_HC_OPTS= -prof -# Way t: +# Way 't': WAY_t_NAME=ticky-ticky profiling WAY_t_HC_OPTS= -ticky # Way `u': WAY_u_NAME=unregisterized (using portable C only) -WAY_u_HC_OPTS= +WAY_u_HC_OPTS=-unreg -# Way `mc': concurrent -WAY_mc_NAME=concurrent -WAY_mc_HC_OPTS=-concurrent - -# Way `mr': -WAY_mr_NAME=profiled concurrent -WAY_mr_HC_OPTS=-prof -concurrent - -# Way `mt': -WAY_mt_NAME=ticky-ticky concurrent -WAY_mt_HC_OPTS=-ticky -concurrent +# Way `s': +WAY_s_NAME=threads (for SMP) +WAY_s_HC_OPTS=-smp # Way `mp': WAY_mp_NAME=parallel WAY_mp_HC_OPTS=-parallel -# # Way `mg': -# WAY_mg_NAME=GranSim WAY_mg_HC_OPTS=-gransim # -# Ways for different garbage collectors +# These ways apply to the RTS only: # -WAY_2s_NAME=2-space GC -WAY_2s_HC_OPTS=-2s -WAY_1s_NAME=1-space GC -WAY_1s_HC_OPTS=-1s +# Way 'thr': +WAY_thr_NAME=threaded +WAY_thr_HC_OPTS=-optc-DTHREADED_RTS + +# Way 'thr_p': +WAY_thr_p_NAME=threaded profiled +WAY_thr_p_HC_OPTS=-optc-DTHREADED_RTS -prof + +# Way 'debug': +WAY_debug_NAME=debug +WAY_debug_HC_OPTS=-optc-DDEBUG + +# Way 'debug_p': +WAY_debug_p_NAME=debug profiled +WAY_debug_p_HC_OPTS=-optc-DDEBUG -prof + +# Way 'thr_debug': +WAY_thr_debug_NAME=threaded +WAY_thr_debug_HC_OPTS=-optc-DTHREADED_RTS -optc-DDEBUG -WAY_du_NAME=dual-mode GC -WAY_du_HC_OPTS=-du +# Way 'thr_debug_p': +WAY_thr_debug_p_NAME=threaded +WAY_thr_debug_p_HC_OPTS=-optc-DTHREADED_RTS -optc-DDEBUG -prof # # Add user-way configurations here: @@ -757,9 +1132,6 @@ WAY_g_HC_OPTS= WAY_h_NAME= WAY_h_HC_OPTS= -WAY_i_NAME= -WAY_i_HC_OPTS= - WAY_j_NAME= WAY_j_HC_OPTS= @@ -777,3 +1149,23 @@ WAY_n_HC_OPTS= WAY_o_NAME= WAY_o_HC_OPTS= + +################################################################################ +# +# 31-bit-Int Core files +# +################################################################################ + +# +# It is possible to configure the compiler and prelude to support 31-bit +# integers, suitable for a back-end and RTS using a tag bit on a 32-bit +# architecture. Currently the only useful output from this option is external Core +# files. The following additions to your build.mk will produce the +# 31-bit core output. Note that this is *not* just a library "way"; the +# compiler must be built a special way too. + +# GhcCppOpts +=-DWORD_SIZE_IN_BITS=31 +# GhcLibHcOpts +=-fext-core -fno-code -DWORD_SIZE_IN_BITS=31 +# GhcLibCppOpts += -DWORD_SIZE_IN_BITS=31 +# SplitObjs=NO +