xref: /freebsd/stand/libsa/Makefile (revision b64c5a0ace59af62eff52bfe110a521dc73c937b)
1# Originally from	$NetBSD: Makefile,v 1.21 1997/10/26 22:08:38 lukem Exp $
2#
3# Notes:
4# - We don't use the libc strerror/sys_errlist because the string table is
5#   quite large.
6#
7
8.include <bsd.init.mk>
9
10LIBSA_CPUARCH?=${MACHINE_CPUARCH}
11
12LIB?=		sa
13
14# standalone components and stuff we have modified locally
15SRCS+=	gzguts.h zutil.h __main.c abort.c assert.c bcd.c environment.c \
16	features.c getopt.c gets.c globals.c \
17	hexdump.c nvstore.c pager.c panic.c printf.c strdup.c strerror.c \
18	random.c sbrk.c tslog.c twiddle.c zalloc.c zalloc_malloc.c
19
20# private (pruned) versions of libc string functions
21SRCS+=	strcasecmp.c
22
23.PATH: ${LIBCSRC}/net
24
25SRCS+= ntoh.c
26
27# string functions from libc
28.PATH: ${LIBCSRC}/string
29SRCS+=	bcmp.c bcopy.c bzero.c ffs.c fls.c \
30	memccpy.c memchr.c memcmp.c memcpy.c memmove.c memset.c \
31	strcat.c strchr.c strchrnul.c strcmp.c strcpy.c stpcpy.c stpncpy.c \
32	strcspn.c strlcat.c strlcpy.c strlen.c strncat.c strncmp.c strncpy.c \
33	strnlen.c strpbrk.c strrchr.c strsep.c strspn.c strstr.c strtok.c swab.c
34
35# stdlib functions from libc
36.PATH: ${LIBCSRC}/stdlib
37SRCS+=	abs.c strtol.c strtoll.c strtoul.c strtoull.c
38
39# common boot code
40.PATH:	${SYSDIR}/kern
41SRCS+=	subr_boot.c
42
43.if ${MACHINE_CPUARCH} == "arm"
44.PATH: ${LIBCSRC}/arm/gen
45
46# Do not generate movt/movw, because the relocation fixup for them does not
47# translate to the -Bsymbolic -pie format required by self_reloc() in loader(8).
48# Also, the fpu is not available in a standalone environment.
49CFLAGS.clang+=	-mno-movt
50CFLAGS.clang+=	-mfpu=none
51
52.PATH: ${SRCTOP}/contrib/llvm-project/compiler-rt/lib/builtins/arm/
53SRCS+=	aeabi_idivmod.S aeabi_ldivmod.S aeabi_uidivmod.S aeabi_uldivmod.S
54SRCS+=	aeabi_memcmp.S aeabi_memcpy.S aeabi_memmove.S aeabi_memset.S
55.endif
56
57.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "riscv"
58.PATH: ${LIBCSRC}/${MACHINE_CPUARCH}/gen
59.endif
60
61# Compiler support functions
62.PATH: ${SRCTOP}/contrib/llvm-project/compiler-rt/lib/builtins/
63# __clzsi2 and ctzsi2 for various builtin functions
64SRCS+=	clzsi2.c ctzsi2.c
65# Divide and modulus functions called by the compiler
66SRCS+=	divmoddi4.c  divmodsi4.c  divdi3.c  divsi3.c  moddi3.c  modsi3.c
67SRCS+=	udivmoddi4.c udivmodsi4.c udivdi3.c udivsi3.c umoddi3.c umodsi3.c
68SRCS+=	ashldi3.c ashrdi3.c lshrdi3.c
69
70.if ${MACHINE_CPUARCH:Namd64:Ni386} == ""
71.PATH: ${SASRC}/x86
72SRCS+= hypervisor.c
73.endif
74
75.if ${MACHINE_CPUARCH} == "powerpc"
76SRCS+=	syncicache.c
77.endif
78
79# uuid functions from libc
80.PATH: ${LIBCSRC}/uuid
81SRCS+= uuid_create_nil.c uuid_equal.c uuid_from_string.c uuid_is_nil.c uuid_to_string.c
82
83# _setjmp/_longjmp
84.PATH: ${SASRC}/${LIBSA_CPUARCH}
85SRCS+=	_setjmp.S
86
87# decompression functionality from libbz2
88# NOTE: to actually test this functionality after libbz2 upgrade compile
89# loader(8) with LOADER_BZIP2_SUPPORT defined
90.PATH: ${SRCTOP}/contrib/bzip2
91.for i in bzlib.c crctable.c decompress.c huffman.c randtable.c
92CFLAGS.${i}+= -DBZ_NO_STDIO -DBZ_NO_COMPRESS
93SRCS+=${i}
94.endfor
95
96# decompression functionality from zlib
97# https://github.com/madler/zlib/issues/633 documents why we suppress deprecated
98# prototype warnings.
99.PATH: ${SRCTOP}/sys/contrib/zlib
100ZLIB_CFLAGS=-DHAVE_MEMCPY -I${SRCTOP}/sys/contrib/zlib ${NO_WDEPRECATED_NON_PROTOTYPE}
101.for i in adler32.c crc32.c infback.c inffast.c inflate.c inftrees.c zutil.c
102CFLAGS.${i}+=${ZLIB_CFLAGS}
103SRCS+=	${i}
104.endfor
105
106# lz4 decompression functionality
107.PATH: ${SRCTOP}/sys/cddl/contrib/opensolaris/common/lz4
108SRCS+=	lz4.c
109CFLAGS.lz4.c+= -I${SRCTOP}/sys/cddl/contrib/opensolaris/common/lz4
110
111# io routines
112SRCS+=	closeall.c dev.c ioctl.c nullfs.c stat.c mount.c \
113	fstat.c close.c lseek.c open.c read.c write.c readdir.c preload.c
114
115# SMBios routines
116SRCS+=	smbios.c
117.if !defined(BOOT_HIDE_SERIAL_NUMBERS)
118# Export serial numbers, UUID, and asset tag from loader.
119CFLAGS.smbios.c+= -DSMBIOS_SERIAL_NUMBERS
120.if defined(BOOT_LITTLE_ENDIAN_UUID)
121# Use little-endian UUID format as defined in SMBIOS 2.6.
122CFLAGS.smbios.c+= -DSMBIOS_LITTLE_ENDIAN_UUID
123.elif defined(BOOT_NETWORK_ENDIAN_UUID)
124# Use network-endian UUID format for backward compatibility.
125CFLAGS.smbios.c+= -DSMBIOS_NETWORK_ENDIAN_UUID
126.endif
127.endif
128
129# network routines
130SRCS+=	arp.c ether.c ip.c inet_ntoa.c in_cksum.c net.c udp.c netif.c rpc.c
131
132# network info services:
133SRCS+=	bootp.c rarp.c bootparam.c
134
135# boot filesystems
136SRCS+=	ufs.c nfs.c cd9660.c tftp.c gzipfs.c bzipfs.c
137SRCS+=	dosfs.c ext2fs.c
138SRCS+=	splitfs.c
139SRCS+=	pkgfs.c
140
141# Time support
142SRCS+=	time.c
143
144# kernel ufs support
145.PATH: ${SRCTOP}/sys/ufs/ffs
146SRCS+=ffs_subr.c ffs_tables.c
147
148#
149# i386 has a constrained space for its /boot/loader, so compile out the
150# extensive messages diagnosing bad superblocks. i386 doesn't support UEFI
151# booting, so doing it always makes sense natively there. When we compile
152# for 32-bit on amd64, LIBSA_CPUARCH is also i386 and we use libsa32 only
153# for the BIOS /boot/loader which has the same constraints.
154#
155.if ${LIBSA_CPUARCH} == "i386"
156CFLAGS.ffs_subr.c+= -DSTANDALONE_SMALL
157.endif
158
159CFLAGS.gzipfs.c+= ${ZLIB_CFLAGS}
160CFLAGS.pkgfs.c+= ${ZLIB_CFLAGS}
161CFLAGS.bzipfs.c+= -I${SRCTOP}/contrib/bzip2  -DBZ_NO_STDIO -DBZ_NO_COMPRESS
162
163# explicit_bzero and calculate_crc32c
164.PATH: ${SYSDIR}/libkern
165SRCS+=  explicit_bzero.c crc32_libkern.c
166
167# Bits from GELI reused for some random seeding cases
168.PATH: ${SYSDIR}/geom/eli
169SRCS+=	g_eli_hmac.c pkcs5v2.c
170
171# Maybe GELI
172.if ${MK_LOADER_GELI} == "yes"
173.include "${SASRC}/geli/Makefile.inc"
174.endif
175
176.if ${MK_LOADER_VERIEXEC} == "yes" && ${MK_BEARSSL} == "yes"
177# XXX Note that these pollutes CFLAGS in a way that's not easy to fix
178.include "${SRCTOP}/lib/libbearssl/Makefile.libsa.inc"
179.include "${SRCTOP}/lib/libsecureboot/Makefile.libsa.inc"
180.endif
181
182# Maybe ZFS
183.if ${MK_LOADER_ZFS} == "yes"
184.include "${SASRC}/zfs/Makefile.inc"
185.endif
186
187# Crypto hashing functions
188# sha256 and sha512 from sys/crypto
189.PATH: ${SYSDIR}/crypto/sha2
190SRCS+=		sha256c.c sha512c.c
191
192# md5 from the kernel
193.PATH: ${SYSDIR}/kern
194SRCS+=		md5c.c
195
196.if ${DO32:U0} == 0
197MAN=libsa.3
198.endif
199
200# Create a subset of includes that are safe, as well as adjusting those that aren't
201# The lists may drive people nuts, but they are explicitly opt-in
202FAKE_DIRS=xlocale arpa ssp
203SAFE_INCS=a.out.h assert.h elf.h limits.h nlist.h setjmp.h stddef.h stdbool.h string.h strings.h time.h uuid.h
204STAND_H_INC=ctype.h fcntl.h signal.h stdio.h stdlib.h unistd.h
205OTHER_INC=stdarg.h errno.h stdint.h
206
207beforedepend:
208	mkdir -p ${FAKE_DIRS}; \
209	for i in ${SAFE_INCS}; do \
210		ln -sf ${SRCTOP}/include/$$i $$i; \
211	done; \
212	ln -sf ${SYSDIR}/${MACHINE}/include/stdarg.h stdarg.h; \
213	ln -sf ${SYSDIR}/sys/errno.h errno.h; \
214	ln -sf ${SYSDIR}/sys/stdint.h stdint.h; \
215	ln -sf ${SRCTOP}/include/arpa/inet.h arpa/inet.h; \
216	ln -sf ${SRCTOP}/include/arpa/tftp.h arpa/tftp.h; \
217	ln -sf ${SRCTOP}/include/ssp/ssp.h ssp/ssp.h; \
218	for i in _time.h _strings.h _string.h; do \
219		[ -f xlocale/$$i ] || :> xlocale/$$i; \
220	done; \
221	for i in ${STAND_H_INC}; do \
222		ln -sf ${SASRC}/stand.h $$i; \
223	done
224CLEANDIRS+=${FAKE_DIRS}
225CLEANFILES+= ${SAFE_INCS} ${STAND_H_INC} ${OTHER_INC}
226
227.include <bsd.lib.mk>
228