Annotation of sys/arch/sparc/conf/Makefile.sparc, Revision 1.1
1.1 ! nbrk 1: # $OpenBSD: Makefile.sparc,v 1.39 2007/07/30 16:23:33 thib Exp $
! 2: # $NetBSD: Makefile.sparc,v 1.32.4.1 1996/06/12 20:26:32 pk Exp $
! 3:
! 4: # Makefile for OpenBSD
! 5: #
! 6: # This makefile is constructed from a machine description:
! 7: # config machineid
! 8: # Most changes should be made in the machine description
! 9: # /sys/arch/sparc/conf/``machineid''
! 10: # after which you should do
! 11: # config machineid
! 12: # Machine generic makefile changes should be made in
! 13: # /sys/arch/sparc/conf/Makefile.sparc
! 14: # after which config should be rerun for all machines of that type.
! 15: #
! 16: # N.B.: NO DEPENDENCIES ON FOLLOWING FLAGS ARE VISIBLE TO MAKEFILE
! 17: # IF YOU CHANGE THE DEFINITION OF ANY OF THESE RECOMPILE EVERYTHING
! 18: #
! 19: # -DTRACE compile in kernel tracing hooks
! 20: # -DQUOTA compile in file system quotas
! 21:
! 22: # DEBUG is set to -g if debugging.
! 23: # PROF is set to -pg if profiling.
! 24:
! 25: .include <bsd.own.mk>
! 26:
! 27: MKDEP?= mkdep
! 28: SIZE?= size
! 29: STRIP?= strip
! 30:
! 31: # source tree is located via $S relative to the compilation directory
! 32: .ifndef S
! 33: S!= cd ../../../..; pwd
! 34: .endif
! 35: SPARC= $S/arch/sparc
! 36:
! 37: INCLUDES= -nostdinc -I. -I$S -I$S/arch
! 38: CPPFLAGS= ${INCLUDES} ${IDENT} -D_KERNEL -Dsparc
! 39:
! 40: CDIAGFLAGS= -Werror -Wall -Wstrict-prototypes -Wmissing-prototypes \
! 41: -Wno-uninitialized -Wno-format -Wno-main \
! 42: -Wstack-larger-than-2047
! 43:
! 44: .if ${IDENT:M-DSUN*} == ${IDENT:M-DSUN4M}
! 45: CMACHFLAGS= -mcpu=supersparc
! 46: .else
! 47: CMACHFLAGS=
! 48: .endif
! 49: .if ${IDENT:M-DNO_PROPOLICE}
! 50: CMACHFLAGS+= -fno-stack-protector
! 51: .endif
! 52: CMACHFLAGS+= -fno-builtin-printf -fno-builtin-log
! 53:
! 54: CFLAGS= ${DEBUG} -O2 ${CDIAGFLAGS} ${CMACHFLAGS} ${COPTS} ${PIPE}
! 55: # add `-mno-fpu' to work around gcc (last noticed in v2.7.2) bug
! 56: CFLAGS+= -mno-fpu
! 57: AFLAGS= -x assembler-with-cpp -traditional-cpp -D_LOCORE
! 58: LINKFLAGS= -N -e start -Ttext F8004000
! 59: STRIPFLAGS= -g -X -x
! 60:
! 61: HOSTCC= ${CC}
! 62: HOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//}
! 63: HOSTED_CFLAGS= ${CFLAGS}
! 64:
! 65: ### find out what to use for libkern
! 66: .include "$S/lib/libkern/Makefile.inc"
! 67: .ifndef PROF
! 68: LIBKERN= ${KERNLIB}
! 69: .else
! 70: LIBKERN= ${KERNLIB_PROF}
! 71: .endif
! 72:
! 73: ### find out what to use for libcompat
! 74: .include "$S/compat/common/Makefile.inc"
! 75: .ifndef PROF
! 76: LIBCOMPAT= ${COMPATLIB}
! 77: .else
! 78: LIBCOMPAT= ${COMPATLIB_PROF}
! 79: .endif
! 80:
! 81: # compile rules: rules are named ${TYPE}_${SUFFIX}${CONFIG_DEP}
! 82: # where TYPE is NORMAL, DRIVER, or PROFILE}; SUFFIX is the file suffix,
! 83: # capitalized (e.g. C for a .c file), and CONFIG_DEP is _C if the file
! 84: # is marked as config-dependent.
! 85:
! 86: NORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
! 87: NORMAL_C_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} ${PARAM} -c $<
! 88:
! 89: DRIVER_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
! 90: DRIVER_C_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} ${PARAM} -c $<
! 91:
! 92: NORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $<
! 93: NORMAL_S_C= ${CC} ${AFLAGS} ${CPPFLAGS} ${PARAM} -c $<
! 94:
! 95: HOSTED_C= ${HOSTCC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $<
! 96:
! 97: %OBJS
! 98:
! 99: %CFILES
! 100:
! 101: %SFILES
! 102:
! 103: # load lines for config "xxx" will be emitted as:
! 104: # xxx: ${SYSTEM_DEP} swapxxx.o
! 105: # ${SYSTEM_LD_HEAD}
! 106: # ${SYSTEM_LD} swapxxx.o
! 107: # ${SYSTEM_LD_TAIL}
! 108: SYSTEM_OBJ= locore.o \
! 109: param.o ioconf.o ${OBJS} ${LIBKERN} ${LIBCOMPAT}
! 110: SYSTEM_DEP= Makefile ${SYSTEM_OBJ}
! 111: SYSTEM_LD_HEAD= @rm -f $@
! 112: SYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \
! 113: ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o
! 114: SYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@
! 115:
! 116: DEBUG?=
! 117: .if ${DEBUG} == "-g"
! 118: LINKFLAGS+= -X
! 119: SYSTEM_LD_TAIL+=; \
! 120: echo mv $@ $@.gdb; rm -f $@.gdb; mv $@ $@.gdb; \
! 121: echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \
! 122: ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb
! 123: .else
! 124: LINKFLAGS+= -S -x
! 125: .endif
! 126:
! 127: %LOAD
! 128:
! 129: assym.h: $S/kern/genassym.sh ${SPARC}/sparc/genassym.cf Makefile
! 130: sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} \
! 131: ${PARAM} < ${SPARC}/sparc/genassym.cf > assym.h.tmp && \
! 132: mv -f assym.h.tmp assym.h
! 133:
! 134: param.c: $S/conf/param.c
! 135: rm -f param.c
! 136: cp $S/conf/param.c .
! 137:
! 138: param.o: param.c Makefile
! 139: ${NORMAL_C_C}
! 140:
! 141: ioconf.o: ioconf.c
! 142: ${NORMAL_C}
! 143:
! 144: newvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP}
! 145: sh $S/conf/newvers.sh
! 146: ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c
! 147:
! 148:
! 149: clean::
! 150: rm -f eddep *bsd *bsd.gdb tags *.[io] [a-z]*.s \
! 151: [Ee]rrs linterrs makelinks genassym genassym.o assym.h
! 152:
! 153: lint:
! 154: @lint -hbxncez -DGENERIC -Dvolatile= ${CPPFLAGS} ${PARAM} -UKGDB \
! 155: ${CFILES} ioconf.c param.c | \
! 156: grep -v 'static function .* unused'
! 157:
! 158: tags:
! 159: @echo "see $S/kern/Makefile for tags"
! 160:
! 161: links:
! 162: egrep '#if' ${CFILES} | sed -f $S/conf/defines | \
! 163: sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink
! 164: echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \
! 165: sort -u | comm -23 - dontlink | \
! 166: sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks
! 167: sh makelinks && rm -f dontlink
! 168:
! 169: SRCS= ${SPARC}/sparc/locore.s \
! 170: param.c ioconf.c ${CFILES} ${SFILES}
! 171: depend:: .depend
! 172: .depend: ${SRCS} assym.h param.c
! 173: ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${SPARC}/sparc/locore.s
! 174: ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES}
! 175: .if !empty(SFILES)
! 176: ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES}
! 177: .endif
! 178: sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \
! 179: ${CPPFLAGS} < ${SPARC}/sparc/genassym.cf
! 180: @sed -e 's/.*\.o:.* /assym.h: /' < assym.dep >> .depend
! 181: @rm -f assym.dep
! 182:
! 183:
! 184: # depend on root or device configuration
! 185: autoconf.o conf.o: Makefile
! 186:
! 187: # depend on network or filesystem configuration
! 188: uipc_proto.o vfs_conf.o: Makefile
! 189:
! 190: # depend on maxusers
! 191: machdep.o: Makefile
! 192:
! 193: # depend on CPU configuration
! 194: bwtwo.o cgsix.o cgthree.o cgtwo.o cons.o dma.o esp.o fb.o if_ie.o: Makefile
! 195: ms.c obio.o zs.c autoconf.o clock.o cpu.o disksubr.o locore.o: Makefile
! 196: machdep.o mem.o openprom.o pmap.o vm_machdep.o: Makefile
! 197:
! 198:
! 199: locore.o: ${SPARC}/sparc/locore.s assym.h
! 200: ${NORMAL_S}
! 201:
! 202: # The install target can be redefined by putting a
! 203: # install-kernel-${MACHINE_NAME} target into /etc/mk.conf
! 204: MACHINE_NAME!= uname -n
! 205: install: install-kernel-${MACHINE_NAME}
! 206: .if !target(install-kernel-${MACHINE_NAME}})
! 207: install-kernel-${MACHINE_NAME}:
! 208: rm -f /obsd
! 209: ln /bsd /obsd
! 210: cp bsd /nbsd
! 211: mv /nbsd /bsd
! 212: .endif
! 213:
! 214: %RULES
CVSweb