]> git.saurik.com Git - apple/xnu.git/blobdiff - makedefs/MakeInc.def
xnu-792.24.17.tar.gz
[apple/xnu.git] / makedefs / MakeInc.def
index fb14d0d33b8a5f2a4034f6043afa8527cac4932f..73842031c4b9702f76b27ff4e29285ec6e7a66f5 100644 (file)
@@ -16,14 +16,6 @@ export INCR_EXPORTHDRS       = FALSE
 endif
 endif
 
-ifndef INCR_INSTALLHDRS
-ifeq ($(shell test -d $$DSTROOT/$INCDIR;echo $$?),0)
-export INCR_INSTALLHDRS        = TRUE
-else
-export INCR_INSTALLHDRS        = FALSE
-endif
-endif
-
 #
 # Component List
 #
@@ -90,7 +82,7 @@ export INSTALL_ARCH_DEFAULT   = PPC
 #
 # Standard defines list
 #
-export DEFINES = -DAPPLE -DNeXT -DKERNEL_PRIVATE -D__MACHO__=1 -Dvolatile=__volatile $(IDENT)
+export DEFINES = -DAPPLE -DNeXT -DKERNEL -DKERNEL_PRIVATE -DXNU_KERNEL_PRIVATE -DPRIVATE -D__MACHO__=1 -Dvolatile=__volatile $(IDENT)
 
 #
 # Compiler command
@@ -99,6 +91,34 @@ KCC  = /usr/bin/cc
 KC++ = /usr/bin/c++
 CC   = $(KCC)
 
+#
+# Compiler warning flags
+#
+
+CWARNFLAGS_STD = \
+       -Wall -Wno-format-y2k -W -Wstrict-prototypes -Wmissing-prototypes \
+       -Wpointer-arith -Wreturn-type -Wcast-qual -Wwrite-strings -Wswitch \
+       -Wshadow -Wcast-align -Wbad-function-cast -Wchar-subscripts -Winline \
+       -Wnested-externs -Wredundant-decls
+
+export CWARNFLAGS ?= $(CWARNFLAGS_STD)
+
+MWARNFLAGS_STD = \
+       -Wall -Wno-format-y2k -W -Wstrict-prototypes -Wmissing-prototypes \
+       -Wpointer-arith -Wreturn-type -Wcast-qual -Wwrite-strings -Wswitch \
+       -Wshadow -Wcast-align -Wbad-function-cast -Wchar-subscripts -Winline \
+       -Wnested-externs -Wredundant-decls
+
+export MWARNFLAGS ?= $(MWARNFLAGS_STD)
+
+CXXWARNFLAGS_STD = \
+       -Wall -Wno-format-y2k -W -Wstrict-prototypes -Wmissing-prototypes \
+       -Wpointer-arith -Wreturn-type -Wcast-qual -Wwrite-strings -Wswitch \
+       -Wshadow -Wcast-align -Wchar-subscripts -Winline -Wredundant-decls \
+       -fpermissive
+
+export CXXWARNFLAGS ?= $(CXXWARNFLAGS_STD)
+
 
 #
 # Setup for parallel sub-makes when doing an RC build
@@ -118,20 +138,23 @@ endif
 
 export CFLAGS_GEN = -static -g -nostdinc -nostdlib -no-cpp-precomp \
        -fno-builtin -finline -fno-keep-inline-functions -msoft-float \
-       -fsigned-bitfields -Wpointer-arith $(OTHER_CFLAGS) -fpermissive 
+       -fsigned-bitfields $(OTHER_CFLAGS)
 
 export CFLAGS_RELEASE  = 
-export CFLAGS_DEBUG    = -fno-omit-frame-pointer
-export CFLAGS_PROFILE  = 
+export CFLAGS_DEBUG    = 
+export CFLAGS_PROFILE  =  -pg
 
-export CFLAGS_PPC      = -arch ppc -Dppc -DPPC -D__PPC__ -D_BIG_ENDIAN=__BIG_ENDIAN__
-export CFLAGS_I386     = -arch i386 -Di386 -DI386 -D__I386__ -D_BIG_ENDIAN=__LITTLE_ENDIAN__
+export CFLAGS_PPC      = -arch ppc -Dppc -DPPC -D__PPC__ -DPAGE_SIZE_FIXED
+export CFLAGS_I386     = -arch i386 -Di386 -DI386 -D__I386__ -DPAGE_SIZE_FIXED \
+       -march=i686 -mpreferred-stack-boundary=2 -falign-functions=4 -mcpu=pentium4 -force_cpusubtype_ALL
 
 export CFLAGS_RELEASEPPC = -O2 -mcpu=750 -mmultiple -fschedule-insns
 export CFLAGS_RELEASE_TRACEPPC = -O2 -mcpu=750 -mmultiple -fschedule-insns
-export CFLAGS_DEBUGPPC = -O1 -mcpu=750 -mmultiple -fschedule-insns
-export CFLAGS_RELEASEI386 = -O2
-export CFLAGS_DEBUGI386 = -O2
+export CFLAGS_DEBUGPPC = -O2 -mcpu=750 -mmultiple -fschedule-insns
+export CFLAGS_PROFILEPPC = -O2 -mcpu=750 -mmultiple -fschedule-insns
+export CFLAGS_RELEASEI386 = -Os
+export CFLAGS_DEBUGI386 = -Os
+export CFLAGS_PROFILEI386 = -Os
 
 export CFLAGS  = $(CFLAGS_GEN) \
                  $($(addsuffix $(ARCH_CONFIG),CFLAGS_)) \
@@ -139,16 +162,13 @@ export CFLAGS     = $(CFLAGS_GEN) \
                  $($(addsuffix $(ARCH_CONFIG), $(addsuffix $(KERNEL_CONFIG),CFLAGS_))) \
                  $(DEFINES)
 
-# Default CCFLAGS
-#(we do not call it CPPFLAGS as that has a special meaning in unix tradition
-# and in gcc: CPPFLAGS is for C Pre-Processor flags.  CCFLAGS has precedent
-# in ProjectBuilder because of the .cc extension)
+# Default C++ flags
 #
-CPPFLAGS_GEN  = -fno-rtti -fno-exceptions -fcheck-new -fapple-kext 
+CXXFLAGS_GEN  = -fno-rtti -fno-exceptions -fcheck-new -fapple-kext -fpermissive
 
-CPPFLAGS      = $(CPPFLAGS_GEN) \
-                 $($(addsuffix $(ARCH_CONFIG),CCFLAGS_)) \
-                 $($(addsuffix $(KERNEL_CONFIG),CCFLAGS_))
+CXXFLAGS      = $(CXXFLAGS_GEN) \
+                 $($(addsuffix $(ARCH_CONFIG),CXXFLAGS_)) \
+                 $($(addsuffix $(KERNEL_CONFIG),CXXFLAGS_))
 
 #
 # Assembler command
@@ -181,28 +201,46 @@ LD        = /usr/bin/ld
 #
 # Default LDFLAGS
 #
-export LDFLAGS_COMPONENT_GEN = -static -r 
+export LDFLAGS_COMPONENT_GEN = -static -r $(COMP_LDFLAGS_COMPONENT_GEN)
 
-export LDFLAGS_COMPONENT_RELEASE       = 
-export LDFLAGS_COMPONENT_DEBUG                 = 
-export LDFLAGS_COMPONENT_PROFILE       = 
+export LDFLAGS_COMPONENT_RELEASE =  $(COMP_LDFLAGS_COMPONENT_RELEASE)
+export LDFLAGS_COMPONENT_DEBUG   =  $(COMP_LDFLAGS_COMPONENT_DEBUG)
+export LDFLAGS_COMPONENT_PROFILE =  $(COMP_LDFLAGS_COMPONENT_PROFILE)
 
-export LDFLAGS_COMPONENT_PPC   = -arch ppc
-export LDFLAGS_COMPONENT_I386  = -arch i386
+export LDFLAGS_COMPONENT_PPC   = -arch ppc $(COMP_LDFLAGS_COMPONENT_PPC)
+export LDFLAGS_COMPONENT_I386  = -arch i386 $(COMP_LDFLAGS_COMPONENT_i386)
 
 export LDFLAGS_COMPONENT       = $(LDFLAGS_COMPONENT_GEN) \
                  $($(addsuffix $(ARCH_CONFIG),LDFLAGS_COMPONENT_)) \
                  $($(addsuffix $(KERNEL_CONFIG),LDFLAGS_COMPONENT_))
 
-export LDFLAGS_KERNEL_GEN = -static -force_cpusubtype_ALL -segalign 0x1000
+export LDFLAGS_KERNEL_GEN = \
+       -static \
+       -force_cpusubtype_ALL \
+       -e __start \
+       -segalign 0x1000 \
+       -sectalign __TEXT __text 0x1000 \
+       -sectalign __DATA __common 0x1000 \
+       -sectalign __DATA __bss 0x1000 \
+       -sectcreate __PRELINK __text /dev/null \
+       -sectcreate __PRELINK __symtab /dev/null \
+       -sectcreate __PRELINK __info /dev/null
 
 export LDFLAGS_KERNEL_RELEASE  =
 #  -noseglinkedit
 export LDFLAGS_KERNEL_DEBUG    = 
 export LDFLAGS_KERNEL_PROFILE  = 
 
-export LDFLAGS_KERNEL_PPC      = -arch ppc -segaddr __VECTORS 0x0 -segaddr __TEXT 0x11000 -e __start -sectalign __DATA __common 0x1000 -sectalign __DATA __bss 0x1000
-export LDFLAGS_KERNEL_I386     = -arch i386 -segaddr __TEXT 0x100000 -e _pstart
+export LDFLAGS_KERNEL_PPC      = \
+       -arch ppc \
+       -segaddr __VECTORS 0x0 \
+       -segaddr __HIB 0x7000  \
+       -segaddr __TEXT 0xe000
+export LDFLAGS_KERNEL_I386     = \
+       -arch i386 \
+       -segaddr __HIB  0xC0100000 \
+       -segaddr __TEXT 0xC0111000
 
 export LDFLAGS_KERNEL  = $(LDFLAGS_KERNEL_GEN) \
                  $($(addsuffix $(ARCH_CONFIG),LDFLAGS_KERNEL_)) \
@@ -219,7 +257,7 @@ export LD_KERNEL_LIBS       = -lcc_kext
 #
 export INCFLAGS_IMPORT         = $(patsubst %, -I$(OBJROOT)/EXPORT_HDRS/%, $(COMPONENT_IMPORT_LIST))
 export INCFLAGS_EXTERN         = -I$(OBJROOT)/EXTERN_HDRS -I$(SRCROOT)/EXTERNAL_HEADERS -I$(SRCROOT)/EXTERNAL_HEADERS/bsd
-export INCFLAGS_GEN    = -I$(SRCROOT)/$(COMPONENT) 
+export INCFLAGS_GEN    = -I$(SRCROOT)/$(COMPONENT) -I$(OBJROOT)/EXPORT_HDRS/$(COMPONENT)
 export INCFLAGS_POSIX  = -I$(OBJROOT)/EXPORT_HDRS/bsd
 export INCFLAGS_LOCAL  = -I.
 
@@ -265,6 +303,14 @@ KINCVERS = A
 KINCFRAME = $(FRAMEDIR)/Kernel.framework
 KINCDIR = $(KINCFRAME)/Versions/$(KINCVERS)/Headers
 KPINCDIR = $(KINCFRAME)/Versions/$(KINCVERS)/PrivateHeaders
+KRESDIR = $(KINCFRAME)/Versions/$(KINCVERS)/Resources
+
+XNU_PRIVATE_UNIFDEF = -UMACH_KERNEL_PRIVATE -UBSD_KERNEL_PRIVATE -UIOKIT_KERNEL_PRIVATE -ULIBKERN_KERNEL_PRIVATE -ULIBSA_KERNEL_PRIVATE -UPEXPERT_KERNEL_PRIVATE -UXNU_KERNEL_PRIVATE
+
+SPINCFRAME_UNIFDEF = $(XNU_PRIVATE_UNIFDEF) -UKERNEL_PRIVATE -UKERNEL -DPRIVATE
+SINCFRAME_UNIFDEF  = $(XNU_PRIVATE_UNIFDEF) -UKERNEL_PRIVATE -UKERNEL -UPRIVATE
+KPINCFRAME_UNIFDEF = $(XNU_PRIVATE_UNIFDEF) -DKERNEL_PRIVATE -DPRIVATE -DKERNEL
+KINCFRAME_UNIFDEF  = $(XNU_PRIVATE_UNIFDEF) -UKERNEL_PRIVATE -UPRIVATE -DKERNEL
 
 #
 # Compononent Header file destinations
@@ -274,10 +320,11 @@ EXPDIR = EXPORT_HDRS/$(COMPONENT)
 #
 # Strip Flags
 #
-export STRIP_FLAGS_RELEASE     = -S 
-export STRIP_FLAGS_RELEASE_TRACE       = -S 
+export STRIP_FLAGS_RELEASE     = -S -x 
+export STRIP_FLAGS_RELEASE_TRACE       = -S -x 
 export STRIP_FLAGS_DEBUG       = -S 
-export STRIP_FLAGS_PROFILE     = -S 
+export STRIP_FLAGS_DEBUG_TRACE = -S 
+export STRIP_FLAGS_PROFILE     = -S -x
 
 export STRIP_FLAGS     = $($(addsuffix $(KERNEL_CONFIG),STRIP_FLAGS_))