Home | History | Annotate | Line # | Download | only in mk
sys.mk revision 1.119
      1  1.119  christos #	$NetBSD: sys.mk,v 1.119 2013/12/31 18:46:09 christos 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.107       chs # see src/doc/HACKS for details
     32  1.107       chs DBG?=	-Os
     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.116      yamt CTFMFLAGS	?=	-g -t -L VERSION
     48  1.100    darran 
     49  1.119  christos # We have to define these here, because if we don't the rules below will
     50  1.119  christos # not work
     51  1.119  christos .if exists(/usr/bin/ctfconvert) && exists(/usr/bin/ctfmerge)
     52  1.119  christos CTFCONVERT	?=	ctfconvert
     53  1.119  christos CTFMERGE	?=	ctfmerge
     54  1.119  christos .endif
     55  1.100    darran 
     56   1.41        tv CXX?=		c++
     57  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}
     58   1.89  christos 
     59   1.98     joerg __ALLSRC1=	${empty(DESTDIR):?${.ALLSRC}:${.ALLSRC:S|^${DESTDIR}|^destdir|}}
     60   1.98     joerg __ALLSRC2=	${empty(MAKEOBJDIR):?${__ALLSRC1}:${__ALLSRC1:S|^${MAKEOBJDIR}|^obj|}}
     61   1.98     joerg __ALLSRC3=	${empty(NETBSDSRCDIR):?${__ALLSRC2}:${__ALLSRC2:S|^${NETBSDSRCDIR}|^src|}}
     62  1.105     joerg __BUILDSEED=	${BUILDSEED}/${__ALLSRC3:O}/${.TARGET}
     63  1.105     joerg _CXXSEED?=	${BUILDSEED:D-frandom-seed=${__BUILDSEED:hash}}
     64   1.98     joerg 
     65   1.98     joerg COMPILE.cc?=	${CXX} ${_CXXSEED} ${CXXFLAGS} ${CPPFLAGS} -c
     66   1.22  christos LINK.cc?=	${CXX} ${CXXFLAGS} ${CPPFLAGS} ${LDFLAGS}
     67   1.34     lukem 
     68   1.34     lukem OBJC?=		${CC}
     69   1.34     lukem OBJCFLAGS?=	${CFLAGS}
     70   1.34     lukem COMPILE.m?=	${OBJC} ${OBJCFLAGS} ${CPPFLAGS} -c
     71   1.34     lukem LINK.m?=	${OBJC} ${OBJCFLAGS} ${CPPFLAGS} ${LDFLAGS}
     72    1.3   mycroft 
     73   1.22  christos CPP?=		cpp
     74   1.75     lukem CPPFLAGS?=
     75    1.1       cgd 
     76   1.22  christos FC?=		f77
     77   1.30     mikel FFLAGS?=	-O
     78   1.22  christos RFLAGS?=
     79   1.22  christos COMPILE.f?=	${FC} ${FFLAGS} -c
     80   1.22  christos LINK.f?=	${FC} ${FFLAGS} ${LDFLAGS}
     81   1.22  christos COMPILE.F?=	${FC} ${FFLAGS} ${CPPFLAGS} -c
     82   1.22  christos LINK.F?=	${FC} ${FFLAGS} ${CPPFLAGS} ${LDFLAGS}
     83   1.22  christos COMPILE.r?=	${FC} ${FFLAGS} ${RFLAGS} -c
     84   1.22  christos LINK.r?=	${FC} ${FFLAGS} ${RFLAGS} ${LDFLAGS}
     85   1.29   thorpej 
     86   1.29   thorpej INSTALL?=	install
     87   1.22  christos 
     88   1.79     lukem LD?=		ld
     89   1.79     lukem 
     90   1.22  christos LEX?=		lex
     91   1.22  christos LFLAGS?=
     92   1.22  christos LEX.l?=		${LEX} ${LFLAGS}
     93   1.22  christos 
     94   1.22  christos LINT?=		lint
     95   1.85     perry LINTFLAGS?=	-chapbxzFS
     96   1.22  christos 
     97   1.36       gwr LORDER?=	lorder
     98   1.36       gwr 
     99   1.22  christos MAKE?=		make
    100   1.22  christos 
    101   1.36       gwr NM?=		nm
    102   1.36       gwr 
    103   1.22  christos PC?=		pc
    104   1.22  christos PFLAGS?=
    105   1.22  christos COMPILE.p?=	${PC} ${PFLAGS} ${CPPFLAGS} -c
    106   1.22  christos LINK.p?=	${PC} ${PFLAGS} ${CPPFLAGS} ${LDFLAGS}
    107   1.22  christos 
    108   1.22  christos SHELL?=		sh
    109   1.36       gwr 
    110   1.36       gwr SIZE?=		size
    111   1.36       gwr 
    112   1.36       gwr TSORT?= 	tsort -q
    113   1.22  christos 
    114   1.22  christos YACC?=		yacc
    115   1.40        tv YFLAGS?=
    116   1.22  christos YACC.y?=	${YACC} ${YFLAGS}
    117    1.1       cgd 
    118   1.15       jtc # C
    119   1.14       jtc .c:
    120   1.15       jtc 	${LINK.c} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    121  1.100    darran .if defined(CTFCONVERT)
    122  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    123  1.100    darran .endif
    124   1.15       jtc .c.o:
    125   1.15       jtc 	${COMPILE.c} ${.IMPSRC}
    126  1.100    darran .if defined(CTFCONVERT)
    127  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    128  1.100    darran .endif
    129   1.15       jtc .c.a:
    130   1.15       jtc 	${COMPILE.c} ${.IMPSRC}
    131   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    132   1.76     lukem 	rm -f ${.PREFIX}.o
    133   1.21       cgd .c.ln:
    134   1.83     lukem 	${LINT} ${LINTFLAGS} \
    135   1.83     lukem 	    ${CPPFLAGS:C/-([IDU])[  ]*/-\1/Wg:M-[IDU]*} \
    136   1.83     lukem 	    -i ${.IMPSRC}
    137   1.14       jtc 
    138   1.15       jtc # C++
    139   1.55  jdolecek .cc .cpp .cxx .C:
    140   1.15       jtc 	${LINK.cc} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    141   1.55  jdolecek .cc.o .cpp.o .cxx.o .C.o:
    142   1.15       jtc 	${COMPILE.cc} ${.IMPSRC}
    143   1.55  jdolecek .cc.a .cpp.a .cxx.a .C.a:
    144   1.15       jtc 	${COMPILE.cc} ${.IMPSRC}
    145   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    146   1.76     lukem 	rm -f ${.PREFIX}.o
    147   1.14       jtc 
    148   1.15       jtc # Fortran/Ratfor
    149   1.15       jtc .f:
    150   1.15       jtc 	${LINK.f} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    151   1.15       jtc .f.o:
    152   1.15       jtc 	${COMPILE.f} ${.IMPSRC}
    153  1.114  christos .if defined(CTFCONVERT)
    154  1.114  christos 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    155  1.114  christos .endif
    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 .F:
    162   1.15       jtc 	${LINK.F} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    163  1.100    darran .if defined(CTFCONVERT)
    164  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    165  1.100    darran .endif
    166   1.15       jtc .F.o:
    167   1.15       jtc 	${COMPILE.F} ${.IMPSRC}
    168  1.100    darran .if defined(CTFCONVERT)
    169  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    170  1.100    darran .endif
    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 .r:
    177   1.15       jtc 	${LINK.r} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    178   1.15       jtc .r.o:
    179   1.15       jtc 	${COMPILE.r} ${.IMPSRC}
    180  1.114  christos .if defined(CTFCONVERT)
    181  1.114  christos 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    182  1.114  christos .endif
    183   1.15       jtc .r.a:
    184   1.15       jtc 	${COMPILE.r} ${.IMPSRC}
    185   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    186   1.76     lukem 	rm -f ${.PREFIX}.o
    187    1.9       jtc 
    188   1.15       jtc # Pascal
    189   1.15       jtc .p:
    190   1.15       jtc 	${LINK.p} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    191  1.100    darran .if defined(CTFCONVERT)
    192  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    193  1.100    darran .endif
    194    1.1       cgd .p.o:
    195   1.15       jtc 	${COMPILE.p} ${.IMPSRC}
    196  1.100    darran .if defined(CTFCONVERT)
    197  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    198  1.100    darran .endif
    199   1.15       jtc .p.a:
    200   1.15       jtc 	${COMPILE.p} ${.IMPSRC}
    201   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    202   1.76     lukem 	rm -f ${.PREFIX}.o
    203    1.1       cgd 
    204   1.15       jtc # Assembly
    205   1.15       jtc .s:
    206   1.15       jtc 	${LINK.s} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    207  1.100    darran .if defined(CTFCONVERT)
    208  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    209  1.100    darran .endif
    210    1.1       cgd .s.o:
    211   1.27   mycroft 	${COMPILE.s} ${.IMPSRC}
    212  1.100    darran .if defined(CTFCONVERT)
    213  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    214  1.100    darran .endif
    215   1.15       jtc .s.a:
    216   1.15       jtc 	${COMPILE.s} ${.IMPSRC}
    217   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    218   1.76     lukem 	rm -f ${.PREFIX}.o
    219   1.15       jtc .S:
    220   1.15       jtc 	${LINK.S} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
    221  1.100    darran .if defined(CTFCONVERT)
    222  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    223  1.100    darran .endif
    224    1.8    brezak .S.o:
    225   1.27   mycroft 	${COMPILE.S} ${.IMPSRC}
    226  1.100    darran .if defined(CTFCONVERT)
    227  1.100    darran 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    228  1.100    darran .endif
    229   1.15       jtc .S.a:
    230   1.15       jtc 	${COMPILE.S} ${.IMPSRC}
    231   1.76     lukem 	${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
    232   1.76     lukem 	rm -f ${.PREFIX}.o
    233    1.1       cgd 
    234   1.15       jtc # Lex
    235   1.15       jtc .l:
    236   1.15       jtc 	${LEX.l} ${.IMPSRC}
    237   1.15       jtc 	${LINK.c} -o ${.TARGET} lex.yy.c ${LDLIBS} -ll
    238   1.15       jtc 	rm -f lex.yy.c
    239   1.15       jtc .l.c:
    240   1.15       jtc 	${LEX.l} ${.IMPSRC}
    241   1.15       jtc 	mv lex.yy.c ${.TARGET}
    242    1.1       cgd .l.o:
    243   1.15       jtc 	${LEX.l} ${.IMPSRC}
    244   1.75     lukem 	${COMPILE.c} -o ${.TARGET} lex.yy.c
    245  1.114  christos .if defined(CTFCONVERT)
    246  1.114  christos 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    247  1.114  christos .endif
    248    1.1       cgd 	rm -f lex.yy.c
    249    1.1       cgd 
    250   1.15       jtc # Yacc
    251   1.15       jtc .y:
    252   1.15       jtc 	${YACC.y} ${.IMPSRC}
    253   1.15       jtc 	${LINK.c} -o ${.TARGET} y.tab.c ${LDLIBS}
    254   1.15       jtc 	rm -f y.tab.c
    255   1.38        tv .y.c:
    256   1.15       jtc 	${YACC.y} ${.IMPSRC}
    257   1.38        tv 	mv y.tab.c ${.TARGET}
    258   1.15       jtc .y.o:
    259   1.15       jtc 	${YACC.y} ${.IMPSRC}
    260   1.15       jtc 	${COMPILE.c} -o ${.TARGET} y.tab.c
    261  1.114  christos .if defined(CTFCONVERT)
    262  1.114  christos 	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
    263  1.114  christos .endif
    264    1.1       cgd 	rm -f y.tab.c
    265    1.1       cgd 
    266   1.15       jtc # Shell
    267   1.15       jtc .sh:
    268   1.15       jtc 	rm -f ${.TARGET}
    269   1.15       jtc 	cp ${.IMPSRC} ${.TARGET}
    270   1.79     lukem 	chmod a+x ${.TARGET}
    271