2 # Mach Operating System
3 # Copyright (c) 1986 Carnegie-Mellon University
4 # All rights reserved. The CMU software License Agreement specifies
5 # the terms and conditions for use and redistribution.
8 export MakeInc_cmd=${SRCROOT}/makedefs/MakeInc.cmd
9 export MakeInc_def=${SRCROOT}/makedefs/MakeInc.def
10 export MakeInc_rule=${SRCROOT}/makedefs/MakeInc.rule
11 export MakeInc_dir=${SRCROOT}/makedefs/MakeInc.dir
13 include $(MakeInc_cmd)
14 include $(MakeInc_def)
19 CFLAGS+= -include meta_features.h -DMACH_KERNEL_PRIVATE -DMACH_KERNEL
20 SFLAGS+= -include meta_features.h
22 # Objects that don't want -Wcast-align warning (8474835)
23 OBJS_NO_CAST_ALIGN = \
24 atm_notification_user.o \
69 ccdigest_final_64be.o \
77 ccmode_factory_ctr_crypt.o \
88 # Objects that don't want -Wsign-compare warning (15294427)
89 OBJS_NO_SIGN_COMPARE = \
90 atm_notification_user.o
92 $(foreach file,$(OBJS_NO_CAST_ALIGN),$(eval $(call add_perfile_cflags,$(file),-Wno-cast-align)))
93 $(foreach file,$(OBJS_NO_SIGN_COMPARE),$(eval $(call add_perfile_cflags,$(file),-Wno-sign-compare)))
96 # Do not provide CTF symbolic these files
98 chud_glue.o_SKIP_CTFCONVERT = 1
101 # XXX: INCFLAGS to include libsa prototypes
103 INCFLAGS_MAKEFILE= -I$(SOURCE)libsa
106 # Directories for mig generated files
119 # Make sure we don't remove this by accident if interrupted at the wrong
125 # Theses macros are filled in by the config program depending on the
126 # current configuration. The MACHDEP macro is replaced by the
127 # contents of the machine dependent makefile template and the others
128 # are replaced by the corresponding symbol definitions for the
142 # Rebuild if per-file overrides change
143 ${OBJS}: $(firstword $(MAKEFILE_LIST))
145 # Rebuild if global compile flags change
148 $(_v)$(REPLACECONTENTS) $@ $(KCC) $(CFLAGS) $(INCFLAGS)
149 $(CXXOBJS): .CXXFLAGS
151 $(_v)$(REPLACECONTENTS) $@ $(KC++) $(CXXFLAGS) $(INCFLAGS)
154 $(_v)$(REPLACECONTENTS) $@ $(S_KCC) $(SFLAGS) $(INCFLAGS)
156 $(COMPONENT).filelist: $(OBJS)
157 $(_v)for hib_file in ${HIB_FILES}; \
159 $(SEG_HACK) -n __HIB -o $${hib_file}__ $${hib_file} || exit 1; \
160 mv $${hib_file}__ $${hib_file} || exit 1; \
162 @echo "$(ColorL)LDFILELIST$(Color0) $(ColorLF)$(COMPONENT)$(Color0)"
163 $(_v)for obj in ${OBJS}; do \
164 echo $(TARGET)/$(CURRENT_KERNEL_CONFIG)/$${obj}; \
165 done > $(COMPONENT).filelist
167 do_all: $(COMPONENT).filelist
169 do_build_all:: do_all
171 # genassym.o actually is an assembly file,
172 # we name it genassym.o to help with the automatic
173 # dependency generation
175 GENASSYM_LOCATION = $(CURRENT_ARCH_CONFIG_LC)
177 ifeq ($(CURRENT_ARCH_CONFIG_LC),x86_64)
178 GENASSYM_LOCATION = i386
179 else ifeq ($(CURRENT_ARCH_CONFIG_LC),x86_64h)
180 GENASSYM_LOCATION = i386
184 genassym.o: .CFLAGS $(firstword $(MAKEFILE_LIST))
185 genassym.o: $(SOURCE_DIR)/$(COMPONENT)/$(GENASSYM_LOCATION)/genassym.c
186 @echo "[$(CMD_MC)] $(ColorH)GENASSYM$(Color0) $(ColorLF)$<$(Color0)"
187 $(_v)${GENASSYM_KCC} ${CFLAGS} ${CFLAGS_NOLTO_FLAG} -MD -S -o ${@} ${INCFLAGS} $<
190 $(_v)sed -e '/^[[:space:]]*DEFINITION__define__/!d;{N;s/\n//;}' -e 's/^[[:space:]]*DEFINITION__define__\([^:]*\):.*ascii.*\"[\$$]*\([-0-9\#]*\)\".*$$/#define \1 \2/' -e 'p' -e 's/#//2' -e 's/^[[:space:]]*#define \([A-Za-z0-9_]*\)[[:space:]]*[\$$#]*\([-0-9]*\).*$$/#define \1_NUM \2/' genassym.o > $@
196 include $(MakeInc_rule)
197 include $(MakeInc_dir)