blob: 19945465bc70239be4719c921a0e65016cbecacf [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 -060067endef
68
69###############################################################################
Furquan Shaikh88ca81a2014-04-22 16:33:22 -070070# bootblock
71###############################################################################
Patrick Georgi641dd712011-11-01 18:55:59 +010072
Stefan Reinauer181b7732015-03-15 19:23:50 +010073ifeq ($(CONFIG_ARCH_BOOTBLOCK_X86_32)$(CONFIG_ARCH_BOOTBLOCK_X86_64),y)
Furquan Shaikh99ac98f2014-04-23 10:18:48 -070074
Martin Rothcbf6e6b2020-06-06 09:45:20 -060075bootblock-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -060076bootblock-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -060077bootblock-y += post.c
78bootblock-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -060079bootblock-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
80bootblock-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -060081bootblock-y += memcpy.c
82bootblock-y += memset.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +010083bootblock-$(CONFIG_ARCH_BOOTBLOCK_X86_32) += memmove_32.c
84bootblock-$(CONFIG_ARCH_BOOTBLOCK_X86_64) += memmove_64.S
Aaron Durbinf49ddb62018-01-24 17:35:58 -070085bootblock-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Alexandru Gagniuc6a622312015-10-27 10:27:30 -070086bootblock-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -060087bootblock-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Kyösti Mälkkib8d575c2019-12-16 16:00:49 +020088bootblock-$(CONFIG_BOOTBLOCK_NORMAL) += bootblock_normal.c
Kyösti Mälkki97b76f72020-11-19 16:41:28 +020089bootblock-y += gdt_init.S
Alexandru Gagniucee2740b2015-10-04 17:47:36 -070090bootblock-y += id.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -060091bootblock-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Arthur Heymans28de28d2022-05-15 21:46:44 +020092bootblock-y += bootblock.ld
93bootblock-y += car.ld
Martin Rothcbf6e6b2020-06-06 09:45:20 -060094
Nico Huber81b09f42016-01-23 00:50:00 +010095$(call src-to-obj,bootblock,$(dir)/id.S): $(obj)/build.h
Patrick Georgiab355752015-10-15 11:07:07 +020096
Aaron Durbineb907b32016-01-21 00:08:17 -060097ifeq ($(CONFIG_ARCH_BOOTBLOCK_X86_32),y)
98$(eval $(call early_x86_stage,bootblock,elf32-i386))
99else
100$(eval $(call early_x86_stage,bootblock,elf64-x86-64))
101endif
102
Arthur Heymanse8217b12022-04-05 20:42:07 +0200103ifeq ($(CONFIG_BOOTBLOCK_IN_CBFS),y)
Yu-Ping Wu471eda52022-05-20 17:36:46 +0800104add_bootblock = \
105 $(CBFSTOOL) $(1) add -f $(2) -n bootblock -t bootblock $(TXTIBB) \
106 -b -$(call file-size,$(2)) \
Arthur Heymans31187bb2022-03-30 21:31:27 +0200107 $(cbfs-autogen-attributes) $(TS_OPTIONS) $(CBFSTOOL_ADD_CMD_OPTIONS)
Arthur Heymanse8217b12022-04-05 20:42:07 +0200108endif
Arthur Heymans31187bb2022-03-30 21:31:27 +0200109
Julius Wernerd69ccaf2023-04-05 16:18:32 -0700110ifneq ($(CONFIG_CBFS_VERIFICATION),y)
Arthur Heymans50ece622021-05-04 08:46:58 +0200111$(call src-to-obj,bootblock,$(dir)/walkcbfs.S): $(obj)/fmap_config.h
Arthur Heymansa033d8c2021-05-05 14:20:03 +0200112bootblock-y += walkcbfs.S
Julius Wernerd69ccaf2023-04-05 16:18:32 -0700113endif
Arthur Heymans0eb9c572019-01-05 18:21:47 +0100114
Stefan Reinauer181b7732015-03-15 19:23:50 +0100115endif # CONFIG_ARCH_BOOTBLOCK_X86_32 / CONFIG_ARCH_BOOTBLOCK_X86_64
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700116
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700117###############################################################################
Aaron Durbin75c51d92015-09-29 16:31:20 -0500118# verstage
119###############################################################################
120
121ifeq ($(CONFIG_ARCH_VERSTAGE_X86_32)$(CONFIG_ARCH_VERSTAGE_X86_64),y)
122
Arthur Heymansf25f0952021-04-30 14:45:19 +0200123verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += assembly_entry.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600124verstage-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600125verstage-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600126verstage-y += post.c
Hannah Williamsd3c0c0c2018-04-27 09:09:04 -0700127verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += gdt_init.S
Aaron Durbin4b032e42018-04-20 01:39:30 -0600128verstage-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
129verstage-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600130verstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500131
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600132verstage-y += cpu_common.c
133verstage-y += memset.c
134verstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100135verstage-$(CONFIG_ARCH_VERSTAGE_X86_32) += memmove_32.c
136verstage-$(CONFIG_ARCH_VERSTAGE_X86_64) += memmove_64.S
Aaron Durbin57dbbbb2016-03-18 13:12:41 -0500137verstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600138verstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Arthur Heymans7bea0842018-06-06 18:19:56 +0200139# If verstage is a separate stage it means there's no need
Aaron Durbin10221a02016-05-26 10:55:48 -0500140# for a chipset-specific car_stage_entry() so use the generic one
141# which just calls verstage().
Arthur Heymans7bea0842018-06-06 18:19:56 +0200142verstage-$(CONFIG_VBOOT_SEPARATE_VERSTAGE) += verstage.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500143
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700144verstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Aaron Durbin75c51d92015-09-29 16:31:20 -0500145
Arthur Heymans28de28d2022-05-15 21:46:44 +0200146verstage-y += car.ld
147
Julius Wernere91d1702017-03-20 15:32:15 -0700148verstage-libs ?=
Aaron Durbin75c51d92015-09-29 16:31:20 -0500149
150ifeq ($(CONFIG_ARCH_VERSTAGE_X86_32),y)
151$(eval $(call early_x86_stage,verstage,elf32-i386))
152else
153$(eval $(call early_x86_stage,verstage,elf64-x86-64))
154endif
155
Aaron Durbin75c51d92015-09-29 16:31:20 -0500156endif # CONFIG_ARCH_VERSTAGE_X86_32 / CONFIG_ARCH_VERSTAGE_X86_64
157
158###############################################################################
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500159# romstage
160###############################################################################
161
162ifeq ($(CONFIG_ARCH_ROMSTAGE_X86_32)$(CONFIG_ARCH_ROMSTAGE_X86_64),y)
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700163
Arthur Heymansa2bc2542021-05-29 08:10:49 +0200164romstage-$(CONFIG_SEPARATE_ROMSTAGE) += assembly_entry.S
165romstage-$(CONFIG_SEPARATE_ROMSTAGE) += romstage.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600166romstage-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600167romstage-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600168romstage-y += post.c
Arthur Heymansa2bc2542021-05-29 08:10:49 +0200169romstage-$(CONFIG_SEPARATE_ROMSTAGE) += gdt_init.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600170romstage-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -0600171romstage-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
172romstage-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600173romstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100174romstage-$(CONFIG_ARCH_ROMSTAGE_X86_32) += memmove_32.c
175romstage-$(CONFIG_ARCH_ROMSTAGE_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600176romstage-y += memset.c
Lee Leahye82b5052016-07-25 17:07:53 -0700177romstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600178romstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Rizwan Qureshib1b44d32016-08-26 21:08:50 +0530179romstage-y += postcar_loader.c
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700180romstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600181romstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Raul E Rangelca0606e2021-07-21 14:34:00 -0600182romstage-$(CONFIG_COOP_MULTITASKING) += thread.c
183romstage-$(CONFIG_COOP_MULTITASKING) += thread_switch.S
Arthur Heymans28de28d2022-05-15 21:46:44 +0200184romstage-y += car.ld
Lee Leahye82b5052016-07-25 17:07:53 -0700185
Rizwan Qureshi8e8ca5c2018-10-01 14:35:25 +0530186romstage-srcs += $(wildcard $(src)/mainboard/$(MAINBOARDDIR)/romstage.c)
Alexandru Gagniuceb3c9912014-03-29 13:01:11 -0500187romstage-libs ?=
188
Stefan Reinauer98749332015-06-23 12:57:06 -0700189ifeq ($(CONFIG_ARCH_ROMSTAGE_X86_32),y)
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500190$(eval $(call early_x86_stage,romstage,elf32-i386))
Stefan Reinauer98749332015-06-23 12:57:06 -0700191else
Aaron Durbin1bc6a792015-09-29 14:54:25 -0500192$(eval $(call early_x86_stage,romstage,elf64-x86-64))
Stefan Reinauer98749332015-06-23 12:57:06 -0700193endif
194
Patrick Georgid69839b2015-04-03 10:32:17 +0200195# Compiling crt0 with -g seems to trigger https://sourceware.org/bugzilla/show_bug.cgi?id=6428
Aaron Durbin75c51d92015-09-29 16:31:20 -0500196romstage-S-ccopts += -g0
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700197
Stefan Reinauer181b7732015-03-15 19:23:50 +0100198endif # CONFIG_ARCH_ROMSTAGE_X86_32 / CONFIG_ARCH_ROMSTAGE_X86_64
Stefan Reinauerf1939bb2010-12-30 17:39:50 +0000199
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700200###############################################################################
Lee Leahya7491502016-07-24 07:43:23 -0700201# postcar
202###############################################################################
203
Patrick Rudolph8daa12f2018-12-26 15:12:32 +0100204ifeq ($(CONFIG_ARCH_POSTCAR_X86_32),y)
Lee Leahya7491502016-07-24 07:43:23 -0700205$(eval $(call create_class_compiler,postcar,x86_32))
Patrick Rudolph8daa12f2018-12-26 15:12:32 +0100206else
207$(eval $(call create_class_compiler,postcar,x86_64))
208endif
Lee Leahya7491502016-07-24 07:43:23 -0700209postcar-generic-ccopts += -D__POSTCAR__
210
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600211postcar-y += boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600212postcar-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600213postcar-y += post.c
Hannah Williamsd3c0c0c2018-04-27 09:09:04 -0700214postcar-y += gdt_init.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600215postcar-y += cpu_common.c
Aaron Durbin4b032e42018-04-20 01:39:30 -0600216postcar-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
217postcar-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
Lee Leahya7491502016-07-24 07:43:23 -0700218postcar-y += exit_car.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600219postcar-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100220postcar-$(CONFIG_ARCH_POSTCAR_X86_32) += memmove_32.c
221postcar-$(CONFIG_ARCH_POSTCAR_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600222postcar-y += memset.c
Lee Leahya7491502016-07-24 07:43:23 -0700223postcar-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600224postcar-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Aaron Durbin6b0cebc2016-09-16 16:15:14 -0500225postcar-y += postcar.c
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700226postcar-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600227postcar-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Lee Leahya7491502016-07-24 07:43:23 -0700228
Lee Leahy4cfde2a2016-07-24 07:51:24 -0700229LDFLAGS_postcar += -Map $(objcbfs)/postcar.map
230
Lee Leahya7491502016-07-24 07:43:23 -0700231$(objcbfs)/postcar.debug: $$(postcar-objs)
232 @printf " LINK $(subst $(obj)/,,$(@))\n"
Furquan Shaikh46514c22020-06-11 11:59:07 -0700233 $(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 -0700234
235$(objcbfs)/postcar.elf: $(objcbfs)/postcar.debug.rmod
236 cp $< $@
237
238# Add postcar to CBFS
239cbfs-files-$(CONFIG_POSTCAR_STAGE) += $(CONFIG_CBFS_PREFIX)/postcar
240$(CONFIG_CBFS_PREFIX)/postcar-file := $(objcbfs)/postcar.elf
241$(CONFIG_CBFS_PREFIX)/postcar-type := stage
242$(CONFIG_CBFS_PREFIX)/postcar-compression := none
243
244###############################################################################
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700245# ramstage
246###############################################################################
247
Stefan Reinauer181b7732015-03-15 19:23:50 +0100248ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32)$(CONFIG_ARCH_RAMSTAGE_X86_64),y)
Furquan Shaikh99ac98f2014-04-23 10:18:48 -0700249
Angel Pons79572e42020-07-13 00:17:43 +0200250ramstage-y += acpi.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700251ramstage-$(CONFIG_HAVE_ACPI_RESUME) += acpi_s3.c
Marshall Dawson991467d2018-09-04 12:32:56 -0600252ramstage-$(CONFIG_ACPI_BERT) += acpi_bert_storage.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600253ramstage-y += boot.c
254ramstage-y += post.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700255ramstage-y += c_start.S
Patrick Rudolphe5638152018-12-09 10:48:59 +0100256ramstage-y += c_exit.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700257ramstage-y += cpu.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600258ramstage-y += cpu_common.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600259ramstage-$(CONFIG_DEBUG_HW_BREAKPOINTS) += breakpoint.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700260ramstage-y += ebda.c
261ramstage-y += exception.c
Aaron Durbin7a7c70b2018-04-20 00:56:57 -0600262ramstage-y += idt.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700263ramstage-$(CONFIG_IOAPIC) += ioapic.c
Maximilian Bruneb3e336c2023-09-16 19:49:39 +0200264ramstage-y += dma.c
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600265ramstage-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100266ramstage-$(CONFIG_ARCH_RAMSTAGE_X86_32) += memmove_32.c
267ramstage-$(CONFIG_ARCH_RAMSTAGE_X86_64) += memmove_64.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600268ramstage-y += memset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700269ramstage-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
270ramstage-$(CONFIG_GENERATE_MP_TABLE) += mpspec.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600271ramstage-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS) += null_breakpoint.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700272ramstage-$(CONFIG_GENERATE_PIRQ_TABLE) += pirq_routing.c
Robbie Zhang18792312017-02-13 13:44:14 -0800273ramstage-y += rdrand.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700274ramstage-$(CONFIG_GENERATE_SMBIOS_TABLES) += smbios.c
275ramstage-y += tables.c
276ramstage-$(CONFIG_COOP_MULTITASKING) += thread.c
277ramstage-$(CONFIG_COOP_MULTITASKING) += thread_switch.S
Aaron Durbinf49ddb62018-01-24 17:35:58 -0700278ramstage-$(CONFIG_COLLECT_TIMESTAMPS_TSC) += timestamp.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700279ramstage-$(CONFIG_HAVE_ACPI_RESUME) += wakeup.S
Martin Rothcbf6e6b2020-06-06 09:45:20 -0600280ramstage-$(CONFIG_HAVE_CF9_RESET) += cf9_reset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700281
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700282rmodules_x86_32-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100283rmodules_x86_32-y += memmove_32.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700284rmodules_x86_32-y += memset.c
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300285
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700286rmodules_x86_64-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100287rmodules_x86_64-y += memmove_64.S
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700288rmodules_x86_64-y += memset.c
Lee Leahy99f1b2f2016-07-25 17:18:50 -0700289
Patrick Georgic32a52c2015-06-22 21:10:34 +0200290ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32),y)
291target-objcopy=-O elf32-i386 -B i386
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300292LD_MACHINE =-m elf_i386
Patrick Georgic32a52c2015-06-22 21:10:34 +0200293endif
294ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_64),y)
Stefan Reinauer593f5c82015-07-30 18:03:18 -0700295target-objcopy=-O elf64-x86-64 -B i386:x86-64
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300296LD_MACHINE =-m elf_x86_64
Patrick Georgic32a52c2015-06-22 21:10:34 +0200297endif
298
Arthur Heymans67d95182023-05-17 17:37:17 +0200299# Make sure generated code does not use XMMx and MMx registers
300CFLAGS_x86_32 += -mno-mmx -mno-sse
301CFLAGS_x86_64 += -mno-mmx -mno-sse
302
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700303ramstage-srcs += $(wildcard src/mainboard/$(MAINBOARDDIR)/mainboard.c)
304ifeq ($(CONFIG_GENERATE_MP_TABLE),y)
305ifneq ($(wildcard src/mainboard/$(MAINBOARDDIR)/mptable.c),)
306ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/mptable.c
307endif
308endif
309ifeq ($(CONFIG_GENERATE_PIRQ_TABLE),y)
310ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/irq_tables.c
311endif
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700312
313ramstage-libs ?=
314
Elyes HAOUAS2f79eb32018-08-07 12:24:42 +0200315# The rmodule_link definition creates an elf file with .rmod extension.
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700316$(objcbfs)/ramstage.elf: $(objcbfs)/ramstage.debug.rmod
317 cp $< $@
318
Furquan Shaikh46514c22020-06-11 11:59:07 -0700319$(objcbfs)/ramstage.debug: $(objgenerated)/ramstage.o $(call src-to-obj,ramstage,$(CONFIG_MEMLAYOUT_LD_FILE))
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700320 @printf " CC $(subst $(obj)/,,$(@))\n"
Srinivas Hegde2d589cf2023-11-21 22:10:36 +0000321 $(LD_ramstage) $(LDFLAGS_ramstage) -o $@ -L$(obj) $< -T $(call src-to-obj,ramstage,$(CONFIG_MEMLAYOUT_LD_FILE))
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700322
Patrick Georgi3ce96bd2014-11-22 17:42:58 +0100323$(objgenerated)/ramstage.o: $$(ramstage-objs) $(COMPILER_RT_ramstage) $$(ramstage-libs)
Furquan Shaikh88ca81a2014-04-22 16:33:22 -0700324 @printf " CC $(subst $(obj)/,,$(@))\n"
Kyösti Mälkki67a537c2020-06-04 09:21:40 +0300325 $(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 -0700326
Stefan Reinauer181b7732015-03-15 19:23:50 +0100327endif # CONFIG_ARCH_RAMSTAGE_X86_32 / CONFIG_ARCH_RAMSTAGE_X86_64
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530328
Robert Zieba3f01cd12022-04-14 10:36:15 -0600329smm-$(CONFIG_DEBUG_HW_BREAKPOINTS_IN_ALL_STAGES) += breakpoint.c
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530330smm-$(CONFIG_IDT_IN_EVERY_STAGE) += exception.c
331smm-$(CONFIG_IDT_IN_EVERY_STAGE) += idt.S
332smm-y += memcpy.c
Arthur Heymans9df0fee2022-11-04 20:20:14 +0100333smm-$(CONFIG_ARCH_RAMSTAGE_X86_32) += memmove_32.c
334smm-$(CONFIG_ARCH_RAMSTAGE_X86_64) += memmove_64.S
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530335smm-y += memset.c
336smm-$(CONFIG_X86_TOP4G_BOOTMEDIA_MAP) += mmap_boot.c
Robert Zieba3f01cd12022-04-14 10:36:15 -0600337smm-$(CONFIG_DEBUG_NULL_DEREF_BREAKPOINTS_IN_ALL_STAGES) += null_breakpoint.c
Subrata Banikeb5b0d02019-06-04 16:46:41 +0530338
Kyösti Mälkki0be41992021-01-08 13:58:10 +0200339smm-srcs += $(wildcard src/mainboard/$(MAINBOARDDIR)/smihandler.c)
Felix Held6759ad32023-12-14 20:49:59 +0100340
341ifneq ($(CONFIG_HAVE_CONFIGURABLE_APMC_SMI_PORT),y)
342ramstage-y += apmc_smi_port.c
343smm-y += apmc_smi_port.c
344endif