X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rts%2FMakefile;h=6bf42712cb8230d7ca2fcc5a8ef3dd1acfd9eb22;hb=ca5ded310c0a596be199a3da5f14be2fb2020687;hp=67201cded58ee9f97784d9b48406c2312a3591dc;hpb=f638fdfe1d9de1307355c8074fbff9c28342c0ef;p=ghc-hetmet.git diff --git a/rts/Makefile b/rts/Makefile index 67201cd..6bf4271 100644 --- a/rts/Makefile +++ b/rts/Makefile @@ -44,7 +44,7 @@ endif NON_HS_PACKAGE = YES # grab sources from these subdirectories -ALL_DIRS = hooks parallel +ALL_DIRS = hooks parallel sm ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" ALL_DIRS += win32 @@ -88,7 +88,7 @@ H_FILES = $(wildcard ../includes/*.h) $(wildcard *.h) # gcc provides lots of useful warnings if you ask it. # This is a pretty good list to start with - use a # to comment out # any you don't like. -WARNING_OPTS += -Wall +WARNING_OPTS += -Wall WARNING_OPTS += -W WARNING_OPTS += -Wstrict-prototypes WARNING_OPTS += -Wmissing-prototypes @@ -96,7 +96,7 @@ WARNING_OPTS += -Wmissing-declarations WARNING_OPTS += -Winline WARNING_OPTS += -Waggregate-return #WARNING_OPTS += -Wpointer-arith -WARNING_OPTS += -Wbad-function-cast +#WARNING_OPTS += -Wbad-function-cast #WARNING_OPTS += -Wcast-align #WARNING_OPTS += -Wnested-externs #WARNING_OPTS += -Wshadow @@ -105,7 +105,7 @@ WARNING_OPTS += -Wbad-function-cast #WARNING_OPTS += -Wredundant-decls #WARNING_OPTS += -Wconversion -STANDARD_OPTS += -I../includes -I. -Iparallel +STANDARD_OPTS += -I../includes -I. -Iparallel -Ism # COMPILING_RTS is only used when building Win32 DLL support. STANDARD_OPTS += -DCOMPILING_RTS @@ -119,6 +119,11 @@ SRC_CC_OPTS += $(STANDARD_OPTS) SRC_CC_OPTS += $(GhcRtsCcOpts) SRC_HC_OPTS += $(GhcRtsHcOpts) +ifneq "$(GhcWithSMP)" "YES" +SRC_CC_OPTS += -DNOSMP +SRC_HC_OPTS += -optc-DNOSMP +endif + ifneq "$(DLLized)" "YES" SRC_HC_OPTS += -static endif @@ -139,6 +144,10 @@ ifeq "$(HaveLibMingwEx)" "YES" PACKAGE_CPP_OPTS += -DHAVE_LIBMINGWEX endif +ifeq "$(GhciWithDebugger)" "YES" +STANDARD_OPTS += -DDEBUGGER +endif + ifeq "$(DotnetSupport)" "YES" # @@ -174,6 +183,14 @@ EXCLUDED_SRCS += $(wildcard Vis*.c) endif #----------------------------------------------------------------------------- +# Add PAPI library if needed + +ifeq "$(GhcRtsWithPapi)" "YES" +SRC_HC_OPTS += -optc-DUSE_PAPI +PACKAGE_CPP_OPTS += -DUSE_PAPI +endif + +#----------------------------------------------------------------------------- # make depend setup SRC_MKDEPENDC_OPTS += -I. -I../includes @@ -239,7 +256,7 @@ boot :: if [ -f gmp/config.status ]; then \ cd gmp && CC=$(WhatGccIsCalled) ./config.status; \ else \ - cd gmp && CC=$(WhatGccIsCalled) ./configure --enable-shared=no \ + cd gmp && CC=$(WhatGccIsCalled) $(SHELL) configure --enable-shared=no \ --host=`echo $(HOSTPLATFORM) | sed 's/i[567]86/i486/g'`; \ fi @@ -275,6 +292,24 @@ endif CLEAN_FILES += gmp/libgmp.a +# Need to get the GMP vars in through CPP to package.conf.in, and put +# quotes around each element. + +empty = +space = $(empty) $(empty) +comma = , +PACKAGE_CPP_OPTS += -DGMP_INCLUDE_DIRS='$(subst $(space),$(comma),$(patsubst %,"%",$(strip $(GMP_INCLUDE_DIRS))))' +PACKAGE_CPP_OPTS += -DGMP_LIB_DIRS='$(subst $(space),$(comma),$(patsubst %,"%",$(strip $(GMP_LIB_DIRS))))' + +ifneq "$(GMP_INCLUDE_DIRS)" "" +SRC_HC_OPTS += -I$(GMP_INCLUDE_DIRS) +SRC_CC_OPTS += -I$(GMP_INCLUDE_DIRS) +SRC_HSC2HS_OPTS += -I$(GMP_INCLUDE_DIRS) +endif +ifneq "$(GMP_LIB_DIRS)" "" +SRC_LD_OPTS += -L$(GMP_LIB_DIRS) +endif + #----------------------------------------------------------------------------- # # Building the GUM SysMan @@ -301,26 +336,7 @@ endif # Compiling the cmm files # ToDo: should we really include Rts.h here? Required for GNU_ATTRIBUTE(). -SRC_HC_OPTS += \ - -I. \ - -\#include Prelude.h \ - -\#include Rts.h \ - -\#include RtsFlags.h \ - -\#include RtsUtils.h \ - -\#include StgRun.h \ - -\#include Schedule.h \ - -\#include Printer.h \ - -\#include Sanity.h \ - -\#include STM.h \ - -\#include Storage.h \ - -\#include SchedAPI.h \ - -\#include Timer.h \ - -\#include ProfHeap.h \ - -\#include LdvProfile.h \ - -\#include Profiling.h \ - -\#include OSThreads.h \ - -\#include Apply.h \ - -\#include SMP.h +SRC_HC_OPTS += -I. -\#include HCIncludes.h ifeq "$(Windows)" "YES" PrimOps_HC_OPTS += -\#include '' -\#include win32/AsyncIO.h @@ -334,10 +350,18 @@ SRC_HC_OPTS += -optc-fno-stack-protector endif # -O3 helps unroll some loops (especially in copy() with a constant argument). -# -fno-strict-aliasing is a hack because we often mix StgPtr and StgClosure pointers -# to the same object, and gcc will assume these don't alias. eg. it happens in -# copy() with gcc 3.4.3, the upd_evacee() assigments get moved before the object copy. -GC_HC_OPTS += -optc-O3 -optc-fno-strict-aliasing +sm/Evac_HC_OPTS += -optc-funroll-loops + +# Without this, thread_obj will not be inlined (at least on x86 with GCC 4.1.0) +sm/Compact_HC_OPTS += -optc-finline-limit=2500 + +# -fno-strict-aliasing is required for the runtime, because we often +# use a variety of types to represent closure pointers (StgPtr, +# StgClosure, StgMVar, etc.), and without -fno-strict-aliasing gcc is +# allowed to assume that these pointers do not alias. eg. without +# this flag we get problems in GC.c:copy() with gcc 3.4.3, the +# upd_evacee() assigments get moved before the object copy. +SRC_CC_OPTS += -fno-strict-aliasing # Cmm must be compiled via-C for now, because the NCG can't handle loops SRC_HC_OPTS += -fvia-C