]> git.saurik.com Git - apple/xnu.git/blobdiff - libkern/conf/Makefile.template
xnu-7195.101.1.tar.gz
[apple/xnu.git] / libkern / conf / Makefile.template
index 0a4000c195257e106ded0b3db432a458953be273..2f78dc30e0c7cce44ee363a3d1ca1c35c4de42bd 100644 (file)
@@ -5,16 +5,6 @@
 # the terms and conditions for use and redistribution.
 #
 
-#
-# Export IDENT for sub-makefiles
-#
-export IDENT
-
-#
-# XXX: INCFLAGS 
-#
-INCFLAGS_MAKEFILE=  
-
 export MakeInc_cmd=${SRCROOT}/makedefs/MakeInc.cmd
 export MakeInc_def=${SRCROOT}/makedefs/MakeInc.def
 export MakeInc_rule=${SRCROOT}/makedefs/MakeInc.rule
@@ -24,17 +14,18 @@ include $(MakeInc_cmd)
 include $(MakeInc_def)
 
 #
-# XXX: CFLAGS
+# CFLAGS
 #
-CFLAGS+= -imacros meta_features.h -DKERNEL -DLIBKERN_KERNEL_PRIVATE -DOSALLOCDEBUG=1 \
-         -Wall -Wno-four-char-constants -fno-common  $(CFLAGS_INLINE_CONFIG)
+CFLAGS+= -include meta_features.h -DLIBKERN_KERNEL_PRIVATE -DOSALLOCDEBUG=1
+SFLAGS+= -include meta_features.h
 
-SFLAGS+= -DKERNEL
+# Runtime support functions don't interact well with LTO (9294679)
+stack_protector.o_CFLAGS_ADD += $(CFLAGS_NOLTO_FLAG)
 
 #
 # Directories for mig generated files
 #
-COMP_SUBDIRS = 
+COMP_SUBDIRS =
 
 #
 #  Make sure we don't remove this by accident if interrupted at the wrong
@@ -52,39 +43,135 @@ COMP_SUBDIRS =
 
 %OBJS
 
+%LIBOBJS
+
 %CFILES
 
-%MFILES
+%CXXFILES
 
 %SFILES
 
-%BFILES
-
-%ORDERED
 %MACHDEP
 
 #
-#  OBJSDEPS is the set of files (defined in the machine dependent
-#  template if necessary) which all objects depend on (such as an
-#  in-line assembler expansion filter)
-#
-${OBJS}: ${OBJSDEPS}
-
-
-%LOAD
-
-LDOBJS = $(OBJS)
-
-$(COMPONENT).o: $(LDOBJS)
-       @echo LD $(COMPONENT)
-       $(_v)$(LD)  $(LDFLAGS_COMPONENT) -o $(COMPONENT).o ${LDOBJS} 
-
-do_all: $(COMPONENT).o
-
-do_depend: do_all
-       $(_v)${MD} -u Makedep -f -d `ls *.d`
-       
-do_build_all: do_depend 
+# Machine-independent per-file flags
+#
+
+#
+# Diagnostic opt-outs.  We need to make this list empty.
+#
+# DO NOT ADD MORE HERE.
+#
+# -Wno-cast-align
+OSKext.cpo_CXXWARNFLAGS_ADD += -Wno-cast-align
+OSKextLib.cpo_CXXWARNFLAGS_ADD += -Wno-cast-align
+OSMetaClass.cpo_CXXWARNFLAGS_ADD += -Wno-cast-align
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-cast-align
+corecrypto_md5.o_CFLAGS_ADD += -Wno-cast-align
+corecrypto_sha1.o_CFLAGS_ADD += -Wno-cast-align
+# -Wno-cast-qual
+OSKext.cpo_CXXWARNFLAGS_ADD += -Wno-cast-qual
+compress.o_CFLAGS_ADD += -Wno-cast-qual
+deflate.o_CFLAGS_ADD += -Wno-cast-qual
+runtime.cpo_CXXWARNFLAGS_ADD += -Wno-cast-qual
+trees.o_CFLAGS_ADD += -Wno-cast-qual
+uncompr.o_CFLAGS_ADD += -Wno-cast-qual
+# -Wno-implicit-int-conversion
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-implicit-int-conversion
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-implicit-int-conversion
+kxld_sym.o_CFLAGS_ADD += -Wno-implicit-int-conversion
+log.o_CFLAGS_ADD += -Wno-implicit-int-conversion
+scanf.o_CFLAGS_ADD += -Wno-implicit-int-conversion
+# -Wno-missing-prototypes
+OSRuntime.cpo_CXXWARNFLAGS_ADD += -Wno-missing-prototypes
+# -Wno-shorten-64-to-32
+OSKext.cpo_CXXWARNFLAGS_ADD += -Wno-shorten-64-to-32
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-shorten-64-to-32
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-shorten-64-to-32
+log.o_CFLAGS_ADD += -Wno-shorten-64-to-32
+scanf.o_CFLAGS_ADD += -Wno-shorten-64-to-32
+# -Wno-sign-conversion
+OSCollection.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSData.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSDebug.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSKext.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSKextVersion.o_CFLAGS_ADD += -Wno-sign-conversion
+OSMetaClass.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSNumber.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSObject.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSRuntime.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSSerializeBinary.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSSet.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSString.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-sign-conversion
+adler32.o_CFLAGS_ADD += -Wno-sign-conversion
+corecrypto_aes.o_CFLAGS_ADD += -Wno-sign-conversion
+corecrypto_aesxts.o_CFLAGS_ADD += -Wno-sign-conversion
+deflate.o_CFLAGS_ADD += -Wno-sign-conversion
+inet_aton.o_CFLAGS_ADD += -Wno-sign-conversion
+infback.o_CFLAGS_ADD += -Wno-sign-conversion
+inflate.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_array.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_copyright.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_dict.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_object.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_reloc.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_sym.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_symtab.o_CFLAGS_ADD += -Wno-sign-conversion
+kxld_util.o_CFLAGS_ADD += -Wno-sign-conversion
+log.o_CFLAGS_ADD += -Wno-sign-conversion
+refcnt.o_CFLAGS_ADD += -Wno-sign-conversion
+scanf.o_CFLAGS_ADD += -Wno-sign-conversion
+trees.o_CFLAGS_ADD += -Wno-sign-conversion
+uuid.o_CFLAGS_ADD += -Wno-sign-conversion
+# -Wno-unreachable-code
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-unreachable-code
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-unreachable-code
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-unreachable-code-break
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-unreachable-code-break
+# -Wno-zero-as-null-pointer-constant
+OSUnserialize.cpo_CXXWARNFLAGS_ADD += -Wno-zero-as-null-pointer-constant
+OSUnserializeXML.cpo_CXXWARNFLAGS_ADD += -Wno-zero-as-null-pointer-constant
+
+# Rebuild if per-file overrides change
+${OBJS}: $(firstword $(MAKEFILE_LIST))
+
+# Rebuild if global compile flags change
+$(COBJS): .CFLAGS
+.CFLAGS: ALWAYS
+       $(_v)$(REPLACECONTENTS) $@ $(KCC) $(CFLAGS) $(INCFLAGS)
+$(CXXOBJS): .CXXFLAGS
+.CXXFLAGS: ALWAYS
+       $(_v)$(REPLACECONTENTS) $@ $(KC++) $(CXXFLAGS) $(INCFLAGS)
+$(SOBJS): .SFLAGS
+.SFLAGS: ALWAYS
+       $(_v)$(REPLACECONTENTS) $@ $(S_KCC) $(SFLAGS) $(INCFLAGS)
+
+$(COMPONENT).filelist: $(OBJS)
+       $(_v)for hib_file in ${HIB_FILES}; \
+       do      \
+               $(SEG_HACK) -n __HIB -o $${hib_file}__ $${hib_file} || exit 1; \
+               mv $${hib_file}__ $${hib_file} || exit 1; \
+       done
+       @$(LOG_LDFILELIST) "$(COMPONENT)"
+       $(_v)for obj in ${OBJS}; do     \
+                $(ECHO) $(TARGET)/$(CURRENT_KERNEL_CONFIG)/$${obj}; \
+       done > $(COMPONENT).filelist
+
+$(COMPONENT).libfilelist: $(LIBOBJS)
+       @$(LOG_LDFILELIST) "lib$(COMPONENT)"
+       $(_v)for obj in ${LIBOBJS}; do  \
+                $(ECHO) $(TARGET)/$(CURRENT_KERNEL_CONFIG)/$${obj}; \
+       done > $(COMPONENT).libfilelist
+
+ifeq ($(RC_ProjectName),xnu_libraries)
+do_all: $(COMPONENT).libfilelist
+else
+do_all: $(COMPONENT).filelist
+endif
+
+do_build_all:: do_all
 
 %RULES