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.
9 # Export IDENT for sub-makefiles
14 # XXX: INCFLAGS to include libsa prototypes
16 INCFLAGS_MAKEFILE= -I$(SOURCE)libsa
18 export MakeInc_cmd=${SRCROOT}/makedefs/MakeInc.cmd
19 export MakeInc_def=${SRCROOT}/makedefs/MakeInc.def
20 export MakeInc_rule=${SRCROOT}/makedefs/MakeInc.rule
21 export MakeInc_dir=${SRCROOT}/makedefs/MakeInc.dir
23 include $(MakeInc_cmd)
24 include $(MakeInc_def)
29 CFLAGS+= -include meta_features.h -DMACH_KERNEL_PRIVATE $(CFLAGS_INLINE_CONFIG)
32 # Directories for mig generated files
47 COMP_SUBDIRS_X86_64 = \
51 # Make sure we don't remove this by accident if interrupted at the wrong
57 # Theses macros are filled in by the config program depending on the
58 # current configuration. The MACHDEP macro is replaced by the
59 # contents of the machine dependent makefile template and the others
60 # are replaced by the corresponding symbol definitions for the
78 # OBJSDEPS is the set of files (defined in the machine dependent
79 # template if necessary) which all objects depend on (such as an
80 # in-line assembler expansion filter)
89 $(COMPONENT).filelist: $(LDOBJS) assym.s
90 $(_v)if [ $(BUILD_MACHO_OBJ) -eq 1 ]; then \
91 for hib_file in ${HIB_FILES}; \
93 $(SEG_HACK) __HIB $${hib_file} -o $${hib_file}__; \
94 mv $${hib_file}__ $${hib_file} ; \
97 @echo LDFILELIST $(COMPONENT)
98 $(_v)( for obj in ${LDOBJS}; do \
99 echo $(TARGET)$(COMP_OBJ_DIR)/$(KERNEL_CONFIG)/$${obj}; \
100 done; ) > $(COMPONENT).filelist
102 do_all: $(COMPONENT).filelist
105 $(_v)${MD} -u Makedep -f -d `ls *.d`;
107 do_build_all: do_depend
109 # genassym.o actually is an assembly file,
110 # we name it genassym.o to help with the automatic
111 # dependency generation
113 GENASSYM_LOCATION = $(ARCH_CONFIG_LC)
115 ifeq ($(ARCH_CONFIG_LC),x86_64)
116 GENASSYM_LOCATION = i386
119 genassym.o: $(SOURCE_DIR)/$(COMPONENT)/$(GENASSYM_LOCATION)/genassym.c
120 $(_v)${KCC} $(subst -flto,,${CFLAGS}) -MD ${_HOST_EXTRA_CFLAGS} -S -o ${@} -c ${INCFLAGS} $<
123 $(_v)sed -e '/#DEFINITION#/!d' -e 's/^.*#DEFINITION#//' -e 's/\$$//' -e 'p' -e 's/#//2' -e 's/[^A-Za-z0-9_]*\([A-Za-z0-9_]*\)/ \1_NUM/2' genassym.o > ${@}
130 include $(MakeInc_rule)
131 include $(MakeInc_dir)