xref: /freebsd/stand/defs.mk (revision e34fd722)
1ca987d46SWarner Losh
2ca987d46SWarner Losh.if !defined(__BOOT_DEFS_MK__)
3ca987d46SWarner Losh__BOOT_DEFS_MK__=${MFILE}
4ca987d46SWarner Losh
5991699dbSWarner Losh# We need to define all the MK_ options before including src.opts.mk
6991699dbSWarner Losh# because it includes bsd.own.mk which needs the right MK_ values,
7991699dbSWarner Losh# espeically MK_CTF.
8991699dbSWarner Losh
98299b37fSWarner LoshMK_CTF=		no
108299b37fSWarner LoshMK_SSP=		no
118299b37fSWarner LoshMK_PROFILE=	no
12879675e9SWarner LoshMK_PIE=		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
275e9226f0SAlex Richardson.if ${LDFLAGS:M-nostdlib}
285e9226f0SAlex Richardson# Sanitizers won't work unless we link against libc (e.g. in userboot/test).
295e9226f0SAlex RichardsonMK_ASAN:=	no
305e9226f0SAlex RichardsonMK_UBSAN:=	no
315e9226f0SAlex Richardson.endif
325e9226f0SAlex 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
65e34fd722SWarner LoshFLUALIB?=	${SRCTOP}/lib/flua
66ee74c236SKyle Evans
67ca987d46SWarner LoshLIBSA=		${BOOTOBJ}/libsa/libsa.a
68ca987d46SWarner Losh.if ${MACHINE} == "i386"
69ca987d46SWarner LoshLIBSA32=	${LIBSA}
70ca987d46SWarner Losh.else
71ca987d46SWarner LoshLIBSA32=	${BOOTOBJ}/libsa32/libsa32.a
72ca987d46SWarner Losh.endif
73ca987d46SWarner Losh
74ca987d46SWarner Losh# Standard options:
7505f37f4dSWarner LoshCFLAGS+=	-nostdinc
76f9553770SWarner Losh# Allow CFLAGS_EARLY.file/target so that code that needs specific stack
77f9553770SWarner Losh# of include paths can set them up before our include paths. Normally
78f9553770SWarner Losh# the only thing that should be there are -I directives, and as few of
79f9553770SWarner Losh# those as possible.
80f9553770SWarner LoshCFLAGS+=	${CFLAGS_EARLY} ${CFLAGS_EARLY.${.IMPSRC:T}} ${CFLAGS_EARLY.${.TARGET:T}}
8105f37f4dSWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
8205f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa32
8305f37f4dSWarner Losh.else
8405f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa
8505f37f4dSWarner Losh.endif
86b65d7763SWarner LoshCFLAGS+=	-I${SASRC} -D_STANDALONE
874f6b2874SWarner LoshCFLAGS+=	-I${SYSDIR}
88ef1fcaf0SWarner Losh# Spike the floating point interfaces
89e52cfb3eSWarner LoshCFLAGS+=	-Ddouble=jagged-little-pill -Dfloat=floaty-mcfloatface
900125fb63SWarner Losh.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
91f835d609SWarner Losh# Slim down the image. This saves about 15% in size with clang 6 on x86
92f835d609SWarner Losh# Our most constrained /boot/loader env is BIOS booting on x86, where
93f835d609SWarner Losh# our text + data + BTX have to fit into 640k below the ISA hole.
94f835d609SWarner Losh# Experience has shown that problems arise between ~520k to ~530k.
95f835d609SWarner LoshCFLAGS.clang+=	-Oz
96f835d609SWarner LoshCFLAGS.gcc+=	-Os
97094b4065SToomas SoomeCFLAGS+=	-ffunction-sections -fdata-sections
980125fb63SWarner Losh.endif
99ca987d46SWarner Losh
1005ba722feSWarner Losh# GELI Support, with backward compat hooks (mostly)
101ca987d46SWarner Losh.if defined(LOADER_NO_GELI_SUPPORT)
102ca987d46SWarner LoshMK_LOADER_GELI=no
103ca987d46SWarner Losh.warning "Please move from LOADER_NO_GELI_SUPPORT to WITHOUT_LOADER_GELI"
104ca987d46SWarner Losh.endif
105ca987d46SWarner Losh.if defined(LOADER_GELI_SUPPORT)
106ca987d46SWarner LoshMK_LOADER_GELI=yes
107ca987d46SWarner Losh.warning "Please move from LOADER_GELI_SUPPORT to WITH_LOADER_GELI"
108ca987d46SWarner Losh.endif
109ca987d46SWarner Losh.if ${MK_LOADER_GELI} == "yes"
110ca987d46SWarner LoshCFLAGS+=	-DLOADER_GELI_SUPPORT
11162bd02ceSWarner LoshCFLAGS+=	-I${SASRC}/geli
1124927bbceSWarner Losh.endif # MK_LOADER_GELI
113ca987d46SWarner Losh
1148701bb8fSWarner Losh# These should be confined to loader.mk, but can't because uboot/lib
1158701bb8fSWarner Losh# also uses it. It's part of loader, but isn't a loader so we can't
1168701bb8fSWarner Losh# just include loader.mk
1178701bb8fSWarner Losh.if ${LOADER_DISK_SUPPORT:Uyes} == "yes"
1188701bb8fSWarner LoshCFLAGS+= -DLOADER_DISK_SUPPORT
1198701bb8fSWarner Losh.endif
1208701bb8fSWarner Losh
1214f6b2874SWarner Losh# Machine specific flags for all builds here
122ca987d46SWarner Losh
123f8328864SLeandro Lupori# Ensure PowerPC64 and PowerPC64LE boot loaders are compiled as 32 bit.
124f8328864SLeandro Lupori# PowerPC64LE boot loaders are 32-bit little-endian.
125f8328864SLeandro Lupori.if ${MACHINE_ARCH} == "powerpc64"
126b75abea4SBrandon BergrenCFLAGS+=	-m32 -mcpu=powerpc -mbig-endian
127f8328864SLeandro Lupori.elif ${MACHINE_ARCH} == "powerpc64le"
128f8328864SLeandro LuporiCFLAGS+=	-m32 -mcpu=powerpc -mlittle-endian
129ca987d46SWarner Losh.endif
130ca987d46SWarner Losh
131ca987d46SWarner Losh# For amd64, there's a bit of mixed bag. Some of the tree (i386, lib*32) is
132ca987d46SWarner Losh# build 32-bit and some 64-bit (lib*, efi). Centralize all the 32-bit magic here
133ca987d46SWarner Losh# and activate it when DO32 is explicitly defined to be 1.
134ca987d46SWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
135073193edSDimitry AndricCFLAGS+=	-m32
136ca987d46SWarner Losh# LD_FLAGS is passed directly to ${LD}, not via ${CC}:
137ca987d46SWarner LoshLD_FLAGS+=	-m elf_i386_fbsd
138ca987d46SWarner LoshAFLAGS+=	--32
139ca987d46SWarner Losh.endif
140ca987d46SWarner Losh
1414f6b2874SWarner Losh# Add in the no float / no SIMD stuff and announce we're freestanding
1422192efc0SMitchell Horne# aarch64 and riscv don't have -msoft-float, but all others do.
1434f6b2874SWarner LoshCFLAGS+=	-ffreestanding ${CFLAGS_NO_SIMD}
1444f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "aarch64"
145a2e2311aSAndrew TurnerCFLAGS+=	-mgeneral-regs-only -ffixed-x18 -fPIC
146fcdb1f03SWarner Losh.elif ${MACHINE_CPUARCH} == "riscv"
1472192efc0SMitchell HorneCFLAGS+=	-march=rv64imac -mabi=lp64 -fPIC
1482192efc0SMitchell HorneCFLAGS.clang+=	-mcmodel=medium
1492192efc0SMitchell HorneCFLAGS.gcc+=	-mcmodel=medany
150fcdb1f03SWarner Losh.else
1514f6b2874SWarner LoshCFLAGS+=	-msoft-float
1524f6b2874SWarner Losh.endif
1534f6b2874SWarner Losh
15489797c88SJustin Hibbits# -msoft-float seems to be insufficient for powerpcspe
15589797c88SJustin Hibbits.if ${MACHINE_ARCH} == "powerpcspe"
15689797c88SJustin HibbitsCFLAGS+=	-mno-spe
15789797c88SJustin Hibbits.endif
15889797c88SJustin Hibbits
1594f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || (${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 1)
1604f6b2874SWarner LoshCFLAGS+=	-march=i386
1614f6b2874SWarner LoshCFLAGS.gcc+=	-mpreferred-stack-boundary=2
1624f6b2874SWarner Losh.endif
163fcdb1f03SWarner Losh.if ${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 0
164fcdb1f03SWarner LoshCFLAGS+=	-fPIC -mno-red-zone
165fcdb1f03SWarner Losh.endif
1664f6b2874SWarner Losh
1674f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "arm"
1684f6b2874SWarner Losh# Do not generate movt/movw, because the relocation fixup for them does not
1694f6b2874SWarner Losh# translate to the -Bsymbolic -pie format required by self_reloc() in loader(8).
1704f6b2874SWarner Losh# Also, the fpu is not available in a standalone environment.
1714f6b2874SWarner LoshCFLAGS.clang+=	-mno-movt
1724f6b2874SWarner LoshCFLAGS.clang+=  -mfpu=none
173fcdb1f03SWarner LoshCFLAGS+=	-fPIC
1744f6b2874SWarner Losh.endif
1754f6b2874SWarner Losh
1762192efc0SMitchell Horne# Some RISC-V linkers have support for relaxations, while some (lld) do not
1772192efc0SMitchell Horne# yet. If this is the case we inhibit the compiler from emitting relaxations.
1785e697f5fSMitchell Horne.if ${LINKER_FEATURES:Mriscv-relaxations} == ""
1792192efc0SMitchell HorneCFLAGS+=	-mno-relax
1802192efc0SMitchell Horne.endif
1812192efc0SMitchell Horne
1824f6b2874SWarner Losh# The boot loader build uses dd status=none, where possible, for reproducible
1834f6b2874SWarner Losh# build output (since performance varies from run to run). Trouble is that
1844f6b2874SWarner Losh# option was recently (10.3) added to FreeBSD and is non-standard. Only use it
1854f6b2874SWarner Losh# when this test succeeds rather than require dd to be a bootstrap tool.
1864f6b2874SWarner LoshDD_NOSTATUS!=(dd status=none count=0 2> /dev/null && echo status=none) || true
1874f6b2874SWarner LoshDD=dd ${DD_NOSTATUS}
1884f6b2874SWarner Losh
1899d45c24cSWarner Losh#
1909d45c24cSWarner Losh# Have a sensible default
1919d45c24cSWarner Losh#
192f9f8ac94SKyle Evans.if ${MK_LOADER_LUA} == "yes"
1939d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=lua
194f9f8ac94SKyle Evans.elif ${MK_FORTH} == "yes"
195f9f8ac94SKyle EvansLOADER_DEFAULT_INTERP?=4th
1969d45c24cSWarner Losh.else
1979d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=simp
1989d45c24cSWarner Losh.endif
1999d45c24cSWarner LoshLOADER_INTERP?=${LOADER_DEFAULT_INTERP}
2009d45c24cSWarner Losh
201ca987d46SWarner Losh# Make sure we use the machine link we're about to create
202ca987d46SWarner LoshCFLAGS+=-I.
203ca987d46SWarner Losh
204a0139c46SWarner Loshall: ${PROG}
205a0139c46SWarner Losh
20656758831SToomas SoomeCLEANFILES+= teken_state.h
20756758831SToomas Soometeken.c: teken_state.h
20856758831SToomas Soome
20956758831SToomas Soometeken_state.h: ${SYSDIR}/teken/sequences
21056758831SToomas Soome	awk -f ${SYSDIR}/teken/gensequences \
21156758831SToomas Soome		${SYSDIR}/teken/sequences > teken_state.h
21256758831SToomas Soome
213a0139c46SWarner Losh.if !defined(NO_OBJ)
214e9b148a3SSimon J. Gerraty_ILINKS=include/machine
215ca987d46SWarner Losh.if ${MACHINE} != ${MACHINE_CPUARCH} && ${MACHINE} != "arm64"
216e9b148a3SSimon J. Gerraty_ILINKS+=include/${MACHINE_CPUARCH}
217ca987d46SWarner Losh.endif
218ca987d46SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
219e9b148a3SSimon J. Gerraty_ILINKS+=include/x86
220ca987d46SWarner Losh.endif
221e9b148a3SSimon J. GerratyCFLAGS+= -Iinclude
222e9b148a3SSimon J. GerratyCLEANDIRS+= include
223ca987d46SWarner Losh
224ca987d46SWarner Loshbeforedepend: ${_ILINKS}
225ca987d46SWarner Loshbeforebuild: ${_ILINKS}
226ca987d46SWarner Losh
227ca987d46SWarner Losh# Ensure that the links exist without depending on it when it exists which
228ca987d46SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes.
229ca987d46SWarner Losh.for _link in ${_ILINKS}
230ca987d46SWarner Losh.if !exists(${.OBJDIR}/${_link})
231ca987d46SWarner Losh${OBJS}:       ${_link}
232a0139c46SWarner Losh.endif # _link exists
233ca987d46SWarner Losh.endfor
234ca987d46SWarner Losh
235ca987d46SWarner Losh.NOPATH: ${_ILINKS}
236ca987d46SWarner Losh
237e9b148a3SSimon J. Gerraty${_ILINKS}: .NOMETA
238e9b148a3SSimon J. Gerraty	@case ${.TARGET:T} in \
239ca987d46SWarner Losh	machine) \
240ca987d46SWarner Losh		if [ ${DO32:U0} -eq 0 ]; then \
241ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE}/include ; \
242ca987d46SWarner Losh		else \
243ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE:C/amd64/i386/}/include ; \
244ca987d46SWarner Losh		fi ;; \
245ca987d46SWarner Losh	*) \
246ca987d46SWarner Losh		path=${SYSDIR}/${.TARGET:T}/include ;; \
247ca987d46SWarner Losh	esac ; \
248e9b148a3SSimon J. Gerraty	case ${.TARGET} in \
249e9b148a3SSimon J. Gerraty	*/*) mkdir -p ${.TARGET:H};; \
250e9b148a3SSimon J. Gerraty	esac ; \
251ca987d46SWarner Losh	path=`(cd $$path && /bin/pwd)` ; \
252e9b148a3SSimon J. Gerraty	${ECHO} ${.TARGET} "->" $$path ; \
253d8e1e85cSAlex Richardson	ln -fns $$path ${.TARGET}
254a0139c46SWarner Losh.endif # !NO_OBJ
255ca987d46SWarner Losh.endif # __BOOT_DEFS_MK__
256