9118f0148c
"-Os" was specfied when gcc 4.5.x was imported and the commit log says "-O2 produces much bigger code with gcc 4.5 than it did with gcc 4.1" but "-Os" disables most inline declarations and makes some applications much slower. "-O2 -fno-reorder-blocks" seems enough to reduce sizes and disabling -freorder-blocks wouldn't cause particular performance impact on ancient m68k machines with small cache memories. See my post on port-m68k@ for more details: http://mail-index.NetBSD.org/port-m68k/2014/06/22/msg000488.html No objection in the thread and "seems fine to me" from mrg@.
243 lines
5.6 KiB
Makefile
243 lines
5.6 KiB
Makefile
# $NetBSD: sys.mk,v 1.125 2014/06/29 05:20:15 tsutsui Exp $
|
|
# @(#)sys.mk 8.2 (Berkeley) 3/21/94
|
|
#
|
|
# This file contains the basic rules for make(1) and is read first
|
|
# Do not put conditionals that are set on different files here and
|
|
# expect them to work.
|
|
|
|
unix?= We run NetBSD.
|
|
|
|
.SUFFIXES: .a .o .ln .s .S .c .cc .cpp .cxx .C .f .F .r .p .l .y .sh
|
|
|
|
.LIBS: .a
|
|
|
|
AR?= ar
|
|
ARFLAGS?= rl
|
|
RANLIB?= ranlib
|
|
|
|
AS?= as
|
|
AFLAGS?=
|
|
COMPILE.s?= ${CC} ${AFLAGS} ${AFLAGS.${<:T}} -c
|
|
LINK.s?= ${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${LDFLAGS}
|
|
_ASM_TRADITIONAL_CPP= -x assembler-with-cpp
|
|
COMPILE.S?= ${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${CPPFLAGS} ${_ASM_TRADITIONAL_CPP} -c
|
|
LINK.S?= ${CC} ${AFLAGS} ${AFLAGS.${<:T}} ${CPPFLAGS} ${LDFLAGS}
|
|
|
|
CC?= cc
|
|
.if ${MACHINE_ARCH} == "sh3el" || ${MACHINE_ARCH} == "sh3eb"
|
|
# -O2 is too -falign-* zealous for low-memory sh3 machines
|
|
DBG?= -Os -freorder-blocks
|
|
.elif ${MACHINE_ARCH} == "m68k" || ${MACHINE_ARCH} == "m68000"
|
|
# -freorder-blocks (enabled by -O2) produces much bigger code
|
|
DBG?= -O2 -fno-reorder-blocks
|
|
.elif ${MACHINE_ARCH} == "coldfire"
|
|
DBG?= -O1
|
|
.elif ${MACHINE_ARCH} == "vax"
|
|
DBG?= -O1 -fgcse -fstrength-reduce -fgcse-after-reload
|
|
.else
|
|
DBG?= -O2
|
|
.endif
|
|
CFLAGS?= ${DBG}
|
|
LDFLAGS?=
|
|
COMPILE.c?= ${CC} ${CFLAGS} ${CPPFLAGS} -c
|
|
LINK.c?= ${CC} ${CFLAGS} ${CPPFLAGS} ${LDFLAGS}
|
|
|
|
# C Type Format data is required for DTrace
|
|
CTFFLAGS ?= -g -L VERSION
|
|
# Use only one thread for now.
|
|
CTFMFLAGS ?= -S 1 -g -t -L VERSION
|
|
|
|
# We have to define these here, because if we don't the rules below will
|
|
# not work
|
|
CTFCONVERT ?= : ctfconvert
|
|
CTFMERGE ?= : ctfmerge
|
|
|
|
CXX?= c++
|
|
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}
|
|
|
|
__ALLSRC1= ${empty(DESTDIR):?${.ALLSRC}:${.ALLSRC:S|^${DESTDIR}|^destdir|}}
|
|
__ALLSRC2= ${empty(MAKEOBJDIR):?${__ALLSRC1}:${__ALLSRC1:S|^${MAKEOBJDIR}|^obj|}}
|
|
__ALLSRC3= ${empty(NETBSDSRCDIR):?${__ALLSRC2}:${__ALLSRC2:S|^${NETBSDSRCDIR}|^src|}}
|
|
__BUILDSEED= ${BUILDSEED}/${__ALLSRC3:O}/${.TARGET}
|
|
_CXXSEED?= ${BUILDSEED:D-frandom-seed=${__BUILDSEED:hash}}
|
|
|
|
COMPILE.cc?= ${CXX} ${_CXXSEED} ${CXXFLAGS} ${CPPFLAGS} -c
|
|
LINK.cc?= ${CXX} ${CXXFLAGS} ${CPPFLAGS} ${LDFLAGS}
|
|
|
|
OBJC?= ${CC}
|
|
OBJCFLAGS?= ${CFLAGS}
|
|
COMPILE.m?= ${OBJC} ${OBJCFLAGS} ${CPPFLAGS} -c
|
|
LINK.m?= ${OBJC} ${OBJCFLAGS} ${CPPFLAGS} ${LDFLAGS}
|
|
|
|
CPP?= cpp
|
|
CPPFLAGS?=
|
|
|
|
FC?= f77
|
|
FFLAGS?= -O
|
|
RFLAGS?=
|
|
COMPILE.f?= ${FC} ${FFLAGS} -c
|
|
LINK.f?= ${FC} ${FFLAGS} ${LDFLAGS}
|
|
COMPILE.F?= ${FC} ${FFLAGS} ${CPPFLAGS} -c
|
|
LINK.F?= ${FC} ${FFLAGS} ${CPPFLAGS} ${LDFLAGS}
|
|
COMPILE.r?= ${FC} ${FFLAGS} ${RFLAGS} -c
|
|
LINK.r?= ${FC} ${FFLAGS} ${RFLAGS} ${LDFLAGS}
|
|
|
|
INSTALL?= install
|
|
|
|
LD?= ld
|
|
|
|
LEX?= lex
|
|
LFLAGS?=
|
|
LEX.l?= ${LEX} ${LFLAGS}
|
|
|
|
LINT?= lint
|
|
LINTFLAGS?= -chapbxzgFS
|
|
|
|
LORDER?= lorder
|
|
|
|
MAKE?= make
|
|
|
|
NM?= nm
|
|
|
|
PC?= pc
|
|
PFLAGS?=
|
|
COMPILE.p?= ${PC} ${PFLAGS} ${CPPFLAGS} -c
|
|
LINK.p?= ${PC} ${PFLAGS} ${CPPFLAGS} ${LDFLAGS}
|
|
|
|
SHELL?= sh
|
|
|
|
SIZE?= size
|
|
|
|
TSORT?= tsort -q
|
|
|
|
YACC?= yacc
|
|
YFLAGS?=
|
|
YACC.y?= ${YACC} ${YFLAGS}
|
|
|
|
# C
|
|
.c:
|
|
${LINK.c} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
# XXX: disable for now
|
|
# ${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.c.o:
|
|
${COMPILE.c} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.c.a:
|
|
${COMPILE.c} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
.c.ln:
|
|
${LINT} ${LINTFLAGS} \
|
|
${CPPFLAGS:C/-([IDU])[ ]*/-\1/Wg:M-[IDU]*} \
|
|
-i ${.IMPSRC}
|
|
|
|
# C++
|
|
.cc .cpp .cxx .C:
|
|
${LINK.cc} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
.cc.o .cpp.o .cxx.o .C.o:
|
|
${COMPILE.cc} ${.IMPSRC}
|
|
.cc.a .cpp.a .cxx.a .C.a:
|
|
${COMPILE.cc} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
# Fortran/Ratfor
|
|
.f:
|
|
${LINK.f} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
.f.o:
|
|
${COMPILE.f} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.f.a:
|
|
${COMPILE.f} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
.F:
|
|
${LINK.F} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.F.o:
|
|
${COMPILE.F} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.F.a:
|
|
${COMPILE.F} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
.r:
|
|
${LINK.r} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
.r.o:
|
|
${COMPILE.r} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.r.a:
|
|
${COMPILE.r} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
# Pascal
|
|
.p:
|
|
${LINK.p} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.p.o:
|
|
${COMPILE.p} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.p.a:
|
|
${COMPILE.p} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
# Assembly
|
|
.s:
|
|
${LINK.s} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.s.o:
|
|
${COMPILE.s} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.s.a:
|
|
${COMPILE.s} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
.S:
|
|
${LINK.S} -o ${.TARGET} ${.IMPSRC} ${LDLIBS}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.S.o:
|
|
${COMPILE.S} ${.IMPSRC}
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
.S.a:
|
|
${COMPILE.S} ${.IMPSRC}
|
|
${AR} ${ARFLAGS} ${.TARGET} ${.PREFIX}.o
|
|
rm -f ${.PREFIX}.o
|
|
|
|
# Lex
|
|
.l:
|
|
${LEX.l} ${.IMPSRC}
|
|
${LINK.c} -o ${.TARGET} lex.yy.c ${LDLIBS} -ll
|
|
rm -f lex.yy.c
|
|
.l.c:
|
|
${LEX.l} ${.IMPSRC}
|
|
mv lex.yy.c ${.TARGET}
|
|
.l.o:
|
|
${LEX.l} ${.IMPSRC}
|
|
${COMPILE.c} -o ${.TARGET} lex.yy.c
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
rm -f lex.yy.c
|
|
|
|
# Yacc
|
|
.y:
|
|
${YACC.y} ${.IMPSRC}
|
|
${LINK.c} -o ${.TARGET} y.tab.c ${LDLIBS}
|
|
rm -f y.tab.c
|
|
.y.c:
|
|
${YACC.y} ${.IMPSRC}
|
|
mv y.tab.c ${.TARGET}
|
|
.y.o:
|
|
${YACC.y} ${.IMPSRC}
|
|
${COMPILE.c} -o ${.TARGET} y.tab.c
|
|
${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
|
|
rm -f y.tab.c
|
|
|
|
# Shell
|
|
.sh:
|
|
rm -f ${.TARGET}
|
|
cp ${.IMPSRC} ${.TARGET}
|
|
chmod a+x ${.TARGET}
|