Annotation of sys/arch/alpha/conf/Makefile.alpha, Revision 1.1.1.1
1.1 nbrk 1: # $OpenBSD: Makefile.alpha,v 1.39 2007/07/30 16:23:33 thib Exp $
2: # $NetBSD: Makefile.alpha,v 1.27 1996/12/01 06:12:25 jonathan 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/alpha/conf/``machineid''
10: # after which you should do
11: # config machineid
12: # Machine generic makefile changes should be made in
13: # /sys/arch/alpha/conf/Makefile.alpha
14: # after which config should be rerun for all machines of that type.
15: #
16: # DEBUG is set to -g if debugging.
17: # PROF is set to -pg if profiling.
18:
19: .include <bsd.own.mk>
20:
21: MKDEP?= mkdep
22: SIZE?= size
23: STRIP?= strip
24:
25: # source tree is located via $S relative to the compilation directory
26: .ifndef S
27: S!= cd ../../../..; pwd
28: .endif
29: ALPHA= $S/arch/alpha
30:
31: INCLUDES= -I. -I$S -I$S/arch -nostdinc
32: CPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -Dalpha
33:
34: CDIAGFLAGS?= -Werror -Wall -Wstrict-prototypes -Wmissing-prototypes \
35: -Wno-uninitialized -Wno-format -Wno-main \
36: -Wstack-larger-than-2047
37:
38: CMACHFLAGS= -mno-fp-regs -fno-builtin-printf -fno-builtin-log \
39: -finhibit-size-directive -Wa,-mev56
40: .if ${IDENT:M-DNO_PROPOLICE}
41: CMACHFLAGS+= -fno-stack-protector
42: .endif
43: COPTS?= -O2
44: CFLAGS= ${DEBUG} ${CDIAGFLAGS} ${CMACHFLAGS} ${COPTS} ${PIPE}
45: AFLAGS= -traditional -D_LOCORE
46: LINKFLAGS= -N -Ttext fffffc0000230000 -e __start -G 4
47: STRIPFLAGS= -g -X -x
48:
49: HOSTED_CC= ${CC}
50: HOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//}
51: HOSTED_CFLAGS= ${CFLAGS}
52:
53: ### find out what to use for libkern
54: .include "$S/lib/libkern/Makefile.inc"
55: .ifndef PROF
56: LIBKERN= ${KERNLIB}
57: .else
58: LIBKERN= ${KERNLIB_PROF}
59: .endif
60:
61: ### find out what to use for libcompat
62: .include "$S/compat/common/Makefile.inc"
63: .ifndef PROF
64: LIBCOMPAT= ${COMPATLIB}
65: .else
66: LIBCOMPAT= ${COMPATLIB_PROF}
67: .endif
68:
69: # compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or
70: # HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file).
71:
72: NORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
73: NORMAL_S= ${CC} -xassembler-with-cpp ${AFLAGS} ${CPPFLAGS} -c $<
74:
75: HOSTED_C= ${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $<
76:
77: %OBJS
78:
79: %CFILES
80:
81: %SFILES
82:
83: # load lines for config "xxx" will be emitted as:
84: # xxx: ${SYSTEM_DEP} swapxxx.o
85: # ${SYSTEM_LD_HEAD}
86: # ${SYSTEM_LD} swapxxx.o
87: # ${SYSTEM_LD_TAIL}
88: SYSTEM_OBJ= locore.o param.o ioconf.o ${OBJS} ${LIBKERN} ${LIBCOMPAT}
89: SYSTEM_DEP= Makefile ${SYSTEM_OBJ}
90: SYSTEM_LD_HEAD= @rm -f $@
91: SYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \
92: ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o
93: SYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@
94:
95: DEBUG?=
96: .if ${DEBUG} == "-g"
97: LINKFLAGS+= -X
98: SYSTEM_LD_TAIL+=; \
99: echo mv $@ $@.gdb; rm -f $@.gdb; mv $@ $@.gdb; \
100: echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \
101: ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb
102: .else
103: LINKFLAGS+= -S -x
104: .endif
105:
106: %LOAD
107:
108: assym.h: $S/kern/genassym.sh ${ALPHA}/alpha/genassym.cf Makefile
109: sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} \
110: ${PARAM} < ${ALPHA}/alpha/genassym.cf > assym.h.tmp && \
111: mv -f assym.h.tmp assym.h
112:
113: param.c: $S/conf/param.c
114: rm -f param.c
115: cp $S/conf/param.c .
116:
117: param.o: param.c Makefile
118: ${NORMAL_C}
119:
120: ioconf.o: ioconf.c
121: ${NORMAL_C}
122:
123: newvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP}
124: sh $S/conf/newvers.sh
125: ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c
126:
127:
128: clean::
129: rm -f eddep *bsd bsd.gdb tags *.[io] [a-z]*.s \
130: [Ee]rrs linterrs makelinks assym.h
131:
132: lint:
133: @lint -hbxncez -DGENERIC -Dvolatile= ${CPPFLAGS} -UKGDB \
134: ${CFILES} ioconf.c param.c | \
135: grep -v 'static function .* unused'
136:
137: tags:
138: @echo "see $S/kern/Makefile for tags"
139:
140: links:
141: egrep '#if' ${CFILES} | sed -f $S/conf/defines | \
142: sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink
143: echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \
144: sort -u | comm -23 - dontlink | \
145: sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks
146: sh makelinks && rm -f dontlink
147:
148: SRCS= ${ALPHA}/alpha/locore.s param.c ioconf.c ${CFILES} ${SFILES}
149: depend:: .depend
150: .depend: ${SRCS} assym.h param.c ${ALPHA}/alpha/cpuconf.c
151: ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${ALPHA}/alpha/locore.s
152: ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} ${ALPHA}/alpha/cpuconf.c \
153: param.c ioconf.c ${CFILES}
154: ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES}
155: sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \
156: ${CPPFLAGS} < ${ALPHA}/alpha/genassym.cf
157: @sed -e 's/.*\.o:.* /assym.h: /' < assym.dep >> .depend
158: @rm -f assym.dep
159:
160:
161: # depend on root or device configuration
162: autoconf.o conf.o: Makefile
163:
164: # depend on network or filesystem configuration
165: uipc_proto.o vfs_conf.o: Makefile
166:
167: # depend on maxusers
168: machdep.o: Makefile
169:
170: # depend on CPU configuration
171: clock.o machdep.o apecs.o cia.o lca.o ioasic.o scc.o icasic.o: Makefile
172:
173:
174: locore.o: ${ALPHA}/alpha/locore.s assym.h
175: ${NORMAL_S}
176:
177: # The install target can be redefined by putting a
178: # install-kernel-${MACHINE_NAME} target into /etc/mk.conf
179: MACHINE_NAME!= uname -n
180: install: install-kernel-${MACHINE_NAME}
181: .if !target(install-kernel-${MACHINE_NAME}})
182: install-kernel-${MACHINE_NAME}:
183: rm -f /obsd
184: ln /bsd /obsd
185: cp bsd /nbsd
186: mv /nbsd /bsd
187: .endif
188:
189: %RULES
CVSweb