blob: ab365fea06a6fccbcc950faef694e19a2ced68b5 [file] [log] [blame]
Patrick Georgi11f00792020-03-04 15:10:45 +01001## SPDX-License-Identifier: GPL-2.0-only
Patrick Georgi0588d192009-08-12 15:00:51 +00002
Patrick Georgi29eeece2018-10-31 14:24:47 +01003ifeq ($(CONFIG_POSTCAR_STAGE),y)
4$(eval $(call init_standard_toolchain,postcar))
5endif
6
Patrick Georgi70a6b4f2015-03-27 14:14:58 +01007################################################################################
8# i386 specific tools
9NVRAMTOOL:=$(objutil)/nvramtool/nvramtool
10
Patrick Georgi8463dd92010-09-30 16:55:02 +000011OPTION_TABLE_H:=
12ifeq ($(CONFIG_HAVE_OPTION_TABLE),y)
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010013
Angel Ponsf206cda2021-05-17 12:12:39 +020014CMOS_LAYOUT_FILE := $(top)/$(call strip_quotes,$(CONFIG_CMOS_LAYOUT_FILE))
15
Patrick Georgi5c0bca22011-01-30 16:31:15 +000016cbfs-files-y += cmos_layout.bin
17cmos_layout.bin-file = $(obj)/cmos_layout.bin
Martin Roth8ea06512016-09-19 13:58:01 -060018cmos_layout.bin-type = cmos_layout
Patrick Georgi24479372011-01-18 13:56:36 +000019
Angel Ponsf206cda2021-05-17 12:12:39 +020020$(obj)/cmos_layout.bin: $(NVRAMTOOL) $(CMOS_LAYOUT_FILE)
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010021 @printf " OPTION $(subst $(obj)/,,$(@))\n"
Angel Ponsf206cda2021-05-17 12:12:39 +020022 $(NVRAMTOOL) -y $(CMOS_LAYOUT_FILE) -L $@
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010023
Patrick Georgi8463dd92010-09-30 16:55:02 +000024OPTION_TABLE_H:=$(obj)/option_table.h
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010025
Angel Ponsf206cda2021-05-17 12:12:39 +020026$(OPTION_TABLE_H): $(NVRAMTOOL) $(CMOS_LAYOUT_FILE)
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010027 @printf " OPTION $(subst $(obj)/,,$(@))\n"
Angel Ponsf206cda2021-05-17 12:12:39 +020028 $(NVRAMTOOL) -y $(CMOS_LAYOUT_FILE) -H $@
Patrick Georgi70a6b4f2015-03-27 14:14:58 +010029endif # CONFIG_HAVE_OPTION_TABLE
Patrick Georgi0588d192009-08-12 15:00:51 +000030
Patrick Georgiff9d78c2011-01-30 16:37:39 +000031stripped_vgabios_id = $(call strip_quotes,$(CONFIG_VGA_BIOS_ID))
32cbfs-files-$(CONFIG_VGA_BIOS) += pci$(stripped_vgabios_id).rom
33pci$(stripped_vgabios_id).rom-file := $(call strip_quotes,$(CONFIG_VGA_BIOS_FILE))
34pci$(stripped_vgabios_id).rom-type := optionrom
35
Martin Roth4cc2cac2019-12-06 19:11:08 -070036stripped_second_vbios_id = $(call strip_quotes,$(CONFIG_VGA_BIOS_SECOND_ID))
37cbfs-files-$(CONFIG_VGA_BIOS_SECOND) += pci$(stripped_second_vbios_id).rom
38pci$(stripped_second_vbios_id).rom-file := $(call strip_quotes,$(CONFIG_VGA_BIOS_SECOND_FILE))
39pci$(stripped_second_vbios_id).rom-type := optionrom
40
Mike Banon0f8547e2019-02-17 19:51:53 +030041stripped_vgabios_dgpu_id = $(call strip_quotes,$(CONFIG_VGA_BIOS_DGPU_ID))
42cbfs-files-$(CONFIG_VGA_BIOS_DGPU) += pci$(stripped_vgabios_dgpu_id).rom
43pci$(stripped_vgabios_dgpu_id).rom-file := $(call strip_quotes,$(CONFIG_VGA_BIOS_DGPU_FILE))
44pci$(stripped_vgabios_dgpu_id).rom-type := optionrom
45
Raul E Rangel90cec2d2021-07-23 16:43:18 -060046# The AMD LPC SPI DMA controller requires source files to be 64 byte aligned.
47ifeq ($(CONFIG_SOC_AMD_COMMON_BLOCK_LPC_SPI_DMA),y)
48pci$(stripped_vgabios_id).rom-align := 64
49pci$(stripped_second_vbios_id).rom-align := 64
50pci$(stripped_vgabios_dgpu_id).rom-align := 64
51endif # CONFIG_SOC_AMD_COMMON_BLOCK_LPC_SPI_DMA
52
Furquan Shaikh88ca81a2014-04-22 16:33:22 -070053###############################################################################
Aaron Durbineb907b32016-01-21 00:08:17 -060054# common support for early assembly includes
55###############################################################################
56
Aaron Durbineb907b32016-01-21 00:08:17 -060057define early_x86_stage
58# $1 stage name
59# $2 oformat
Aaron Durbineb907b32016-01-21 00:08:17 -060060
61# The '.' include path is needed for the generated assembly.inc file.
62$(1)-S-ccopts += -I.
63
64$$(objcbfs)/$(1).debug: $$$$($(1)-libs) $$$$($(1)-objs)
65 @printf " LINK $$(subst $$(obj)/,,$$(@))\n"
Furquan Shaikh46514c22020-06-11 11:59:07 -070066 $$(LD_$(1)) $$(LDFLAGS_$(1)) -o $$@ -L$$(obj) $$(COMPILER_RT_FLAGS_$(1)) --whole-archive --start-group $$(filter-out %.ld,$$($(1)-objs)) $$($(1)-libs) --no-whole-archive $$(COMPILER_RT_$(1)) --end-group -T $(call src-to-obj,$(1),$(CONFIG_MEMLAYOUT_LD_FILE)) --oformat $(2)
Aaron Durbineb907b32016-01-21 00:08:17 -060067 -LANG=C LC_ALL= $$(OBJCOPY_$(1)) --only-section .illegal_globals $$(@) $$(objcbfs)/$(1)_null.offenders >/dev/null 2>&1
68 if [ -z "$$$$($$(NM_$(1)) $$(objcbfs)/$(1)_null.offenders 2>&1 | grep 'no symbols')" ];then \
69 echo "Forbidden global variables in $(1):"; \
70 $$(NM_$(1)) $$(objcbfs)/$(1)_null.offenders; false; \
71 fi
72endef
73
74###############################################################################
Furquan Shaikh88ca81a2014-04-22 16:33:22 -070075# bootblock
76###############################################################################
Patrick Georgi641dd712011-11-01 18:55:59 +010077
Stefan Reinauer181b7732015-03-15 19:23:50 +010078ifeq ($(CONFIG_ARCH_BOOTBLOCK_X86_32)$(CONFIG_ARCH_BOOTBLOCK_X86_64),y)
Furquan Shaikh99ac98f2014-04-23 10:18:48 -070079
Martin Rothcbf6e6b2020-06-06 09:45:20 -060080bootblock-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -060081bootblock-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -060082bootblock-y += post.c
83bootblock-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -060084bootblock-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
85bootblock-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -060086bootblock-y += memcpy.c
87bootblock-y += memset.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +010088bootblock-$(CONFIG_ARCH_BOOTBLOCK_X86_32) += memmove_32.c
89bootblock-$(CONFIG_ARCH_BOOTBLOCK_X86_64) += memmove_64.S
Aaron Durbinf49ddb62018-01-24 17:35:58 -070090bootblock-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Alexandru Gagniuc6a622312015-10-27 10:27:30 -070091bootblock-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -060092bootblock-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Kyösti Mälkkib8d575c2019-12-16 16:00:49 +020093bootblock-$(CONFIG_BOOTBLOCK_NORMAL) += bootblock_normal.c
Kyösti Mälkki97b76f72020-11-19 16:41:28 +020094bootblock-y += gdt_init.S
Alexandru Gagniucee2740b2015-10-04 17:47:36 -070095bootblock-y += id.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -060096bootblock-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Arthur Heymans28de28d2022-05-15 21:46:44 +020097bootblock-y += bootblock.ld
98bootblock-y += car.ld
Martin Rothcbf6e6b2020-06-06 09:45:20 -060099
Nico Huber81b09f42016-01-23 00:50:00 +0100100$(call src-to-obj,bootblock,$(dir)/id.S): $(obj)/build.h
Patrick Georgiab355752015-10-15 11:07:07 +0200101
Aaron Durbineb907b32016-01-21 00:08:17 -0600102ifeq ($(CONFIG_ARCH_BOOTBLOCK_X86_32),y)
103$(eval $(call early_x86_stage,bootblock,elf32-i386))
104else
105$(eval $(call early_x86_stage,bootblock,elf64-x86-64))
106endif
107
Arthur Heymanse8217b12022-04-05 20:42:07 +0200108ifeq ($(CONFIG_BOOTBLOCK_IN_CBFS),y)
Yu-Ping Wu471eda52022-05-20 17:36:46 +0800109add_bootblock = \
110 $(CBFSTOOL) $(1) add -f $(2) -n bootblock -t bootblock $(TXTIBB) \
111 -b -$(call file-size,$(2)) \
Arthur Heymans31187bb2022-03-30 21:31:27 +0200112 $(cbfs-autogen-attributes) $(TS_OPTIONS) $(CBFSTOOL_ADD_CMD_OPTIONS)
Arthur Heymanse8217b12022-04-05 20:42:07 +0200113endif
Arthur Heymans31187bb2022-03-30 21:31:27 +0200114
Julius Wernerd69ccaf2023-04-05 16:18:32 -0700115ifneq ($(CONFIG_CBFS_VERIFICATION),y)
Arthur Heymans50ece622021-05-04 08:46:58 +0200116$(call src-to-obj,bootblock,$(dir)/walkcbfs.S): $(obj)/fmap_config.h
Arthur Heymansa033d8c2021-05-05 14:20:03 +0200117bootblock-y += walkcbfs.S
Julius Wernerd69ccaf2023-04-05 16:18:32 -0700118endif
Arthur Heymans0eb9c572019-01-05 18:21:47 +0100119
Stefan Reinauer181b7732015-03-15 19:23:50 +0100120endif # CONFIG_ARCH_BOOTBLOCK_X86_32 / CONFIG_ARCH_BOOTBLOCK_X86_64
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700121
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700122###############################################################################
Aaron Durbin75c51d92015-09-29 16:31:20 -0500123# verstage
124###############################################################################
125
126ifeq ($(CONFIG_ARCH_VERSTAGE_X86_32)$(CONFIG_ARCH_VERSTAGE_X86_64),y)
127
Arthur Heymansf25f0952021-04-30 14:45:19 +0200128verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += assembly_entry.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600129verstage-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600130verstage-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600131verstage-y += post.c
Hannah Williamsd3c0c0c2018-04-27 09:09:04 -0700132verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += gdt_init.S
Aaron Durbin4b032e42018-04-20 01:39:30 -0600133verstage-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
134verstage-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600135verstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500136
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600137verstage-y += cpu_common.c
138verstage-y += memset.c
139verstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100140verstage-$(CONFIG_ARCH_VERSTAGE_X86_32) += memmove_32.c
141verstage-$(CONFIG_ARCH_VERSTAGE_X86_64) += memmove_64.S
Aaron Durbin57dbbbb2016-03-18 13:12:41 -0500142verstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600143verstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Arthur Heymans7bea0842018-06-06 18:19:56 +0200144# If verstage is a separate stage it means there's no need
Aaron Durbin10221a02016-05-26 10:55:48 -0500145# for a chipset-specific car_stage_entry() so use the generic one
146# which just calls verstage().
Arthur Heymans7bea0842018-06-06 18:19:56 +0200147verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += verstage.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500148
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700149verstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500150
Arthur Heymans28de28d2022-05-15 21:46:44 +0200151verstage-y += car.ld
152
Julius Wernere91d1702017-03-20 15:32:15 -0700153verstage-libs ?=
Aaron Durbin75c51d92015-09-29 16:31:20 -0500154
155ifeq ($(CONFIG_ARCH_VERSTAGE_X86_32),y)
156$(eval $(call early_x86_stage,verstage,elf32-i386))
157else
158$(eval $(call early_x86_stage,verstage,elf64-x86-64))
159endif
160
Aaron Durbin75c51d92015-09-29 16:31:20 -0500161endif # CONFIG_ARCH_VERSTAGE_X86_32 / CONFIG_ARCH_VERSTAGE_X86_64
162
163###############################################################################
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500164# romstage
165###############################################################################
166
167ifeq ($(CONFIG_ARCH_ROMSTAGE_X86_32)$(CONFIG_ARCH_ROMSTAGE_X86_64),y)
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700168
Arthur Heymans08cb80e2020-12-24 12:25:06 +0100169romstage-y += assembly_entry.S
Arthur Heymansbab9e2e2021-05-29 07:30:33 +0200170romstage-y += romstage.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600171romstage-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600172romstage-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600173romstage-y += post.c
Arthur Heymansc05b1a62019-11-22 21:01:30 +0100174romstage-y += gdt_init.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600175romstage-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -0600176romstage-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
177romstage-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600178romstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100179romstage-$(CONFIG_ARCH_ROMSTAGE_X86_32) += memmove_32.c
180romstage-$(CONFIG_ARCH_ROMSTAGE_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600181romstage-y += memset.c
Lee Leahye82b5052016-07-25 17:07:53 -0700182romstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600183romstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Rizwan Qureshib1b44d32016-08-26 21:08:50 +0530184romstage-y += postcar_loader.c
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700185romstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600186romstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Raul E Rangelca0606e2021-07-21 14:34:00 -0600187romstage-$(CONFIG_COOP_MULTITASKING) += thread.c
188romstage-$(CONFIG_COOP_MULTITASKING) += thread_switch.S
Arthur Heymans28de28d2022-05-15 21:46:44 +0200189romstage-y += car.ld
Lee Leahye82b5052016-07-25 17:07:53 -0700190
Rizwan Qureshi8e8ca5c2018-10-01 14:35:25 +0530191romstage-srcs += $(wildcard $(src)/mainboard/$(MAINBOARDDIR)/romstage.c)
Alexandru Gagniuceb3c9912014-03-29 13:01:11 -0500192romstage-libs ?=
193
Stefan Reinauer98749332015-06-23 12:57:06 -0700194ifeq ($(CONFIG_ARCH_ROMSTAGE_X86_32),y)
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500195$(eval $(call early_x86_stage,romstage,elf32-i386))
Stefan Reinauer98749332015-06-23 12:57:06 -0700196else
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500197$(eval $(call early_x86_stage,romstage,elf64-x86-64))
Stefan Reinauer98749332015-06-23 12:57:06 -0700198endif
199
Patrick Georgid69839b2015-04-03 10:32:17 +0200200# Compiling crt0 with -g seems to trigger https://sourceware.org/bugzilla/show_bug.cgi?id=6428
Aaron Durbin75c51d92015-09-29 16:31:20 -0500201romstage-S-ccopts += -g0
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700202
Stefan Reinauer181b7732015-03-15 19:23:50 +0100203endif # CONFIG_ARCH_ROMSTAGE_X86_32 / CONFIG_ARCH_ROMSTAGE_X86_64
Stefan Reinauerf1939bb2010-12-30 17:39:50 +0000204
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700205###############################################################################
Lee Leahya7491502016-07-24 07:43:23 -0700206# postcar
207###############################################################################
208
Patrick Rudolph8daa12f2018-12-26 15:12:32 +0100209ifeq ($(CONFIG_ARCH_POSTCAR_X86_32),y)
Lee Leahya7491502016-07-24 07:43:23 -0700210$(eval $(call create_class_compiler,postcar,x86_32))
Patrick Rudolph8daa12f2018-12-26 15:12:32 +0100211else
212$(eval $(call create_class_compiler,postcar,x86_64))
213endif
Lee Leahya7491502016-07-24 07:43:23 -0700214postcar-generic-ccopts += -D__POSTCAR__
215
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600216postcar-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600217postcar-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600218postcar-y += post.c
Hannah Williamsd3c0c0c2018-04-27 09:09:04 -0700219postcar-y += gdt_init.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600220postcar-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -0600221postcar-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
222postcar-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Lee Leahya7491502016-07-24 07:43:23 -0700223postcar-y += exit_car.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600224postcar-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100225postcar-$(CONFIG_ARCH_POSTCAR_X86_32) += memmove_32.c
226postcar-$(CONFIG_ARCH_POSTCAR_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600227postcar-y += memset.c
Lee Leahya7491502016-07-24 07:43:23 -0700228postcar-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600229postcar-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Aaron Durbin6b0cebc2016-09-16 16:15:14 -0500230postcar-y += postcar.c
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700231postcar-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600232postcar-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Lee Leahya7491502016-07-24 07:43:23 -0700233
Lee Leahy4cfde2a2016-07-24 07:51:24 -0700234LDFLAGS_postcar += -Map $(objcbfs)/postcar.map
235
Lee Leahya7491502016-07-24 07:43:23 -0700236$(objcbfs)/postcar.debug: $$(postcar-objs)
237 @printf " LINK $(subst $(obj)/,,$(@))\n"
Furquan Shaikh46514c22020-06-11 11:59:07 -0700238 $(LD_postcar) $(LDFLAGS_postcar) -o $@ -L$(obj) $(COMPILER_RT_FLAGS_postcar) --whole-archive --start-group $(filter-out %.ld,$^) --no-whole-archive $(COMPILER_RT_postcar) --end-group -T $(call src-to-obj,postcar,$(CONFIG_MEMLAYOUT_LD_FILE))
Lee Leahya7491502016-07-24 07:43:23 -0700239
240$(objcbfs)/postcar.elf: $(objcbfs)/postcar.debug.rmod
241 cp $< $@
242
243# Add postcar to CBFS
244cbfs-files-$(CONFIG_POSTCAR_STAGE) += $(CONFIG_CBFS_PREFIX)/postcar
245$(CONFIG_CBFS_PREFIX)/postcar-file := $(objcbfs)/postcar.elf
246$(CONFIG_CBFS_PREFIX)/postcar-type := stage
247$(CONFIG_CBFS_PREFIX)/postcar-compression := none
248
249###############################################################################
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700250# ramstage
251###############################################################################
252
Stefan Reinauer181b7732015-03-15 19:23:50 +0100253ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32)$(CONFIG_ARCH_RAMSTAGE_X86_64),y)
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700254
Angel Pons79572e42020-07-13 00:17:43 +0200255ramstage-y += acpi.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700256ramstage-$(CONFIG_HAVE_ACPI_RESUME) += acpi_s3.c
Marshall Dawson991467d2018-09-04 12:32:56 -0600257ramstage-$(CONFIG_ACPI_BERT) += acpi_bert_storage.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600258ramstage-y += boot.c
259ramstage-y += post.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700260ramstage-y += c_start.S
Patrick Rudolphe5638152018-12-09 10:48:59 +0100261ramstage-y += c_exit.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700262ramstage-y += cpu.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600263ramstage-y += cpu_common.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600264ramstage-$(CONFIG_DEBUG_HW_BREAKPOINTS) += breakpoint.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700265ramstage-y += ebda.c
266ramstage-y += exception.c
Aaron Durbin7a7c70b2018-04-20 00:56:57 -0600267ramstage-y += idt.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700268ramstage-$(CONFIG_IOAPIC) += ioapic.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600269ramstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100270ramstage-$(CONFIG_ARCH_RAMSTAGE_X86_32) += memmove_32.c
271ramstage-$(CONFIG_ARCH_RAMSTAGE_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600272ramstage-y += memset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700273ramstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
274ramstage-$(CONFIG_GENERATE_MP_TABLE) += mpspec.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600275ramstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS) += null_breakpoint.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700276ramstage-$(CONFIG_GENERATE_PIRQ_TABLE) += pirq_routing.c
Robbie Zhang18792312017-02-13 13:44:14 -0800277ramstage-y += rdrand.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700278ramstage-$(CONFIG_GENERATE_SMBIOS_TABLES) += smbios.c
279ramstage-y += tables.c
280ramstage-$(CONFIG_COOP_MULTITASKING) += thread.c
281ramstage-$(CONFIG_COOP_MULTITASKING) += thread_switch.S
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700282ramstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700283ramstage-$(CONFIG_HAVE_ACPI_RESUME) += wakeup.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600284ramstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700285
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700286rmodules_x86_32-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100287rmodules_x86_32-y += memmove_32.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700288rmodules_x86_32-y += memset.c
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300289
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700290rmodules_x86_64-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100291rmodules_x86_64-y += memmove_64.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700292rmodules_x86_64-y += memset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700293
Patrick Georgic32a52c2015-06-22 21:10:34 +0200294ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32),y)
295target-objcopy=-O elf32-i386 -B i386
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300296LD_MACHINE =-m elf_i386
Patrick Georgic32a52c2015-06-22 21:10:34 +0200297endif
298ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_64),y)
Stefan Reinauer593f5c82015-07-30 18:03:18 -0700299target-objcopy=-O elf64-x86-64 -B i386:x86-64
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300300LD_MACHINE =-m elf_x86_64
Patrick Georgic32a52c2015-06-22 21:10:34 +0200301endif
302
Arthur Heymans67d95182023-05-17 17:37:17 +0200303# Make sure generated code does not use XMMx and MMx registers
304CFLAGS_x86_32 += -mno-mmx -mno-sse
305CFLAGS_x86_64 += -mno-mmx -mno-sse
306
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700307ramstage-srcs += $(wildcard src/mainboard/$(MAINBOARDDIR)/mainboard.c)
308ifeq ($(CONFIG_GENERATE_MP_TABLE),y)
309ifneq ($(wildcard src/mainboard/$(MAINBOARDDIR)/mptable.c),)
310ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/mptable.c
311endif
312endif
313ifeq ($(CONFIG_GENERATE_PIRQ_TABLE),y)
314ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/irq_tables.c
315endif
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700316
317ramstage-libs ?=
318
Elyes HAOUAS2f79eb32018-08-07 12:24:42 +0200319# The rmodule_link definition creates an elf file with .rmod extension.
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700320$(objcbfs)/ramstage.elf: $(objcbfs)/ramstage.debug.rmod
321 cp $< $@
322
Furquan Shaikh46514c22020-06-11 11:59:07 -0700323$(objcbfs)/ramstage.debug: $(objgenerated)/ramstage.o $(call src-to-obj,ramstage,$(CONFIG_MEMLAYOUT_LD_FILE))
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700324 @printf " CC $(subst $(obj)/,,$(@))\n"
Furquan Shaikh46514c22020-06-11 11:59:07 -0700325 $(LD_ramstage) $(CPPFLAGS) $(LDFLAGS_ramstage) -o $@ -L$(obj) $< -T $(call src-to-obj,ramstage,$(CONFIG_MEMLAYOUT_LD_FILE))
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700326
Patrick Georgi3ce96bd2014-11-22 17:42:58 +0100327$(objgenerated)/ramstage.o: $$(ramstage-objs) $(COMPILER_RT_ramstage) $$(ramstage-libs)
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700328 @printf " CC $(subst $(obj)/,,$(@))\n"
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300329 $(LD_ramstage) $(LD_MACHINE) -r -o $@ $(COMPILER_RT_FLAGS_ramstage) --whole-archive --start-group $(filter-out %.ld,$(ramstage-objs)) $(ramstage-libs) --no-whole-archive $(COMPILER_RT_ramstage) --end-group
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700330
Stefan Reinauer181b7732015-03-15 19:23:50 +0100331endif # CONFIG_ARCH_RAMSTAGE_X86_32 / CONFIG_ARCH_RAMSTAGE_X86_64
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530332
Robert Zieba3f01cd12022-04-14 10:36:15 -0600333smm-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530334smm-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
335smm-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
336smm-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100337smm-$(CONFIG_ARCH_RAMSTAGE_X86_32) += memmove_32.c
338smm-$(CONFIG_ARCH_RAMSTAGE_X86_64) += memmove_64.S
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530339smm-y += memset.c
340smm-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600341smm-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530342
Kyösti Mälkki0be41992021-01-08 13:58:10 +0200343smm-srcs += $(wildcard src/mainboard/$(MAINBOARDDIR)/smihandler.c)