xref: /freebsd-14-stable/sys/conf/Makefile.arm64 (revision bec5167645b5d157a1c980099162362f115ccbfe)
1# Makefile.arm64 -- with config changes.
2# Copyright 1990 W. Jolitz
3#	from: @(#)Makefile.i386	7.1 5/10/91
4#	from FreeBSD: src/sys/conf/Makefile.i386,v 1.255 2002/02/20 23:35:49
5#
6# Makefile for FreeBSD
7#
8# This makefile is constructed from a machine description:
9#	config machineid
10# Most changes should be made in the machine description
11#	/sys/arm64/conf/``machineid''
12# after which you should do
13#	 config machineid
14# Generic makefile changes should be made in
15#	/sys/conf/Makefile.arm64
16# after which config should be rerun for all machines.
17#
18
19# Which version of config(8) is required.
20%VERSREQ=	600012
21
22.if !defined(S)
23S=	../../..
24.endif
25.include "$S/conf/kern.pre.mk"
26
27INCLUDES+= -I$S/contrib/libfdt -I$S/contrib/device-tree/include
28
29LINUX_DTS_VERSION!=	awk '/freebsd,dts-version/ { sub(/;$$/,"", $$NF); print $$NF }' $S/dts/freebsd-compatible.dts
30CFLAGS += -DLINUX_DTS_VERSION=\"${LINUX_DTS_VERSION}\"
31
32PERTHREAD_SSP_ENABLED!=	grep PERTHREAD_SSP opt_global.h || true ; echo
33.if !empty(PERTHREAD_SSP_ENABLED)
34. if (${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} >= 130000) || \
35  ${COMPILER_TYPE} == "gcc"
36ARM64_SSP_CFLAGS = -mstack-protector-guard=sysreg
37ARM64_SSP_CFLAGS += -mstack-protector-guard-reg=sp_el0
38ARM64_SSP_CFLAGS += -mstack-protector-guard-offset=0
39. else
40ARM64_SSP_CFLAGS += -DPERTHREAD_SSP_WARNING
41.  warning "Compiler is too old to support PERTHREAD_SSP"
42. endif
43CFLAGS += ${ARM64_SSP_CFLAGS}
44ARCH_FLAGS += ${ARM64_SSP_CFLAGS}
45.endif
46
47# Use a custom SYSTEM_LD command to generate the elf kernel, so we can
48# set the text segment start address, and also strip the "arm mapping
49# symbols" which have names like $a.0 and $d.2; see the document
50# "ELF for the ARM architecture" for more info on the mapping symbols.
51SYSTEM_LD= \
52	${SYSTEM_LD_BASECMD} \
53	    --defsym='text_start=kernbase + SIZEOF_HEADERS' \
54	    -o ${.TARGET} ${SYSTEM_OBJS} vers.o; \
55	$(OBJCOPY) \
56	    --wildcard \
57	    --strip-symbol='$$[adtx]*' \
58	    ${.TARGET}
59
60# Generate the .bin (booti images) kernel as an extra build output.
61# The targets and rules to generate these appear near the end of the file.
62KERNEL_EXTRA+= ${KERNEL_KO}.bin
63KERNEL_EXTRA_INSTALL+= ${KERNEL_KO}.bin
64
65.if !empty(DDB_ENABLED) || !empty(DTRACE_ENABLED) || !empty(HWPMC_ENABLED)
66CFLAGS += -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer
67.endif
68
69%BEFORE_DEPEND
70
71%OBJS
72
73%FILES.c
74
75%FILES.s
76
77%FILES.m
78
79%CLEAN
80CLEAN+=	${KERNEL_KO}.bin
81
82%RULES
83
84.include "$S/conf/kern.post.mk"
85
86# Create a kernel.bin file...
87# Copy the kernel to u-boot's booti image format (the elf headers are
88# stripped and a custom binary head blob is prepended), saving the
89# output in a temp file.  We also strip arm "marker" symbols which are
90# used only by elf toolchains.  Read the symbols from kernel.full and pass
91# them to arm_kernel_boothdr.awk, which generates a binary header blob
92# that goes on the front of the stripped kernel.  Cat the header blob
93# and the temp file together to make the kernel.bin file.
94${KERNEL_KO}.bin: ${FULLKERNEL}
95	@${OBJCOPY} --wildcard --strip-symbol='$$[adtx]*' \
96	    --output-target=binary ${FULLKERNEL} ${.TARGET}.temp
97	@{ ${NM} ${FULLKERNEL} | \
98	    LC_ALL=C \
99	    ${AWK} -f $S/tools/arm_kernel_boothdr.awk -v hdrtype=v8booti && \
100	    cat ${.TARGET}.temp; \
101	 } > ${.TARGET}
102	@rm ${.TARGET}.temp
103	@echo "created ${.TARGET} from ${.ALLSRC}"
104