Home | History | Annotate | Line # | Download | only in mk
sys.mk revision 1.123.2.1
      1  1.123.2.1       tls #	$NetBSD: sys.mk,v 1.123.2.1 2014/08/10 06:53:30 tls Exp $
      2       1.30     mikel #	@(#)sys.mk	8.2 (Berkeley) 3/21/94
      3      1.111  christos #
      4      1.111  christos # This file contains the basic rules for make(1) and is read first
      5      1.111  christos # Do not put conditionals that are set on different files here and
      6      1.111  christos # expect them to work.
      7        1.1       cgd 
      8       1.30     mikel unix?=		We run NetBSD.
      9        1.1       cgd 
     10       1.80     lukem .SUFFIXES: .a .o .ln .s .S .c .cc .cpp .cxx .C .f .F .r .p .l .y .sh
     11        1.1       cgd 
     12        1.1       cgd .LIBS:		.a
     13        1.1       cgd 
     14       1.22  christos AR?=		ar
     15       1.22  christos ARFLAGS?=	rl
     16       1.22  christos RANLIB?=	ranlib
     17       1.22  christos 
     18       1.22  christos AS?=		as
     19       1.22  christos AFLAGS?=
     20      1.106     joerg COMPILE.s?=	${CC} ${AFLAGS} ${AFLAGS.${<:T}} -c
     21      1.106     joerg LINK.s?=	${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${LDFLAGS}
     22      1.101     joerg _ASM_TRADITIONAL_CPP=	-x assembler-with-cpp
     23      1.106     joerg COMPILE.S?=	${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${CPPFLAGS} ${_ASM_TRADITIONAL_CPP} -c
     24      1.106     joerg LINK.S?=	${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${CPPFLAGS} ${LDFLAGS}
     25       1.22  christos 
     26       1.22  christos CC?=		cc
     27      1.107       chs .if ${MACHINE_ARCH} == "sh3el" || ${MACHINE_ARCH} == "sh3eb"
     28       1.97       uwe # -O2 is too -falign-* zealous for low-memory sh3 machines
     29       1.97       uwe DBG?=	-Os -freorder-blocks
     30      1.107       chs .elif ${MACHINE_ARCH} == "m68k" || ${MACHINE_ARCH} == "m68000"
     31  1.123.2.1       tls # -freorder-blocks (enabled by -O2) produces much bigger code
     32  1.123.2.1       tls DBG?=	-O2 -fno-reorder-blocks
     33      1.117      matt .elif ${MACHINE_ARCH} == "coldfire"
     34      1.117      matt DBG?=	-O1
     35      1.109       abs .elif ${MACHINE_ARCH} == "vax"
     36      1.109       abs DBG?=	-O1 -fgcse -fstrength-reduce -fgcse-after-reload
     37       1.44   mycroft .else
     38      1.107       chs DBG?=	-O2
     39       1.44   mycroft .endif
     40       1.57       sjg CFLAGS?=	${DBG}
     41       1.87     lukem LDFLAGS?=
     42       1.22  christos COMPILE.c?=	${CC} ${CFLAGS} ${CPPFLAGS} -c
     43       1.22  christos LINK.c?=	${CC} ${CFLAGS} ${CPPFLAGS} ${LDFLAGS}
     44       1.22  christos 
     45      1.100    darran # C Type Format data is required for DTrace
     46      1.116      yamt CTFFLAGS	?=	-g -L VERSION
     47      1.122  christos # Use only one thread for now.
     48      1.122  christos CTFMFLAGS	?=	-S 1 -g -t -L VERSION
     49      1.100    darran 
     50       1.41        tv CXX?=		c++
     51      1.118  christos CXXFLAGS?=	${CFLAGS:N-Wno-traditional:N-Wstrict-prototypes:N-Wmissing-prototypes:N-Wno-pointer-sign:N-ffreestanding:N-std=gnu[0-9][0-9]:N-Wold-style-definition:N-Wno-format-zero-length}
     52       1.89  christos 
     53       1.98     joerg __ALLSRC1=	${empty(DESTDIR):?${.ALLSRC}:${.ALLSRC:S|^${DESTDIR}|^destdir|}}
     54       1.98     joerg __ALLSRC2=	${empty(MAKEOBJDIR):?${__ALLSRC1}:${__ALLSRC1:S|^${MAKEOBJDIR}|^obj|}}
     55       1.98     joerg __ALLSRC3=	${empty(NETBSDSRCDIR):?${__ALLSRC2}:${__ALLSRC2:S|^${NETBSDSRCDIR}|^src|}}
     56      1.105     joerg __BUILDSEED=	${BUILDSEED}/${__ALLSRC3:O}/${.TARGET}
     57      1.105     joerg _CXXSEED?=	${BUILDSEED:D-frandom-seed=${__BUILDSEED:hash}}
     58       1.98     joerg 
     59       1.98     joerg COMPILE.cc?=	${CXX} ${_CXXSEED} ${CXXFLAGS} ${CPPFLAGS} -c
     60       1.22  christos LINK.cc?=	${CXX} ${CXXFLAGS} ${CPPFLAGS} ${LDFLAGS}
     61       1.34     lukem 
     62       1.34     lukem OBJC?=		${CC}
     63       1.34     lukem OBJCFLAGS?=	${CFLAGS}
     64       1.34     lukem COMPILE.m?=	${OBJC} ${OBJCFLAGS} ${CPPFLAGS} -c
     65       1.34     lukem LINK.m?=	${OBJC} ${OBJCFLAGS} ${CPPFLAGS} ${LDFLAGS}
     66        1.3   mycroft 
     67       1.22  christos CPP?=		cpp
     68       1.75     lukem CPPFLAGS?=
     69        1.1       cgd 
     70       1.22  christos FC?=		f77
     71       1.30     mikel FFLAGS?=	-O
     72       1.22  christos RFLAGS?=
     73       1.22  christos COMPILE.f?=	${FC} ${FFLAGS} -c
     74       1.22  christos LINK.f?=	${FC} ${FFLAGS} ${LDFLAGS}
     75       1.22  christos COMPILE.F?=	${FC} ${FFLAGS} ${CPPFLAGS} -c
     76       1.22  christos LINK.F?=	${FC} ${FFLAGS} ${CPPFLAGS} ${LDFLAGS}
     77       1.22  christos COMPILE.r?=	${FC} ${FFLAGS} ${RFLAGS} -c
     78       1.22  christos LINK.r?=	${FC} ${FFLAGS} ${RFLAGS} ${LDFLAGS}
     79       1.29   thorpej 
     80       1.29   thorpej INSTALL?=	install
     81       1.22  christos 
     82       1.79     lukem LD?=		ld
     83       1.79     lukem 
     84       1.22  christos LEX?=		lex
     85       1.22  christos LFLAGS?=
     86       1.22  christos LEX.l?=		${LEX} ${LFLAGS}
     87       1.22  christos 
     88       1.22  christos LINT?=		lint
     89  1.123.2.1       tls LINTFLAGS?=	-chapbxzgFS
     90       1.22  christos 
     91       1.36       gwr LORDER?=	lorder
     92       1.36       gwr 
     93       1.22  christos MAKE?=		make
     94       1.22  christos 
     95       1.36       gwr NM?=		nm
     96       1.36       gwr 
     97       1.22  christos PC?=		pc
     98       1.22  christos PFLAGS?=
     99       1.22  christos COMPILE.p?=	${PC} ${PFLAGS} ${CPPFLAGS} -c
    100       1.22  christos LINK.p?=	${PC} ${PFLAGS} ${CPPFLAGS} ${LDFLAGS}
    101       1.22  christos 
    102       1.22  christos SHELL?=		sh
    103       1.36       gwr 
    104       1.36       gwr SIZE?=		size
    105       1.36       gwr 
    106       1.36       gwr TSORT?= 	tsort -q
    107       1.22  christos 
    108       1.22  christos YACC?=		yacc
    109       1.40        tv YFLAGS?=
    110       1.22  christos YACC.y?=	${YACC} ${YFLAGS}
    111        1.1       cgd 
    112       1.15       jtc # C
    113       1.14       jtc .c:
    114       1.15       jtc 	${LINK.c} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    115      1.120  christos # XXX: disable for now
    116  1.123.2.1       tls #	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    117       1.15       jtc .c.o:
    118       1.15       jtc 	${COMPILE.c} ${.IMPSRC}
    119  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    120       1.15       jtc .c.a:
    121       1.15       jtc 	${COMPILE.c} ${.IMPSRC}
    122       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    123       1.76     lukem 	rm -f ${.PREFIX}.o
    124       1.21       cgd .c.ln:
    125       1.83     lukem 	${LINT} ${LINTFLAGS} \
    126       1.83     lukem 	    ${CPPFLAGS:C/-([IDU])[  ]*/-\1/Wg:M-[IDU]*} \
    127       1.83     lukem 	    -i ${.IMPSRC}
    128       1.14       jtc 
    129       1.15       jtc # C++
    130       1.55  jdolecek .cc .cpp .cxx .C:
    131       1.15       jtc 	${LINK.cc} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    132       1.55  jdolecek .cc.o .cpp.o .cxx.o .C.o:
    133       1.15       jtc 	${COMPILE.cc} ${.IMPSRC}
    134       1.55  jdolecek .cc.a .cpp.a .cxx.a .C.a:
    135       1.15       jtc 	${COMPILE.cc} ${.IMPSRC}
    136       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    137       1.76     lukem 	rm -f ${.PREFIX}.o
    138       1.14       jtc 
    139       1.15       jtc # Fortran/Ratfor
    140       1.15       jtc .f:
    141       1.15       jtc 	${LINK.f} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    142       1.15       jtc .f.o:
    143       1.15       jtc 	${COMPILE.f} ${.IMPSRC}
    144  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    145       1.15       jtc .f.a:
    146       1.15       jtc 	${COMPILE.f} ${.IMPSRC}
    147       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    148       1.76     lukem 	rm -f ${.PREFIX}.o
    149       1.14       jtc 
    150       1.15       jtc .F:
    151       1.15       jtc 	${LINK.F} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    152  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    153       1.15       jtc .F.o:
    154       1.15       jtc 	${COMPILE.F} ${.IMPSRC}
    155  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    156       1.15       jtc .F.a:
    157       1.15       jtc 	${COMPILE.F} ${.IMPSRC}
    158       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    159       1.76     lukem 	rm -f ${.PREFIX}.o
    160       1.14       jtc 
    161       1.15       jtc .r:
    162       1.15       jtc 	${LINK.r} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    163       1.15       jtc .r.o:
    164       1.15       jtc 	${COMPILE.r} ${.IMPSRC}
    165  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    166       1.15       jtc .r.a:
    167       1.15       jtc 	${COMPILE.r} ${.IMPSRC}
    168       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    169       1.76     lukem 	rm -f ${.PREFIX}.o
    170        1.9       jtc 
    171       1.15       jtc # Pascal
    172       1.15       jtc .p:
    173       1.15       jtc 	${LINK.p} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    174  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    175        1.1       cgd .p.o:
    176       1.15       jtc 	${COMPILE.p} ${.IMPSRC}
    177  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    178       1.15       jtc .p.a:
    179       1.15       jtc 	${COMPILE.p} ${.IMPSRC}
    180       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    181       1.76     lukem 	rm -f ${.PREFIX}.o
    182        1.1       cgd 
    183       1.15       jtc # Assembly
    184       1.15       jtc .s:
    185       1.15       jtc 	${LINK.s} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    186  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    187        1.1       cgd .s.o:
    188       1.27   mycroft 	${COMPILE.s} ${.IMPSRC}
    189  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    190       1.15       jtc .s.a:
    191       1.15       jtc 	${COMPILE.s} ${.IMPSRC}
    192       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    193       1.76     lukem 	rm -f ${.PREFIX}.o
    194       1.15       jtc .S:
    195       1.15       jtc 	${LINK.S} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    196  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    197        1.8    brezak .S.o:
    198       1.27   mycroft 	${COMPILE.S} ${.IMPSRC}
    199  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    200       1.15       jtc .S.a:
    201       1.15       jtc 	${COMPILE.S} ${.IMPSRC}
    202       1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    203       1.76     lukem 	rm -f ${.PREFIX}.o
    204        1.1       cgd 
    205       1.15       jtc # Lex
    206       1.15       jtc .l:
    207       1.15       jtc 	${LEX.l} ${.IMPSRC}
    208       1.15       jtc 	${LINK.c} -o ${.TARGET} lex.yy.c ${LDLIBS} -ll
    209       1.15       jtc 	rm -f lex.yy.c
    210       1.15       jtc .l.c:
    211       1.15       jtc 	${LEX.l} ${.IMPSRC}
    212       1.15       jtc 	mv lex.yy.c ${.TARGET}
    213        1.1       cgd .l.o:
    214       1.15       jtc 	${LEX.l} ${.IMPSRC}
    215       1.75     lukem 	${COMPILE.c} -o ${.TARGET} lex.yy.c
    216  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    217        1.1       cgd 	rm -f lex.yy.c
    218        1.1       cgd 
    219       1.15       jtc # Yacc
    220       1.15       jtc .y:
    221       1.15       jtc 	${YACC.y} ${.IMPSRC}
    222       1.15       jtc 	${LINK.c} -o ${.TARGET} y.tab.c ${LDLIBS}
    223       1.15       jtc 	rm -f y.tab.c
    224       1.38        tv .y.c:
    225       1.15       jtc 	${YACC.y} ${.IMPSRC}
    226       1.38        tv 	mv y.tab.c ${.TARGET}
    227       1.15       jtc .y.o:
    228       1.15       jtc 	${YACC.y} ${.IMPSRC}
    229       1.15       jtc 	${COMPILE.c} -o ${.TARGET} y.tab.c
    230  1.123.2.1       tls 	${defined(CTFCONVERT):?${CTFCONVERT} ${CTFFLAGS} ${.TARGET}:}
    231        1.1       cgd 	rm -f y.tab.c
    232        1.1       cgd 
    233       1.15       jtc # Shell
    234       1.15       jtc .sh:
    235       1.15       jtc 	rm -f ${.TARGET}
    236       1.15       jtc 	cp ${.IMPSRC} ${.TARGET}
    237       1.79     lukem 	chmod a+x ${.TARGET}
    238