1 1.103 joerg # $NetBSD: sys.mk,v 1.103 2011/01/17 18:11:10 joerg Exp $ 2 1.30 mikel # @(#)sys.mk 8.2 (Berkeley) 3/21/94 3 1.1 cgd 4 1.30 mikel unix?= We run NetBSD. 5 1.1 cgd 6 1.80 lukem .SUFFIXES: .a .o .ln .s .S .c .cc .cpp .cxx .C .f .F .r .p .l .y .sh 7 1.1 cgd 8 1.1 cgd .LIBS: .a 9 1.1 cgd 10 1.22 christos AR?= ar 11 1.22 christos ARFLAGS?= rl 12 1.22 christos RANLIB?= ranlib 13 1.22 christos 14 1.22 christos AS?= as 15 1.22 christos AFLAGS?= 16 1.26 mycroft COMPILE.s?= ${CC} ${AFLAGS} -c 17 1.22 christos LINK.s?= ${CC} ${AFLAGS} ${LDFLAGS} 18 1.102 joerg .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64" || \ 19 1.103 joerg ${MACHINE_ARCH} == "alpha" || ${MACHINE_ARCH} == "sparc" || \ 20 1.103 joerg ${MACHINE_ARCH} == "sparc64" 21 1.101 joerg _ASM_TRADITIONAL_CPP= -x assembler-with-cpp 22 1.101 joerg .else 23 1.101 joerg _ASM_TRADITIONAL_CPP= -traditional-cpp 24 1.101 joerg .endif 25 1.101 joerg COMPILE.S?= ${CC} ${AFLAGS} ${CPPFLAGS} ${_ASM_TRADITIONAL_CPP} -c 26 1.22 christos LINK.S?= ${CC} ${AFLAGS} ${CPPFLAGS} ${LDFLAGS} 27 1.22 christos 28 1.22 christos CC?= cc 29 1.54 mycroft .if ${MACHINE_ARCH} == "alpha" || \ 30 1.66 wiz ${MACHINE_ARCH} == "arm" || \ 31 1.74 fvdl ${MACHINE_ARCH} == "x86_64" || \ 32 1.67 thorpej ${MACHINE_ARCH} == "armeb" || \ 33 1.84 chs ${MACHINE_ARCH} == "hppa" || \ 34 1.52 lukem ${MACHINE_ARCH} == "i386" || \ 35 1.52 lukem ${MACHINE_ARCH} == "m68k" || \ 36 1.53 drochner ${MACHINE_ARCH} == "mipsel" || ${MACHINE_ARCH} == "mipseb" || \ 37 1.88 matt ${MACHINE_ARCH} == "mips64el" || ${MACHINE_ARCH} == "mips64eb" || \ 38 1.62 mycroft ${MACHINE_ARCH} == "powerpc" || \ 39 1.56 matt ${MACHINE_ARCH} == "sparc" || \ 40 1.92 matt ${MACHINE_ARCH} == "sparc64" 41 1.57 sjg DBG?= -O2 42 1.97 uwe .elif ${MACHINE_ARCH} == "sh3el" || ${MACHINE_ARCH} == "sh3eb" 43 1.97 uwe # -O2 is too -falign-* zealous for low-memory sh3 machines 44 1.97 uwe DBG?= -Os -freorder-blocks 45 1.92 matt .elif ${MACHINE_ARCH} == "vax" 46 1.92 matt DBG?= -O1 -fgcse -fstrength-reduce -fgcse-after-reload 47 1.94 mrg .elif ${MACHINE_ARCH} == "m68000" 48 1.96 tsutsui # see src/doc/HACKS for details 49 1.96 tsutsui DBG?= -O1 50 1.44 mycroft .else 51 1.57 sjg DBG?= -O 52 1.44 mycroft .endif 53 1.57 sjg CFLAGS?= ${DBG} 54 1.87 lukem LDFLAGS?= 55 1.22 christos COMPILE.c?= ${CC} ${CFLAGS} ${CPPFLAGS} -c 56 1.22 christos LINK.c?= ${CC} ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} 57 1.22 christos 58 1.100 darran # C Type Format data is required for DTrace 59 1.100 darran # XXX TBD VERSION is not defined 60 1.100 darran CTFFLAGS ?= -L VERSION 61 1.100 darran CTFMFLAGS ?= -t -L VERSION 62 1.100 darran 63 1.100 darran .if defined(MKDTRACE) && ${MKDTRACE} != "no" 64 1.100 darran CTFCONVERT ?= ${TOOL_CTFCONVERT} 65 1.100 darran CTFMERGE ?= ${TOOL_CTFMERGE} 66 1.100 darran .if defined(CFLAGS) && (${CFLAGS:M-g} != "") 67 1.100 darran CTFFLAGS += -g 68 1.100 darran CTFMFLAGS += -g 69 1.100 darran .else 70 1.100 darran CFLAGS += -g 71 1.100 darran .endif 72 1.100 darran .endif 73 1.100 darran 74 1.41 tv CXX?= c++ 75 1.99 kent CXXFLAGS?= ${CFLAGS:N-Wno-traditional:N-Wstrict-prototypes:N-Wmissing-prototypes:N-Wno-pointer-sign:N-ffreestanding:N-std=gnu99} 76 1.89 christos 77 1.98 joerg __ALLSRC1= ${empty(DESTDIR):?${.ALLSRC}:${.ALLSRC:S|^${DESTDIR}|^destdir|}} 78 1.98 joerg __ALLSRC2= ${empty(MAKEOBJDIR):?${__ALLSRC1}:${__ALLSRC1:S|^${MAKEOBJDIR}|^obj|}} 79 1.98 joerg __ALLSRC3= ${empty(NETBSDSRCDIR):?${__ALLSRC2}:${__ALLSRC2:S|^${NETBSDSRCDIR}|^src|}} 80 1.98 joerg 81 1.98 joerg _CXXSEED?= ${BUILDSEED:D-frandom-seed=${BUILDSEED:Q}/${__ALLSRC3:O:Q}/${.TARGET:Q}} 82 1.98 joerg 83 1.98 joerg COMPILE.cc?= ${CXX} ${_CXXSEED} ${CXXFLAGS} ${CPPFLAGS} -c 84 1.22 christos LINK.cc?= ${CXX} ${CXXFLAGS} ${CPPFLAGS} ${LDFLAGS} 85 1.34 lukem 86 1.34 lukem OBJC?= ${CC} 87 1.34 lukem OBJCFLAGS?= ${CFLAGS} 88 1.34 lukem COMPILE.m?= ${OBJC} ${OBJCFLAGS} ${CPPFLAGS} -c 89 1.34 lukem LINK.m?= ${OBJC} ${OBJCFLAGS} ${CPPFLAGS} ${LDFLAGS} 90 1.3 mycroft 91 1.22 christos CPP?= cpp 92 1.75 lukem CPPFLAGS?= 93 1.1 cgd 94 1.22 christos FC?= f77 95 1.30 mikel FFLAGS?= -O 96 1.22 christos RFLAGS?= 97 1.22 christos COMPILE.f?= ${FC} ${FFLAGS} -c 98 1.22 christos LINK.f?= ${FC} ${FFLAGS} ${LDFLAGS} 99 1.22 christos COMPILE.F?= ${FC} ${FFLAGS} ${CPPFLAGS} -c 100 1.22 christos LINK.F?= ${FC} ${FFLAGS} ${CPPFLAGS} ${LDFLAGS} 101 1.22 christos COMPILE.r?= ${FC} ${FFLAGS} ${RFLAGS} -c 102 1.22 christos LINK.r?= ${FC} ${FFLAGS} ${RFLAGS} ${LDFLAGS} 103 1.29 thorpej 104 1.29 thorpej INSTALL?= install 105 1.22 christos 106 1.79 lukem LD?= ld 107 1.79 lukem 108 1.22 christos LEX?= lex 109 1.22 christos LFLAGS?= 110 1.22 christos LEX.l?= ${LEX} ${LFLAGS} 111 1.22 christos 112 1.22 christos LINT?= lint 113 1.85 perry LINTFLAGS?= -chapbxzFS 114 1.22 christos 115 1.36 gwr LORDER?= lorder 116 1.36 gwr 117 1.22 christos MAKE?= make 118 1.22 christos 119 1.36 gwr NM?= nm 120 1.36 gwr 121 1.22 christos PC?= pc 122 1.22 christos PFLAGS?= 123 1.22 christos COMPILE.p?= ${PC} ${PFLAGS} ${CPPFLAGS} -c 124 1.22 christos LINK.p?= ${PC} ${PFLAGS} ${CPPFLAGS} ${LDFLAGS} 125 1.22 christos 126 1.22 christos SHELL?= sh 127 1.36 gwr 128 1.36 gwr SIZE?= size 129 1.36 gwr 130 1.36 gwr TSORT?= tsort -q 131 1.22 christos 132 1.22 christos YACC?= yacc 133 1.40 tv YFLAGS?= 134 1.22 christos YACC.y?= ${YACC} ${YFLAGS} 135 1.1 cgd 136 1.15 jtc # C 137 1.14 jtc .c: 138 1.15 jtc ${LINK.c} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 139 1.100 darran .if defined(CTFCONVERT) 140 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 141 1.100 darran .endif 142 1.15 jtc .c.o: 143 1.15 jtc ${COMPILE.c} ${.IMPSRC} 144 1.100 darran .if defined(CTFCONVERT) 145 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 146 1.100 darran .endif 147 1.15 jtc .c.a: 148 1.15 jtc ${COMPILE.c} ${.IMPSRC} 149 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 150 1.76 lukem rm -f ${.PREFIX}.o 151 1.21 cgd .c.ln: 152 1.83 lukem ${LINT} ${LINTFLAGS} \ 153 1.83 lukem ${CPPFLAGS:C/-([IDU])[ ]*/-\1/Wg:M-[IDU]*} \ 154 1.83 lukem -i ${.IMPSRC} 155 1.14 jtc 156 1.15 jtc # C++ 157 1.55 jdolecek .cc .cpp .cxx .C: 158 1.15 jtc ${LINK.cc} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 159 1.55 jdolecek .cc.o .cpp.o .cxx.o .C.o: 160 1.15 jtc ${COMPILE.cc} ${.IMPSRC} 161 1.55 jdolecek .cc.a .cpp.a .cxx.a .C.a: 162 1.15 jtc ${COMPILE.cc} ${.IMPSRC} 163 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 164 1.76 lukem rm -f ${.PREFIX}.o 165 1.14 jtc 166 1.15 jtc # Fortran/Ratfor 167 1.15 jtc .f: 168 1.15 jtc ${LINK.f} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 169 1.15 jtc .f.o: 170 1.15 jtc ${COMPILE.f} ${.IMPSRC} 171 1.15 jtc .f.a: 172 1.15 jtc ${COMPILE.f} ${.IMPSRC} 173 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 174 1.76 lukem rm -f ${.PREFIX}.o 175 1.14 jtc 176 1.15 jtc .F: 177 1.15 jtc ${LINK.F} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 178 1.100 darran .if defined(CTFCONVERT) 179 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 180 1.100 darran .endif 181 1.15 jtc .F.o: 182 1.15 jtc ${COMPILE.F} ${.IMPSRC} 183 1.100 darran .if defined(CTFCONVERT) 184 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 185 1.100 darran .endif 186 1.15 jtc .F.a: 187 1.15 jtc ${COMPILE.F} ${.IMPSRC} 188 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 189 1.76 lukem rm -f ${.PREFIX}.o 190 1.14 jtc 191 1.15 jtc .r: 192 1.15 jtc ${LINK.r} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 193 1.15 jtc .r.o: 194 1.15 jtc ${COMPILE.r} ${.IMPSRC} 195 1.15 jtc .r.a: 196 1.15 jtc ${COMPILE.r} ${.IMPSRC} 197 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 198 1.76 lukem rm -f ${.PREFIX}.o 199 1.9 jtc 200 1.15 jtc # Pascal 201 1.15 jtc .p: 202 1.15 jtc ${LINK.p} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 203 1.100 darran .if defined(CTFCONVERT) 204 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 205 1.100 darran .endif 206 1.1 cgd .p.o: 207 1.15 jtc ${COMPILE.p} ${.IMPSRC} 208 1.100 darran .if defined(CTFCONVERT) 209 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 210 1.100 darran .endif 211 1.15 jtc .p.a: 212 1.15 jtc ${COMPILE.p} ${.IMPSRC} 213 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 214 1.76 lukem rm -f ${.PREFIX}.o 215 1.1 cgd 216 1.15 jtc # Assembly 217 1.15 jtc .s: 218 1.15 jtc ${LINK.s} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 219 1.100 darran .if defined(CTFCONVERT) 220 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 221 1.100 darran .endif 222 1.1 cgd .s.o: 223 1.27 mycroft ${COMPILE.s} ${.IMPSRC} 224 1.100 darran .if defined(CTFCONVERT) 225 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 226 1.100 darran .endif 227 1.15 jtc .s.a: 228 1.15 jtc ${COMPILE.s} ${.IMPSRC} 229 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 230 1.76 lukem rm -f ${.PREFIX}.o 231 1.15 jtc .S: 232 1.15 jtc ${LINK.S} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} 233 1.100 darran .if defined(CTFCONVERT) 234 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 235 1.100 darran .endif 236 1.8 brezak .S.o: 237 1.27 mycroft ${COMPILE.S} ${.IMPSRC} 238 1.100 darran .if defined(CTFCONVERT) 239 1.100 darran ${CTFCONVERT} ${CTFFLAGS} ${.TARGET} 240 1.100 darran .endif 241 1.15 jtc .S.a: 242 1.15 jtc ${COMPILE.S} ${.IMPSRC} 243 1.76 lukem ${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o 244 1.76 lukem rm -f ${.PREFIX}.o 245 1.1 cgd 246 1.15 jtc # Lex 247 1.15 jtc .l: 248 1.15 jtc ${LEX.l} ${.IMPSRC} 249 1.15 jtc ${LINK.c} -o ${.TARGET} lex.yy.c ${LDLIBS} -ll 250 1.15 jtc rm -f lex.yy.c 251 1.15 jtc .l.c: 252 1.15 jtc ${LEX.l} ${.IMPSRC} 253 1.15 jtc mv lex.yy.c ${.TARGET} 254 1.1 cgd .l.o: 255 1.15 jtc ${LEX.l} ${.IMPSRC} 256 1.75 lukem ${COMPILE.c} -o ${.TARGET} lex.yy.c 257 1.1 cgd rm -f lex.yy.c 258 1.1 cgd 259 1.15 jtc # Yacc 260 1.15 jtc .y: 261 1.15 jtc ${YACC.y} ${.IMPSRC} 262 1.15 jtc ${LINK.c} -o ${.TARGET} y.tab.c ${LDLIBS} 263 1.15 jtc rm -f y.tab.c 264 1.38 tv .y.c: 265 1.15 jtc ${YACC.y} ${.IMPSRC} 266 1.38 tv mv y.tab.c ${.TARGET} 267 1.15 jtc .y.o: 268 1.15 jtc ${YACC.y} ${.IMPSRC} 269 1.15 jtc ${COMPILE.c} -o ${.TARGET} y.tab.c 270 1.1 cgd rm -f y.tab.c 271 1.1 cgd 272 1.15 jtc # Shell 273 1.15 jtc .sh: 274 1.15 jtc rm -f ${.TARGET} 275 1.15 jtc cp ${.IMPSRC} ${.TARGET} 276 1.79 lukem chmod a+x ${.TARGET} 277