xref: /freebsd/stand/defs.mk (revision b75abea4d0879c9e650928edf74ed90a0a790dfe)
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
188299b37fSWarner Losh
19991699dbSWarner Losh.include <src.opts.mk>
205e697f5fSMitchell Horne.include <bsd.linker.mk>
21991699dbSWarner Losh
22991699dbSWarner LoshWARNS?=		1
23991699dbSWarner Losh
24ca987d46SWarner LoshBOOTSRC=	${SRCTOP}/stand
25ca987d46SWarner LoshEFISRC=		${BOOTSRC}/efi
26ca987d46SWarner LoshEFIINC=		${EFISRC}/include
27ca987d46SWarner LoshEFIINCMD=	${EFIINC}/${MACHINE}
28ca987d46SWarner LoshFDTSRC=		${BOOTSRC}/fdt
29ca987d46SWarner LoshFICLSRC=	${BOOTSRC}/ficl
30ca987d46SWarner LoshLDRSRC=		${BOOTSRC}/common
317cafeaa1SWarner LoshLIBLUASRC=	${BOOTSRC}/liblua
32475008d6SBrandon BergrenLIBOFWSRC=	${BOOTSRC}/libofw
337cafeaa1SWarner LoshLUASRC=		${SRCTOP}/contrib/lua/src
34ca987d46SWarner LoshSASRC=		${BOOTSRC}/libsa
35ca987d46SWarner LoshSYSDIR=		${SRCTOP}/sys
36ca987d46SWarner LoshUBOOTSRC=	${BOOTSRC}/uboot
37b8902de1SWarner LoshZFSSRC=		${SASRC}/zfs
384c570f61SWarner LoshOZFS=		${SRCTOP}/sys/contrib/openzfs
394c570f61SWarner LoshZFSOSSRC=	${OZFS}/module/os/freebsd/
404c570f61SWarner LoshZFSOSINC=	${OZFS}/include/os/freebsd
4180335781SKyle EvansLIBCSRC=	${SRCTOP}/lib/libc
42ca987d46SWarner Losh
43ca987d46SWarner LoshBOOTOBJ=	${OBJTOP}/stand
44ca987d46SWarner Losh
45ca987d46SWarner Losh# BINDIR is where we install
46ca987d46SWarner LoshBINDIR?=	/boot
47ca987d46SWarner Losh
48ee74c236SKyle Evans# LUAPATH is where we search for and install lua scripts.
49ee74c236SKyle EvansLUAPATH?=	/boot/lua
50506f3640SKyle EvansFLUASRC?=	${SRCTOP}/libexec/flua
51ee74c236SKyle Evans
52ca987d46SWarner LoshLIBSA=		${BOOTOBJ}/libsa/libsa.a
53ca987d46SWarner Losh.if ${MACHINE} == "i386"
54ca987d46SWarner LoshLIBSA32=	${LIBSA}
55ca987d46SWarner Losh.else
56ca987d46SWarner LoshLIBSA32=	${BOOTOBJ}/libsa32/libsa32.a
57ca987d46SWarner Losh.endif
58ca987d46SWarner Losh
59ca987d46SWarner Losh# Standard options:
6005f37f4dSWarner LoshCFLAGS+=	-nostdinc
61f9553770SWarner Losh# Allow CFLAGS_EARLY.file/target so that code that needs specific stack
62f9553770SWarner Losh# of include paths can set them up before our include paths. Normally
63f9553770SWarner Losh# the only thing that should be there are -I directives, and as few of
64f9553770SWarner Losh# those as possible.
65f9553770SWarner LoshCFLAGS+=	${CFLAGS_EARLY} ${CFLAGS_EARLY.${.IMPSRC:T}} ${CFLAGS_EARLY.${.TARGET:T}}
6605f37f4dSWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
6705f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa32
6805f37f4dSWarner Losh.else
6905f37f4dSWarner LoshCFLAGS+=	-I${BOOTOBJ}/libsa
7005f37f4dSWarner Losh.endif
71b65d7763SWarner LoshCFLAGS+=	-I${SASRC} -D_STANDALONE
724f6b2874SWarner LoshCFLAGS+=	-I${SYSDIR}
73ef1fcaf0SWarner Losh# Spike the floating point interfaces
74e52cfb3eSWarner LoshCFLAGS+=	-Ddouble=jagged-little-pill -Dfloat=floaty-mcfloatface
750125fb63SWarner Losh.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
76f835d609SWarner Losh# Slim down the image. This saves about 15% in size with clang 6 on x86
77f835d609SWarner Losh# Our most constrained /boot/loader env is BIOS booting on x86, where
78f835d609SWarner Losh# our text + data + BTX have to fit into 640k below the ISA hole.
79f835d609SWarner Losh# Experience has shown that problems arise between ~520k to ~530k.
80f835d609SWarner LoshCFLAGS.clang+=	-Oz
81f835d609SWarner LoshCFLAGS.gcc+=	-Os
82094b4065SToomas SoomeCFLAGS+=	-ffunction-sections -fdata-sections
830125fb63SWarner Losh.endif
84ca987d46SWarner Losh
855ba722feSWarner Losh# GELI Support, with backward compat hooks (mostly)
86ca987d46SWarner Losh.if defined(LOADER_NO_GELI_SUPPORT)
87ca987d46SWarner LoshMK_LOADER_GELI=no
88ca987d46SWarner Losh.warning "Please move from LOADER_NO_GELI_SUPPORT to WITHOUT_LOADER_GELI"
89ca987d46SWarner Losh.endif
90ca987d46SWarner Losh.if defined(LOADER_GELI_SUPPORT)
91ca987d46SWarner LoshMK_LOADER_GELI=yes
92ca987d46SWarner Losh.warning "Please move from LOADER_GELI_SUPPORT to WITH_LOADER_GELI"
93ca987d46SWarner Losh.endif
94ca987d46SWarner Losh.if ${MK_LOADER_GELI} == "yes"
95ca987d46SWarner LoshCFLAGS+=	-DLOADER_GELI_SUPPORT
9662bd02ceSWarner LoshCFLAGS+=	-I${SASRC}/geli
974927bbceSWarner Losh.endif # MK_LOADER_GELI
98ca987d46SWarner Losh
998701bb8fSWarner Losh# These should be confined to loader.mk, but can't because uboot/lib
1008701bb8fSWarner Losh# also uses it. It's part of loader, but isn't a loader so we can't
1018701bb8fSWarner Losh# just include loader.mk
1028701bb8fSWarner Losh.if ${LOADER_DISK_SUPPORT:Uyes} == "yes"
1038701bb8fSWarner LoshCFLAGS+= -DLOADER_DISK_SUPPORT
1048701bb8fSWarner Losh.endif
1058701bb8fSWarner Losh
1064f6b2874SWarner Losh# Machine specific flags for all builds here
107ca987d46SWarner Losh
108*b75abea4SBrandon Bergren# Ensure PowerPC64 and PowerPC64LE boot loaders are compiled as 32 bit
109*b75abea4SBrandon Bergren# and in big endian.
110*b75abea4SBrandon Bergren.if ${MACHINE_ARCH:Mpowerpc64*} != ""
111*b75abea4SBrandon BergrenCFLAGS+=	-m32 -mcpu=powerpc -mbig-endian
112ca987d46SWarner Losh.endif
113ca987d46SWarner Losh
114ca987d46SWarner Losh# For amd64, there's a bit of mixed bag. Some of the tree (i386, lib*32) is
115ca987d46SWarner Losh# build 32-bit and some 64-bit (lib*, efi). Centralize all the 32-bit magic here
116ca987d46SWarner Losh# and activate it when DO32 is explicitly defined to be 1.
117ca987d46SWarner Losh.if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
118073193edSDimitry AndricCFLAGS+=	-m32
119ca987d46SWarner Losh# LD_FLAGS is passed directly to ${LD}, not via ${CC}:
120ca987d46SWarner LoshLD_FLAGS+=	-m elf_i386_fbsd
121ca987d46SWarner LoshAFLAGS+=	--32
122ca987d46SWarner Losh.endif
123ca987d46SWarner Losh
1244f6b2874SWarner LoshSSP_CFLAGS=
1254f6b2874SWarner Losh
1264f6b2874SWarner Losh# Add in the no float / no SIMD stuff and announce we're freestanding
1272192efc0SMitchell Horne# aarch64 and riscv don't have -msoft-float, but all others do.
1284f6b2874SWarner LoshCFLAGS+=	-ffreestanding ${CFLAGS_NO_SIMD}
1294f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "aarch64"
130a2e2311aSAndrew TurnerCFLAGS+=	-mgeneral-regs-only -ffixed-x18 -fPIC
131fcdb1f03SWarner Losh.elif ${MACHINE_CPUARCH} == "riscv"
1322192efc0SMitchell HorneCFLAGS+=	-march=rv64imac -mabi=lp64 -fPIC
1332192efc0SMitchell HorneCFLAGS.clang+=	-mcmodel=medium
1342192efc0SMitchell HorneCFLAGS.gcc+=	-mcmodel=medany
135fcdb1f03SWarner Losh.else
1364f6b2874SWarner LoshCFLAGS+=	-msoft-float
1374f6b2874SWarner Losh.endif
1384f6b2874SWarner Losh
13989797c88SJustin Hibbits# -msoft-float seems to be insufficient for powerpcspe
14089797c88SJustin Hibbits.if ${MACHINE_ARCH} == "powerpcspe"
14189797c88SJustin HibbitsCFLAGS+=	-mno-spe
14289797c88SJustin Hibbits.endif
14389797c88SJustin Hibbits
1444f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || (${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 1)
1454f6b2874SWarner LoshCFLAGS+=	-march=i386
1464f6b2874SWarner LoshCFLAGS.gcc+=	-mpreferred-stack-boundary=2
1474f6b2874SWarner Losh.endif
148fcdb1f03SWarner Losh.if ${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 0
149fcdb1f03SWarner LoshCFLAGS+=	-fPIC -mno-red-zone
150fcdb1f03SWarner Losh.endif
1514f6b2874SWarner Losh
1524f6b2874SWarner Losh.if ${MACHINE_CPUARCH} == "arm"
1534f6b2874SWarner Losh# Do not generate movt/movw, because the relocation fixup for them does not
1544f6b2874SWarner Losh# translate to the -Bsymbolic -pie format required by self_reloc() in loader(8).
1554f6b2874SWarner Losh# Also, the fpu is not available in a standalone environment.
1564f6b2874SWarner LoshCFLAGS.clang+=	-mno-movt
1574f6b2874SWarner LoshCFLAGS.clang+=  -mfpu=none
158fcdb1f03SWarner LoshCFLAGS+=	-fPIC
1594f6b2874SWarner Losh.endif
1604f6b2874SWarner Losh
1612192efc0SMitchell Horne# Some RISC-V linkers have support for relaxations, while some (lld) do not
1622192efc0SMitchell Horne# yet. If this is the case we inhibit the compiler from emitting relaxations.
1635e697f5fSMitchell Horne.if ${LINKER_FEATURES:Mriscv-relaxations} == ""
1642192efc0SMitchell HorneCFLAGS+=	-mno-relax
1652192efc0SMitchell Horne.endif
1662192efc0SMitchell Horne
1674f6b2874SWarner Losh# The boot loader build uses dd status=none, where possible, for reproducible
1684f6b2874SWarner Losh# build output (since performance varies from run to run). Trouble is that
1694f6b2874SWarner Losh# option was recently (10.3) added to FreeBSD and is non-standard. Only use it
1704f6b2874SWarner Losh# when this test succeeds rather than require dd to be a bootstrap tool.
1714f6b2874SWarner LoshDD_NOSTATUS!=(dd status=none count=0 2> /dev/null && echo status=none) || true
1724f6b2874SWarner LoshDD=dd ${DD_NOSTATUS}
1734f6b2874SWarner Losh
174fcdb1f03SWarner Losh.if ${MACHINE_CPUARCH} == "mips"
175fcdb1f03SWarner LoshCFLAGS+=	-G0 -fno-pic -mno-abicalls
176fcdb1f03SWarner Losh.endif
177fcdb1f03SWarner Losh
1789d45c24cSWarner Losh#
1799d45c24cSWarner Losh# Have a sensible default
1809d45c24cSWarner Losh#
181f9f8ac94SKyle Evans.if ${MK_LOADER_LUA} == "yes"
1829d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=lua
183f9f8ac94SKyle Evans.elif ${MK_FORTH} == "yes"
184f9f8ac94SKyle EvansLOADER_DEFAULT_INTERP?=4th
1859d45c24cSWarner Losh.else
1869d45c24cSWarner LoshLOADER_DEFAULT_INTERP?=simp
1879d45c24cSWarner Losh.endif
1889d45c24cSWarner LoshLOADER_INTERP?=${LOADER_DEFAULT_INTERP}
1899d45c24cSWarner Losh
190ca987d46SWarner Losh# Make sure we use the machine link we're about to create
191ca987d46SWarner LoshCFLAGS+=-I.
192ca987d46SWarner Losh
193a0139c46SWarner Loshall: ${PROG}
194a0139c46SWarner Losh
19556758831SToomas SoomeCLEANFILES+= teken_state.h
19656758831SToomas Soometeken.c: teken_state.h
19756758831SToomas Soome
19856758831SToomas Soometeken_state.h: ${SYSDIR}/teken/sequences
19956758831SToomas Soome	awk -f ${SYSDIR}/teken/gensequences \
20056758831SToomas Soome		${SYSDIR}/teken/sequences > teken_state.h
20156758831SToomas Soome
202a0139c46SWarner Losh.if !defined(NO_OBJ)
203e9b148a3SSimon J. Gerraty_ILINKS=include/machine
204ca987d46SWarner Losh.if ${MACHINE} != ${MACHINE_CPUARCH} && ${MACHINE} != "arm64"
205e9b148a3SSimon J. Gerraty_ILINKS+=include/${MACHINE_CPUARCH}
206ca987d46SWarner Losh.endif
207ca987d46SWarner Losh.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
208e9b148a3SSimon J. Gerraty_ILINKS+=include/x86
209ca987d46SWarner Losh.endif
210e9b148a3SSimon J. GerratyCFLAGS+= -Iinclude
211e9b148a3SSimon J. GerratyCLEANDIRS+= include
212ca987d46SWarner Losh
213ca987d46SWarner Loshbeforedepend: ${_ILINKS}
214ca987d46SWarner Loshbeforebuild: ${_ILINKS}
215ca987d46SWarner Losh
216ca987d46SWarner Losh# Ensure that the links exist without depending on it when it exists which
217ca987d46SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes.
218ca987d46SWarner Losh.for _link in ${_ILINKS}
219ca987d46SWarner Losh.if !exists(${.OBJDIR}/${_link})
220ca987d46SWarner Losh${OBJS}:       ${_link}
221a0139c46SWarner Losh.endif # _link exists
222ca987d46SWarner Losh.endfor
223ca987d46SWarner Losh
224ca987d46SWarner Losh.NOPATH: ${_ILINKS}
225ca987d46SWarner Losh
226e9b148a3SSimon J. Gerraty${_ILINKS}: .NOMETA
227e9b148a3SSimon J. Gerraty	@case ${.TARGET:T} in \
228ca987d46SWarner Losh	machine) \
229ca987d46SWarner Losh		if [ ${DO32:U0} -eq 0 ]; then \
230ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE}/include ; \
231ca987d46SWarner Losh		else \
232ca987d46SWarner Losh			path=${SYSDIR}/${MACHINE:C/amd64/i386/}/include ; \
233ca987d46SWarner Losh		fi ;; \
234ca987d46SWarner Losh	*) \
235ca987d46SWarner Losh		path=${SYSDIR}/${.TARGET:T}/include ;; \
236ca987d46SWarner Losh	esac ; \
237e9b148a3SSimon J. Gerraty	case ${.TARGET} in \
238e9b148a3SSimon J. Gerraty	*/*) mkdir -p ${.TARGET:H};; \
239e9b148a3SSimon J. Gerraty	esac ; \
240ca987d46SWarner Losh	path=`(cd $$path && /bin/pwd)` ; \
241e9b148a3SSimon J. Gerraty	${ECHO} ${.TARGET} "->" $$path ; \
242d8e1e85cSAlex Richardson	ln -fns $$path ${.TARGET}
243a0139c46SWarner Losh.endif # !NO_OBJ
244ca987d46SWarner Losh.endif # __BOOT_DEFS_MK__
245