blob: bea8567c9b45c0e3763d2dce6bbaf7947440304d [file] [log] [blame]
Simon Glass00ebd1f2017-11-12 21:52:07 -07001#
Simon Glassc9a0b272019-08-24 07:22:59 -06002# Builds test programs. This is launched from elf_test.BuildElfTestFiles()
Simon Glass00ebd1f2017-11-12 21:52:07 -07003#
4# Copyright (C) 2017 Google, Inc
5# Written by Simon Glass <sjg@chromium.org>
6#
7# SPDX-License-Identifier: GPL-2.0+
8#
9
Alper Nebi Yasak5ac76872020-09-06 14:46:04 +030010HOSTARCH := $(shell uname -m | sed -e s/i.86/x86/ )
11ifeq ($(findstring $(HOSTARCH),"x86" "x86_64"),)
12ifeq ($(findstring $(MAKECMDGOALS),"help" "clean"),)
13ifndef CROSS_COMPILE
14$(error Binman tests need to compile to x86, but the CPU arch of your \
15 machine is $(HOSTARCH). Set CROSS_COMPILE to a suitable cross compiler)
16endif
17endif
18endif
19
20CC = $(CROSS_COMPILE)gcc
21OBJCOPY = $(CROSS_COMPILE)objcopy
22
Simon Glass53e22bf2019-08-24 07:22:53 -060023VPATH := $(SRC)
Alper Nebi Yasakd8830cf2022-06-18 15:13:09 +030024CFLAGS := -march=i386 -m32 -nostdlib -I $(SRC)../../../include -I $(SRC) \
Simon Glass1542c8b2019-08-24 07:22:56 -060025 -Wl,--no-dynamic-linker
Simon Glass00ebd1f2017-11-12 21:52:07 -070026
Simon Glassf514d8f2019-08-24 07:22:54 -060027LDS_UCODE := -T $(SRC)u_boot_ucode_ptr.lds
Simon Glass1542c8b2019-08-24 07:22:56 -060028LDS_BINMAN := -T $(SRC)u_boot_binman_syms.lds
Simon Glass8dc60f92019-08-24 07:22:58 -060029LDS_BINMAN_BAD := -T $(SRC)u_boot_binman_syms_bad.lds
Simon Glass7c150132019-11-06 17:22:44 -070030LDS_BINMAN_X86 := -T $(SRC)u_boot_binman_syms_x86.lds
Simon Glass0427bed2021-11-03 21:09:18 -060031LDS_BINMAN_EMBED := -T $(SRC)u_boot_binman_embed.lds
Simon Glass56385c52022-02-08 11:49:59 -070032LDS_EFL_SECTIONS := -T $(SRC)elf_sections.lds
Simon Glass00ebd1f2017-11-12 21:52:07 -070033
Simon Glass5cfcf7e2017-11-13 18:54:58 -070034TARGETS = u_boot_ucode_ptr u_boot_no_ucode_ptr bss_data \
35 u_boot_binman_syms u_boot_binman_syms.bin u_boot_binman_syms_bad \
Simon Glass0427bed2021-11-03 21:09:18 -060036 u_boot_binman_syms_size u_boot_binman_syms_x86 embed_data \
Simon Glass56385c52022-02-08 11:49:59 -070037 u_boot_binman_embed u_boot_binman_embed_sm elf_sections
Simon Glass00ebd1f2017-11-12 21:52:07 -070038
39all: $(TARGETS)
40
41u_boot_no_ucode_ptr: CFLAGS += $(LDS_UCODE)
42u_boot_no_ucode_ptr: u_boot_no_ucode_ptr.c
43
44u_boot_ucode_ptr: CFLAGS += $(LDS_UCODE)
45u_boot_ucode_ptr: u_boot_ucode_ptr.c
46
Simon Glass53e22bf2019-08-24 07:22:53 -060047bss_data: CFLAGS += $(SRC)bss_data.lds
Simon Glass56509842017-11-12 21:52:25 -070048bss_data: bss_data.c
49
Simon Glass056f0ef2021-11-03 21:09:16 -060050embed_data: CFLAGS += $(SRC)embed_data.lds
51embed_data: embed_data.c
52
Simon Glass5cfcf7e2017-11-13 18:54:58 -070053u_boot_binman_syms.bin: u_boot_binman_syms
Alper Nebi Yasak5ac76872020-09-06 14:46:04 +030054 $(OBJCOPY) -O binary $< -R .note.gnu.build-id $@
Simon Glass5cfcf7e2017-11-13 18:54:58 -070055
56u_boot_binman_syms: CFLAGS += $(LDS_BINMAN)
57u_boot_binman_syms: u_boot_binman_syms.c
58
Simon Glass7c150132019-11-06 17:22:44 -070059u_boot_binman_syms_x86: CFLAGS += $(LDS_BINMAN_X86)
60u_boot_binman_syms_x86: u_boot_binman_syms_x86.c
61
Simon Glass5cfcf7e2017-11-13 18:54:58 -070062u_boot_binman_syms_bad: CFLAGS += $(LDS_BINMAN_BAD)
63u_boot_binman_syms_bad: u_boot_binman_syms_bad.c
64
65u_boot_binman_syms_size: CFLAGS += $(LDS_BINMAN)
66u_boot_binman_syms_size: u_boot_binman_syms_size.c
67
Simon Glass0427bed2021-11-03 21:09:18 -060068u_boot_binman_embed: CFLAGS += $(LDS_BINMAN_EMBED)
69u_boot_binman_embed: u_boot_binman_embed.c
70
71u_boot_binman_embed_sm: CFLAGS += $(LDS_BINMAN_EMBED)
72u_boot_binman_embed_sm: u_boot_binman_embed_sm.c
73
Simon Glass56385c52022-02-08 11:49:59 -070074elf_sections: CFLAGS += $(LDS_EFL_SECTIONS)
75elf_sections: elf_sections.c
76
Simon Glass00ebd1f2017-11-12 21:52:07 -070077clean:
78 rm -f $(TARGETS)
79
80help:
81 @echo "Makefile for binman test programs"
82 @echo
83 @echo "Intended for use on x86 hosts"
84 @echo
85 @echo "Targets:"
86 @echo
87 @echo -e "\thelp - Print help (this is it!)"
88 @echo -e "\tall - Builds test programs (default targget)"
89 @echo -e "\tclean - Delete output files"