xref: /freebsd/stand/defs.mk (revision 5e9226f063bc43574e2168b4aafad8232f08002a)
1ca987d46SWarner Losh# $FreeBSD$
2ca987d46SWarner Losh
3ca987d46SWarner Losh.if !defined(__BOOT_DEFS_MK__)
4ca987d46SWarner Losh__BOOT_DEFS_MK__=${MFILE}
5ca987d46SWarner Losh
6991699dbSWarner Losh# We need to define all the MK_ options before including src.opts.mk
7991699dbSWarner Losh# because it includes bsd.own.mk which needs the right MK_ values,
8991699dbSWarner Losh# espeically MK_CTF.
9991699dbSWarner Losh
108299b37fSWarner LoshMK_CTF=		no
118299b37fSWarner LoshMK_SSP=		no
128299b37fSWarner LoshMK_PROFILE=	no
138299b37fSWarner LoshMAN=
1411421c37SWarner Losh.if !defined(PIC)
1511421c37SWarner LoshNO_PIC=
168299b37fSWarner LoshINTERNALLIB=
1711421c37SWarner Losh.endif
187a0c0ff7SWarner Losh# Should be NO_CPU_FLAGS, but bsd.cpu.mk is included too early in bsd.init.mk
197a0c0ff7SWarner Losh# via the early include of bsd.opts.mk. Moving Makefile.inc include earlier in
207a0c0ff7SWarner Losh# that file causes weirdness, so this is the next best thing. We need to do this
217a0c0ff7SWarner Losh# because the loader needs very specific flags to work right, and things like
227a0c0ff7SWarner Losh# CPUTYPE?=native prevent that, and introduce an endless game of whack-a-mole
237a0c0ff7SWarner Losh# to disable more and more features. Boot loader performance is never improved
247a0c0ff7SWarner Losh# enough to make that hassle worth chasing.
257a0c0ff7SWarner Losh_CPUCFLAGS=
268299b37fSWarner Losh
27*5e9226f0SAlex Richardson.if ${LDFLAGS:M-nostdlib}
28*5e9226f0SAlex Richardson# Sanitizers won't work unless we link against libc (e.g. in userboot/test).
29*5e9226f0SAlex RichardsonMK_ASAN:=	no
30*5e9226f0SAlex RichardsonMK_UBSAN:=	no
31*5e9226f0SAlex Richardson.endif
32*5e9226f0SAlex Richardson
33991699dbSWarner Losh.include <src.opts.mk>
345e697f5fSMitchell Horne.include <bsd.linker.mk>
35991699dbSWarner Losh
36991699dbSWarner LoshWARNS?=		1
37991699dbSWarner Losh
38ca987d46SWarner LoshBOOTSRC=	${SRCTOP}/stand
39ca987d46SWarner LoshEFISRC=		${BOOTSRC}/efi
40ca987d46SWarner LoshEFIINC=		${EFISRC}/include
41ca987d46SWarner LoshEFIINCMD=	${EFIINC}/${MACHINE}
42ca987d46SWarner LoshFDTSRC=		${BOOTSRC}/fdt
43ca987d46SWarner LoshFICLSRC=	${BOOTSRC}/ficl
44ca987d46SWarner LoshLDRSRC=		${BOOTSRC}/common
457cafeaa1SWarner LoshLIBLUASRC=	${BOOTSRC}/liblua
46475008d6SBrandon BergrenLIBOFWSRC=	${BOOTSRC}/libofw
477cafeaa1SWarner LoshLUASRC=		${SRCTOP}/contrib/lua/src
48ca987d46SWarner LoshSASRC=		${BOOTSRC}/libsa
49ca987d46SWarner LoshSYSDIR=		${SRCTOP}/sys
50ca987d46SWarner LoshUBOOTSRC=	${BOOTSRC}/uboot
51b8902de1SWarner LoshZFSSRC=		${SASRC}/zfs
524c570f61SWarner LoshOZFS=		${SRCTOP}/sys/contrib/openzfs
534c570f61SWarner LoshZFSOSSRC=	${OZFS}/module/os/freebsd/
544c570f61SWarner LoshZFSOSINC=	${OZFS}/include/os/freebsd
5580335781SKyle EvansLIBCSRC=	${SRCTOP}/lib/libc
56ca987d46SWarner Losh
57ca987d46SWarner LoshBOOTOBJ=	${OBJTOP}/stand
58ca987d46SWarner Losh
59ca987d46SWarner Losh# BINDIR is where we install
60ca987d46SWarner LoshBINDIR?=	/boot
61ca987d46SWarner Losh
62ee74c236SKyle Evans# LUAPATH is where we search for and install lua scripts.
63ee74c236SKyle EvansLUAPATH?=	/boot/lua
64506f3640SKyle EvansFLUASRC?=	${SRCTOP}/libexec/flua
65ee74c236SKyle Evans
66ca987d46SWarner LoshLIBSA=		${BOOTOBJ}/libsa/libsa.a
67ca987d46SWarner Losh.if ${MACHINE} == "i386"
68ca987d46SWarner LoshLIBSA32=	${LIBSA}
69ca987d46SWarner Losh.else
70ca987d46SWarner LoshLIBSA32=	${BOOTOBJ}/libsa32/libsa32.a
71ca987d46SWarner Losh.endif
72ca987d46SWarner Losh
73ca987d46SWarner Losh# Standard options:
7405f37f4dSWarner LoshCFLAGS+=	-nostdinc
75f9553770SWarner Losh# Allow CFLAGS_EARLY.file/target so that code that needs specific stack
76f9553770SWarner Losh# of include paths can set them up before our include paths. Normally
77f9553770SWarner Losh# the only thing that should be there are -I directives, and as few of
78f9553770SWarner Losh# those as possible.
79f9553770SWarner LoshCFLAGS+=	${CFLAGS_EARLY} ${CFLAGS_EARLY.${.IMPSRC:T}} ${CFLAGS_EARLY.${.TARGET:T}}
8005f37f4dSWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
8105f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa32
8205f37f4dSWarner Losh.else
8305f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa
8405f37f4dSWarner Losh.endif
85b65d7763SWarner LoshCFLAGS+=	-I${SASRC} -D_STANDALONE
864f6b2874SWarner LoshCFLAGS+=	-I${SYSDIR}
87ef1fcaf0SWarner Losh# Spike the floating point interfaces
88e52cfb3eSWarner LoshCFLAGS+=	-Ddouble=jagged-little-pill -Dfloat=floaty-mcfloatface
890125fb63SWarner Losh.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
90f835d609SWarner Losh# Slim down the image. This saves about 15% in size with clang 6 on x86
91f835d609SWarner Losh# Our most constrained /boot/loader env is BIOS booting on x86, where
92f835d609SWarner Losh# our text + data + BTX have to fit into 640k below the ISA hole.
93f835d609SWarner Losh# Experience has shown that problems arise between ~520k to ~530k.
94f835d609SWarner LoshCFLAGS.clang+=	-Oz
95f835d609SWarner LoshCFLAGS.gcc+=	-Os
96094b4065SToomas SoomeCFLAGS+=	-ffunction-sections -fdata-sections
970125fb63SWarner Losh.endif
98ca987d46SWarner Losh
995ba722feSWarner Losh# GELI Support, with backward compat hooks (mostly)
100ca987d46SWarner Losh.if defined(LOADER_NO_GELI_SUPPORT)
101ca987d46SWarner LoshMK_LOADER_GELI=no
102ca987d46SWarner Losh.warning "Please move from LOADER_NO_GELI_SUPPORT to WITHOUT_LOADER_GELI"
103ca987d46SWarner Losh.endif
104ca987d46SWarner Losh.if defined(LOADER_GELI_SUPPORT)
105ca987d46SWarner LoshMK_LOADER_GELI=yes
106ca987d46SWarner Losh.warning "Please move from LOADER_GELI_SUPPORT to WITH_LOADER_GELI"
107ca987d46SWarner Losh.endif
108ca987d46SWarner Losh.if ${MK_LOADER_GELI} == "yes"
109ca987d46SWarner LoshCFLAGS+=	-DLOADER_GELI_SUPPORT
11062bd02ceSWarner LoshCFLAGS+=	-I${SASRC}/geli
1114927bbceSWarner Losh.endif # MK_LOADER_GELI
112ca987d46SWarner Losh
1138701bb8fSWarner Losh# These should be confined to loader.mk, but can't because uboot/lib
1148701bb8fSWarner Losh# also uses it. It's part of loader, but isn't a loader so we can't
1158701bb8fSWarner Losh# just include loader.mk
1168701bb8fSWarner Losh.if ${LOADER_DISK_SUPPORT:Uyes} == "yes"
1178701bb8fSWarner LoshCFLAGS+= -DLOADER_DISK_SUPPORT
1188701bb8fSWarner Losh.endif
1198701bb8fSWarner Losh
1204f6b2874SWarner Losh# Machine specific flags for all builds here
121ca987d46SWarner Losh
122b75abea4SBrandon Bergren# Ensure PowerPC64 and PowerPC64LE boot loaders are compiled as 32 bit
123b75abea4SBrandon Bergren# and in big endian.
124b75abea4SBrandon Bergren.if ${MACHINE_ARCH:Mpowerpc64*} != ""
125b75abea4SBrandon BergrenCFLAGS+=	-m32 -mcpu=powerpc -mbig-endian
126ca987d46SWarner Losh.endif
127ca987d46SWarner Losh
128ca987d46SWarner Losh# For amd64, there's a bit of mixed bag. Some of the tree (i386, lib*32) is
129ca987d46SWarner Losh# build 32-bit and some 64-bit (lib*, efi). Centralize all the 32-bit magic here
130ca987d46SWarner Losh# and activate it when DO32 is explicitly defined to be 1.
131ca987d46SWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
132073193edSDimitry AndricCFLAGS+=	-m32
133ca987d46SWarner Losh# LD_FLAGS is passed directly to ${LD}, not via ${CC}:
134ca987d46SWarner LoshLD_FLAGS+=	-m elf_i386_fbsd
135ca987d46SWarner LoshAFLAGS+=	--32
136ca987d46SWarner Losh.endif
137ca987d46SWarner Losh
1384f6b2874SWarner LoshSSP_CFLAGS=
1394f6b2874SWarner Losh
1404f6b2874SWarner Losh# Add in the no float / no SIMD stuff and announce we're freestanding
1412192efc0SMitchell Horne# aarch64 and riscv don't have -msoft-float, but all others do.
1424f6b2874SWarner LoshCFLAGS+=	-ffreestanding ${CFLAGS_NO_SIMD}
1434f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "aarch64"
144a2e2311aSAndrew TurnerCFLAGS+=	-mgeneral-regs-only -ffixed-x18 -fPIC
145fcdb1f03SWarner Losh.elif ${MACHINE_CPUARCH} == "riscv"
1462192efc0SMitchell HorneCFLAGS+=	-march=rv64imac -mabi=lp64 -fPIC
1472192efc0SMitchell HorneCFLAGS.clang+=	-mcmodel=medium
1482192efc0SMitchell HorneCFLAGS.gcc+=	-mcmodel=medany
149fcdb1f03SWarner Losh.else
1504f6b2874SWarner LoshCFLAGS+=	-msoft-float
1514f6b2874SWarner Losh.endif
1524f6b2874SWarner Losh
15389797c88SJustin Hibbits# -msoft-float seems to be insufficient for powerpcspe
15489797c88SJustin Hibbits.if ${MACHINE_ARCH} == "powerpcspe"
15589797c88SJustin HibbitsCFLAGS+=	-mno-spe
15689797c88SJustin Hibbits.endif
15789797c88SJustin Hibbits
1584f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || (${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 1)
1594f6b2874SWarner LoshCFLAGS+=	-march=i386
1604f6b2874SWarner LoshCFLAGS.gcc+=	-mpreferred-stack-boundary=2
1614f6b2874SWarner Losh.endif
162fcdb1f03SWarner Losh.if ${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 0
163fcdb1f03SWarner LoshCFLAGS+=	-fPIC -mno-red-zone
164fcdb1f03SWarner Losh.endif
1654f6b2874SWarner Losh
1664f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "arm"
1674f6b2874SWarner Losh# Do not generate movt/movw, because the relocation fixup for them does not
1684f6b2874SWarner Losh# translate to the -Bsymbolic -pie format required by self_reloc() in loader(8).
1694f6b2874SWarner Losh# Also, the fpu is not available in a standalone environment.
1704f6b2874SWarner LoshCFLAGS.clang+=	-mno-movt
1714f6b2874SWarner LoshCFLAGS.clang+=  -mfpu=none
172fcdb1f03SWarner LoshCFLAGS+=	-fPIC
1734f6b2874SWarner Losh.endif
1744f6b2874SWarner Losh
1752192efc0SMitchell Horne# Some RISC-V linkers have support for relaxations, while some (lld) do not
1762192efc0SMitchell Horne# yet. If this is the case we inhibit the compiler from emitting relaxations.
1775e697f5fSMitchell Horne.if ${LINKER_FEATURES:Mriscv-relaxations} == ""
1782192efc0SMitchell HorneCFLAGS+=	-mno-relax
1792192efc0SMitchell Horne.endif
1802192efc0SMitchell Horne
1814f6b2874SWarner Losh# The boot loader build uses dd status=none, where possible, for reproducible
1824f6b2874SWarner Losh# build output (since performance varies from run to run). Trouble is that
1834f6b2874SWarner Losh# option was recently (10.3) added to FreeBSD and is non-standard. Only use it
1844f6b2874SWarner Losh# when this test succeeds rather than require dd to be a bootstrap tool.
1854f6b2874SWarner LoshDD_NOSTATUS!=(dd status=none count=0 2> /dev/null && echo status=none) || true
1864f6b2874SWarner LoshDD=dd ${DD_NOSTATUS}
1874f6b2874SWarner Losh
188fcdb1f03SWarner Losh.if ${MACHINE_CPUARCH} == "mips"
189fcdb1f03SWarner LoshCFLAGS+=	-G0 -fno-pic -mno-abicalls
190fcdb1f03SWarner Losh.endif
191fcdb1f03SWarner Losh
1929d45c24cSWarner Losh#
1939d45c24cSWarner Losh# Have a sensible default
1949d45c24cSWarner Losh#
195f9f8ac94SKyle Evans.if ${MK_LOADER_LUA} == "yes"
1969d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=lua
197f9f8ac94SKyle Evans.elif ${MK_FORTH} == "yes"
198f9f8ac94SKyle EvansLOADER_DEFAULT_INTERP?=4th
1999d45c24cSWarner Losh.else
2009d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=simp
2019d45c24cSWarner Losh.endif
2029d45c24cSWarner LoshLOADER_INTERP?=${LOADER_DEFAULT_INTERP}
2039d45c24cSWarner Losh
204ca987d46SWarner Losh# Make sure we use the machine link we're about to create
205ca987d46SWarner LoshCFLAGS+=-I.
206ca987d46SWarner Losh
207a0139c46SWarner Loshall: ${PROG}
208a0139c46SWarner Losh
20956758831SToomas SoomeCLEANFILES+= teken_state.h
21056758831SToomas Soometeken.c: teken_state.h
21156758831SToomas Soome
21256758831SToomas Soometeken_state.h: ${SYSDIR}/teken/sequences
21356758831SToomas Soome	awk -f ${SYSDIR}/teken/gensequences \
21456758831SToomas Soome		${SYSDIR}/teken/sequences > teken_state.h
21556758831SToomas Soome
216a0139c46SWarner Losh.if !defined(NO_OBJ)
217e9b148a3SSimon J. Gerraty_ILINKS=include/machine
218ca987d46SWarner Losh.if ${MACHINE} != ${MACHINE_CPUARCH} && ${MACHINE} != "arm64"
219e9b148a3SSimon J. Gerraty_ILINKS+=include/${MACHINE_CPUARCH}
220ca987d46SWarner Losh.endif
221ca987d46SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
222e9b148a3SSimon J. Gerraty_ILINKS+=include/x86
223ca987d46SWarner Losh.endif
224e9b148a3SSimon J. GerratyCFLAGS+= -Iinclude
225e9b148a3SSimon J. GerratyCLEANDIRS+= include
226ca987d46SWarner Losh
227ca987d46SWarner Loshbeforedepend: ${_ILINKS}
228ca987d46SWarner Loshbeforebuild: ${_ILINKS}
229ca987d46SWarner Losh
230ca987d46SWarner Losh# Ensure that the links exist without depending on it when it exists which
231ca987d46SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes.
232ca987d46SWarner Losh.for _link in ${_ILINKS}
233ca987d46SWarner Losh.if !exists(${.OBJDIR}/${_link})
234ca987d46SWarner Losh${OBJS}:       ${_link}
235a0139c46SWarner Losh.endif # _link exists
236ca987d46SWarner Losh.endfor
237ca987d46SWarner Losh
238ca987d46SWarner Losh.NOPATH: ${_ILINKS}
239ca987d46SWarner Losh
240e9b148a3SSimon J. Gerraty${_ILINKS}: .NOMETA
241e9b148a3SSimon J. Gerraty	@case ${.TARGET:T} in \
242ca987d46SWarner Losh	machine) \
243ca987d46SWarner Losh		if [ ${DO32:U0} -eq 0 ]; then \
244ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE}/include ; \
245ca987d46SWarner Losh		else \
246ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE:C/amd64/i386/}/include ; \
247ca987d46SWarner Losh		fi ;; \
248ca987d46SWarner Losh	*) \
249ca987d46SWarner Losh		path=${SYSDIR}/${.TARGET:T}/include ;; \
250ca987d46SWarner Losh	esac ; \
251e9b148a3SSimon J. Gerraty	case ${.TARGET} in \
252e9b148a3SSimon J. Gerraty	*/*) mkdir -p ${.TARGET:H};; \
253e9b148a3SSimon J. Gerraty	esac ; \
254ca987d46SWarner Losh	path=`(cd $$path && /bin/pwd)` ; \
255e9b148a3SSimon J. Gerraty	${ECHO} ${.TARGET} "->" $$path ; \
256d8e1e85cSAlex Richardson	ln -fns $$path ${.TARGET}
257a0139c46SWarner Losh.endif # !NO_OBJ
258ca987d46SWarner Losh.endif # __BOOT_DEFS_MK__
259