]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - stand/defs.mk
MFC r348381: Unexpand be32dec().
[FreeBSD/FreeBSD.git] / stand / defs.mk
1 # $FreeBSD$
2
3 .if !defined(__BOOT_DEFS_MK__)
4 __BOOT_DEFS_MK__=${MFILE}
5
6 # We need to define all the MK_ options before including src.opts.mk
7 # because it includes bsd.own.mk which needs the right MK_ values,
8 # espeically MK_CTF.
9
10 MK_CTF=         no
11 MK_SSP=         no
12 MK_PROFILE=     no
13 MAN=
14 .if !defined(PIC)
15 NO_PIC=
16 INTERNALLIB=
17 .endif
18
19 .include <src.opts.mk>
20
21 WARNS?=         1
22
23 BOOTSRC=        ${SRCTOP}/stand
24 EFISRC=         ${BOOTSRC}/efi
25 EFIINC=         ${EFISRC}/include
26 EFIINCMD=       ${EFIINC}/${MACHINE}
27 FDTSRC=         ${BOOTSRC}/fdt
28 FICLSRC=        ${BOOTSRC}/ficl
29 LDRSRC=         ${BOOTSRC}/common
30 LIBLUASRC=      ${BOOTSRC}/liblua
31 LUASRC=         ${SRCTOP}/contrib/lua/src
32 SASRC=          ${BOOTSRC}/libsa
33 SYSDIR=         ${SRCTOP}/sys
34 UBOOTSRC=       ${BOOTSRC}/uboot
35 ZFSSRC=         ${SASRC}/zfs
36 LIBCSRC=        ${SRCTOP}/lib/libc
37
38 BOOTOBJ=        ${OBJTOP}/stand
39
40 # BINDIR is where we install
41 BINDIR?=        /boot
42
43 LIBSA=          ${BOOTOBJ}/libsa/libsa.a
44 .if ${MACHINE} == "i386"
45 LIBSA32=        ${LIBSA}
46 .else
47 LIBSA32=        ${BOOTOBJ}/libsa32/libsa32.a
48 .endif
49
50 # Standard options:
51 CFLAGS+=        -nostdinc
52 .if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
53 CFLAGS+=        -I${BOOTOBJ}/libsa32
54 .else
55 CFLAGS+=        -I${BOOTOBJ}/libsa
56 .endif
57 CFLAGS+=        -I${SASRC} -D_STANDALONE
58 CFLAGS+=        -I${SYSDIR}
59 # Spike the floating point interfaces
60 CFLAGS+=        -Ddouble=jagged-little-pill -Dfloat=floaty-mcfloatface
61 .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
62 # Slim down the image. This saves about 15% in size with clang 6 on x86
63 # Our most constrained /boot/loader env is BIOS booting on x86, where
64 # our text + data + BTX have to fit into 640k below the ISA hole.
65 # Experience has shown that problems arise between ~520k to ~530k.
66 CFLAGS.clang+=  -Oz
67 CFLAGS.gcc+=    -Os
68 .endif
69
70 # GELI Support, with backward compat hooks (mostly)
71 .if defined(LOADER_NO_GELI_SUPPORT)
72 MK_LOADER_GELI=no
73 .warning "Please move from LOADER_NO_GELI_SUPPORT to WITHOUT_LOADER_GELI"
74 .endif
75 .if defined(LOADER_GELI_SUPPORT)
76 MK_LOADER_GELI=yes
77 .warning "Please move from LOADER_GELI_SUPPORT to WITH_LOADER_GELI"
78 .endif
79 .if ${MK_LOADER_GELI} == "yes"
80 CFLAGS+=        -DLOADER_GELI_SUPPORT
81 CFLAGS+=        -I${SASRC}/geli
82 .endif # MK_LOADER_GELI
83
84 # These should be confined to loader.mk, but can't because uboot/lib
85 # also uses it. It's part of loader, but isn't a loader so we can't
86 # just include loader.mk
87 .if ${LOADER_DISK_SUPPORT:Uyes} == "yes"
88 CFLAGS+= -DLOADER_DISK_SUPPORT
89 .endif
90
91 # Machine specific flags for all builds here
92
93 # All PowerPC builds are 32 bit. We have no 64-bit loaders on powerpc
94 # or powerpc64.
95 .if ${MACHINE_ARCH} == "powerpc64"
96 CFLAGS+=        -m32 -mcpu=powerpc
97 .endif
98
99 # For amd64, there's a bit of mixed bag. Some of the tree (i386, lib*32) is
100 # build 32-bit and some 64-bit (lib*, efi). Centralize all the 32-bit magic here
101 # and activate it when DO32 is explicitly defined to be 1.
102 .if ${MACHINE_ARCH} == "amd64" && ${DO32:U0} == 1
103 CFLAGS+=        -m32
104 # LD_FLAGS is passed directly to ${LD}, not via ${CC}:
105 LD_FLAGS+=      -m elf_i386_fbsd
106 AFLAGS+=        --32
107 .endif
108
109 SSP_CFLAGS=
110
111 # Add in the no float / no SIMD stuff and announce we're freestanding
112 # aarch64 and riscv don't have -msoft-float, but all others do. riscv
113 # currently has no /boot/loader, but may soon.
114 CFLAGS+=        -ffreestanding ${CFLAGS_NO_SIMD}
115 .if ${MACHINE_CPUARCH} == "aarch64"
116 CFLAGS+=        -mgeneral-regs-only -fPIC
117 .elif ${MACHINE_CPUARCH} == "riscv"
118 CFLAGS+=        -march=rv64imac -mabi=lp64
119 .else
120 CFLAGS+=        -msoft-float
121 .endif
122
123 # -msoft-float seems to be insufficient for powerpcspe
124 .if ${MACHINE_ARCH} == "powerpcspe"
125 CFLAGS+=        -mno-spe
126 .endif
127
128 .if ${MACHINE_CPUARCH} == "i386" || (${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 1)
129 CFLAGS+=        -march=i386
130 CFLAGS.gcc+=    -mpreferred-stack-boundary=2
131 .endif
132 .if ${MACHINE_CPUARCH} == "amd64" && ${DO32:U0} == 0
133 CFLAGS+=        -fPIC -mno-red-zone
134 .endif
135
136 .if ${MACHINE_CPUARCH} == "arm"
137 # Do not generate movt/movw, because the relocation fixup for them does not
138 # translate to the -Bsymbolic -pie format required by self_reloc() in loader(8).
139 # Also, the fpu is not available in a standalone environment.
140 .if ${COMPILER_VERSION} < 30800
141 CFLAGS.clang+=  -mllvm -arm-use-movt=0
142 .else
143 CFLAGS.clang+=  -mno-movt
144 .endif
145 CFLAGS.clang+=  -mfpu=none
146 CFLAGS+=        -fPIC
147 .endif
148
149 # The boot loader build uses dd status=none, where possible, for reproducible
150 # build output (since performance varies from run to run). Trouble is that
151 # option was recently (10.3) added to FreeBSD and is non-standard. Only use it
152 # when this test succeeds rather than require dd to be a bootstrap tool.
153 DD_NOSTATUS!=(dd status=none count=0 2> /dev/null && echo status=none) || true
154 DD=dd ${DD_NOSTATUS}
155
156 .if ${MACHINE_CPUARCH} == "mips"
157 CFLAGS+=        -G0 -fno-pic -mno-abicalls
158 .endif
159
160 .if ${MK_LOADER_FORCE_LE} != "no"
161 .if ${MACHINE_ARCH} == "powerpc64"
162 CFLAGS+=        -mlittle-endian
163 .endif
164 .endif
165
166 #
167 # Have a sensible default
168 #
169 .if ${MK_LOADER_LUA} == "yes"
170 LOADER_DEFAULT_INTERP?=lua
171 .elif ${MK_FORTH} == "yes"
172 LOADER_DEFAULT_INTERP?=4th
173 .else
174 LOADER_DEFAULT_INTERP?=simp
175 .endif
176 LOADER_INTERP?=${LOADER_DEFAULT_INTERP}
177
178 # Make sure we use the machine link we're about to create
179 CFLAGS+=-I.
180
181 all: ${PROG}
182
183 .if !defined(NO_OBJ)
184 _ILINKS=machine
185 .if ${MACHINE} != ${MACHINE_CPUARCH} && ${MACHINE} != "arm64"
186 _ILINKS+=${MACHINE_CPUARCH}
187 .endif
188 .if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
189 _ILINKS+=x86
190 .endif
191 CLEANFILES+=${_ILINKS}
192
193 beforedepend: ${_ILINKS}
194 beforebuild: ${_ILINKS}
195
196 # Ensure that the links exist without depending on it when it exists which
197 # causes all the modules to be rebuilt when the directory pointed to changes.
198 .for _link in ${_ILINKS}
199 .if !exists(${.OBJDIR}/${_link})
200 ${OBJS}:       ${_link}
201 .endif # _link exists
202 .endfor
203
204 .NOPATH: ${_ILINKS}
205
206 ${_ILINKS}:
207         @case ${.TARGET} in \
208         machine) \
209                 if [ ${DO32:U0} -eq 0 ]; then \
210                         path=${SYSDIR}/${MACHINE}/include ; \
211                 else \
212                         path=${SYSDIR}/${MACHINE:C/amd64/i386/}/include ; \
213                 fi ;; \
214         *) \
215                 path=${SYSDIR}/${.TARGET:T}/include ;; \
216         esac ; \
217         path=`(cd $$path && /bin/pwd)` ; \
218         ${ECHO} ${.TARGET:T} "->" $$path ; \
219         ln -fhs $$path ${.TARGET:T}
220 .endif # !NO_OBJ
221 .endif # __BOOT_DEFS_MK__