blob: cc940712a8a4d632ca92bfccfd31f9b1d9d6cdff [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
wdenk2262cfe2002-11-18 00:14:45 +00002#
3# (C) Copyright 2000-2002
4# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenk2262cfe2002-11-18 00:14:45 +00005
Wolfgang Denk8ae86b72011-02-04 14:25:17 +01006CONFIG_STANDALONE_LOAD_ADDR ?= 0x40000
Mike Frysinger262ae0a2009-09-03 23:12:47 -04007
Graeme Russ5c161652010-10-07 20:03:23 +11008PLATFORM_CPPFLAGS += -fomit-frame-pointer
Masahiro Yamadaf6941832014-02-26 14:51:01 +09009PF_CPPFLAGS_X86 := $(call cc-option, -fno-toplevel-reorder, \
Bin Meng9a95f512017-07-27 06:12:34 -070010 $(call cc-option, -fno-unit-at-a-time))
Ben Stoltz3f1c0462015-08-04 12:33:42 -060011
Wolfgang Denkcca4e4a2011-11-01 20:54:02 +000012PLATFORM_CPPFLAGS += $(PF_CPPFLAGS_X86)
Graeme Russa85f53c2011-02-12 15:11:21 +110013PLATFORM_CPPFLAGS += -fno-dwarf2-cfi-asm
Simon Glass3a037032017-01-16 07:04:26 -070014
15ifdef CONFIG_SPL_BUILD
16IS_32BIT := y
17else
18ifndef CONFIG_X86_64
19IS_32BIT := y
20endif
21endif
22
23ifeq ($(IS_32BIT),y)
Vasili Galkadbb72342014-06-10 16:14:56 +030024PLATFORM_CPPFLAGS += -march=i386 -m32
Simon Glass3a037032017-01-16 07:04:26 -070025else
Bin Menge719b6b2017-07-27 06:12:35 -070026PLATFORM_CPPFLAGS += $(if $(CONFIG_SPL_BUILD),,-fpic) -fno-common -m64
Simon Glass3a037032017-01-16 07:04:26 -070027endif
Graeme Russd664adb2010-10-07 20:03:20 +110028
Alexander Graf1acbd0e2018-08-20 14:20:51 +020029PLATFORM_RELFLAGS += -fdata-sections -ffunction-sections -fvisibility=hidden
Graeme Russa85f53c2011-02-12 15:11:21 +110030
Simon Glass3a037032017-01-16 07:04:26 -070031PLATFORM_LDFLAGS += -Bsymbolic -Bsymbolic-functions
32PLATFORM_LDFLAGS += -m $(if $(IS_32BIT),elf_i386,elf_x86_64)
Graeme Russa85f53c2011-02-12 15:11:21 +110033
Simon Glass476476e2015-08-04 12:33:52 -060034# This is used in the top-level Makefile which does not include
35# PLATFORM_LDFLAGS
36LDFLAGS_EFI_PAYLOAD := -Bsymbolic -Bsymbolic-functions -shared --no-undefined
37
Ben Stoltz3f1c0462015-08-04 12:33:42 -060038OBJCOPYFLAGS_EFI := -j .text -j .sdata -j .data -j .dynamic -j .dynsym \
39 -j .rel -j .rela -j .reloc
40
Simon Glass3a037032017-01-16 07:04:26 -070041ifeq ($(IS_32BIT),y)
Ben Stoltz3f1c0462015-08-04 12:33:42 -060042CFLAGS_NON_EFI := -mregparm=3
Simon Glass3a037032017-01-16 07:04:26 -070043endif
Ben Stoltz3f1c0462015-08-04 12:33:42 -060044CFLAGS_EFI := -fpic -fshort-wchar
45
Simon Glass96a8d402015-08-04 12:33:56 -060046ifeq ($(CONFIG_EFI_STUB_64BIT),)
47CFLAGS_EFI += $(call cc-option, -mno-red-zone)
Ben Stoltz3f1c0462015-08-04 12:33:42 -060048EFIARCH = ia32
Simon Glass476476e2015-08-04 12:33:52 -060049EFIPAYLOAD_BFDTARGET = elf32-i386
Simon Glass96a8d402015-08-04 12:33:56 -060050else
51EFIARCH = x86_64
52EFIPAYLOAD_BFDTARGET = elf64-x86-64
53endif
Simon Glass476476e2015-08-04 12:33:52 -060054
55EFIPAYLOAD_BFDARCH = i386
Ben Stoltz3f1c0462015-08-04 12:33:42 -060056
Simon Glassd36badf2016-11-07 08:47:13 -070057LDSCRIPT_EFI := $(srctree)/arch/x86/lib/elf_$(EFIARCH)_efi.lds
Simon Glass2dcd4e92016-11-07 08:47:14 -070058EFISTUB := crt0_$(EFIARCH)_efi.o reloc_$(EFIARCH)_efi.o
Ben Stoltz3f1c0462015-08-04 12:33:42 -060059OBJCOPYFLAGS_EFI += --target=efi-app-$(EFIARCH)
60
Simon Glass96a8d402015-08-04 12:33:56 -060061CPPFLAGS_REMOVE_crt0-efi-$(EFIARCH).o += $(CFLAGS_NON_EFI)
62CPPFLAGS_crt0-efi-$(EFIARCH).o += $(CFLAGS_EFI)
63
Ben Stoltz3f1c0462015-08-04 12:33:42 -060064ifeq ($(CONFIG_EFI_APP),y)
65
66PLATFORM_CPPFLAGS += $(CFLAGS_EFI)
67LDFLAGS_FINAL += -znocombreloc -shared
68LDSCRIPT := $(LDSCRIPT_EFI)
69
70else
71
72PLATFORM_CPPFLAGS += $(CFLAGS_NON_EFI)
73PLATFORM_LDFLAGS += --emit-relocs
Simon Glass3a037032017-01-16 07:04:26 -070074LDFLAGS_FINAL += --gc-sections $(if $(CONFIG_SPL_BUILD),,-pie)
Ben Stoltz3f1c0462015-08-04 12:33:42 -060075
76endif
Simon Glass5bd828b2016-11-07 08:47:15 -070077
Simon Glass3a037032017-01-16 07:04:26 -070078ifdef CONFIG_X86_64
79ifndef CONFIG_SPL_BUILD
80PLATFORM_CPPFLAGS += -D__x86_64__
81else
82PLATFORM_CPPFLAGS += -D__I386__
83endif
84else
85PLATFORM_CPPFLAGS += -D__I386__
86endif
87
Heinrich Schuchardt508d8562018-05-18 19:12:19 +020088ifdef CONFIG_EFI_STUB
Simon Glass5bd828b2016-11-07 08:47:15 -070089
Heinrich Schuchardt508d8562018-05-18 19:12:19 +020090ifdef CONFIG_EFI_STUB_64BIT
Simon Glass5bd828b2016-11-07 08:47:15 -070091EFI_LDS := elf_x86_64_efi.lds
92EFI_CRT0 := crt0_x86_64_efi.o
93EFI_RELOC := reloc_x86_64_efi.o
Simon Glass5bd828b2016-11-07 08:47:15 -070094else
95EFI_LDS := elf_ia32_efi.lds
96EFI_CRT0 := crt0_ia32_efi.o
97EFI_RELOC := reloc_ia32_efi.o
Heinrich Schuchardtf4cf1532018-04-06 15:36:31 +020098endif
99
Heinrich Schuchardt508d8562018-05-18 19:12:19 +0200100else
101
102ifdef CONFIG_X86_64
103EFI_LDS := elf_x86_64_efi.lds
104EFI_CRT0 := crt0_x86_64_efi.o
105EFI_RELOC := reloc_x86_64_efi.o
106else
107EFI_LDS := elf_ia32_efi.lds
108EFI_CRT0 := crt0_ia32_efi.o
109EFI_RELOC := reloc_ia32_efi.o
110endif
111
112endif
113
Heinrich Schuchardtf4cf1532018-04-06 15:36:31 +0200114ifdef CONFIG_X86_64
Simon Glass5bd828b2016-11-07 08:47:15 -0700115EFI_TARGET := --target=efi-app-x86_64
Heinrich Schuchardtf4cf1532018-04-06 15:36:31 +0200116else
117EFI_TARGET := --target=efi-app-ia32
Simon Glass5bd828b2016-11-07 08:47:15 -0700118endif