2020-04-18 22:26:39 +02:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
2019-04-23 00:08:31 +02:00
|
|
|
ifeq ($(CONFIG_SOC_AMD_PICASSO),y)
|
2019-04-22 22:55:16 +02:00
|
|
|
|
|
|
|
subdirs-y += ../../../cpu/amd/mtrr/
|
|
|
|
subdirs-y += ../../../cpu/x86/tsc
|
|
|
|
subdirs-y += ../../../cpu/x86/lapic
|
|
|
|
subdirs-y += ../../../cpu/x86/cache
|
|
|
|
subdirs-y += ../../../cpu/x86/mtrr
|
|
|
|
subdirs-y += ../../../cpu/x86/pae
|
|
|
|
subdirs-y += ../../../cpu/x86/smm
|
|
|
|
|
2020-04-04 02:37:04 +02:00
|
|
|
bootblock-y += bootblock/pre_c.S
|
|
|
|
bootblock-y += bootblock/bootblock.c
|
|
|
|
bootblock-y += southbridge.c
|
|
|
|
bootblock-y += i2c.c
|
|
|
|
bootblock-$(CONFIG_PICASSO_UART) += uart.c
|
|
|
|
bootblock-y += tsc_freq.c
|
|
|
|
bootblock-y += gpio.c
|
|
|
|
bootblock-y += smi_util.c
|
2020-05-09 23:26:37 +02:00
|
|
|
bootblock-y += config.c
|
2020-04-04 02:37:04 +02:00
|
|
|
|
2019-04-22 22:55:16 +02:00
|
|
|
romstage-y += i2c.c
|
|
|
|
romstage-y += romstage.c
|
|
|
|
romstage-y += gpio.c
|
|
|
|
romstage-y += pmutil.c
|
2019-08-03 20:28:40 +02:00
|
|
|
romstage-y += memmap.c
|
2019-06-11 20:18:20 +02:00
|
|
|
romstage-$(CONFIG_PICASSO_UART) += uart.c
|
2019-04-22 22:55:16 +02:00
|
|
|
romstage-y += tsc_freq.c
|
|
|
|
romstage-y += southbridge.c
|
|
|
|
romstage-$(CONFIG_HAVE_SMI_HANDLER) += smi_util.c
|
2020-01-24 17:42:57 +01:00
|
|
|
romstage-y += psp.c
|
src/soc/amd/picasso: Add methods to save and restore MTRRs
FSP AGESA overrides the MTRRs that coreboot set up. Until this is fixed
we need to save and restore the MTRRs to undo what AGESA did.
Once AGESA is fixed, we can delete these files.
BUG=b:155426691, b:147042464
TEST=Boot trembyle and see MTRRs being modified
Saving Variable MTRR 0: Base: 0x00000000 0xff000005, Mask: 0x0000ffff 0xff000800
Saving Variable MTRR 1: Base: 0x00000000 0x08070006, Mask: 0x0000ffff 0xffff0800
Saving Variable MTRR 2: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Variable MTRR 3: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Variable MTRR 4: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Variable MTRR 5: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Variable MTRR 6: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Variable MTRR 7: Base: 0x00000000 0x00000000, Mask: 0x00000000 0x00000000
Saving Fixed MTRR 0: 0x00000000 0x00000000
Saving Fixed MTRR 1: 0x00000000 0x00000000
Saving Fixed MTRR 2: 0x00000000 0x00000000
Saving Fixed MTRR 3: 0x00000000 0x00000000
Saving Fixed MTRR 4: 0x00000000 0x00000000
Saving Fixed MTRR 5: 0x00000000 0x00000000
Saving Fixed MTRR 6: 0x00000000 0x00000000
Saving Fixed MTRR 7: 0x00000000 0x00000000
Saving Fixed MTRR 8: 0x00000000 0x00000000
Saving Fixed MTRR 9: 0x00000000 0x00000000
Saving Fixed MTRR 10: 0x00000000 0x00000000
Saving Default Type MTRR: 0x00000000 0x00000800
Saving SYS_CFG: 0x00000000 0x00000800
...
MSR 0x200 was modified: 0x00000000 0x00000006
MSR 0x201 was modified: 0x0000ffff 0x80000800
MSR 0x202 was modified: 0x00000000 0x80000006
MSR 0x203 was modified: 0x0000ffff 0xc0000800
MSR 0x204 was modified: 0x00000000 0xc0000006
MSR 0x205 was modified: 0x0000ffff 0xf0000800
MSR 0x250 was modified: 0x06060606 0x06060606
MSR 0x258 was modified: 0x06060606 0x06060606
SYS_CFG was modified: 0x00000000 0x00740000
Signed-off-by: Raul E Rangel <rrangel@chromium.org>
Change-Id: I6048b25bd8a32904031ca23953f9726754b5a294
Reviewed-on: https://review.coreboot.org/c/coreboot/+/40922
Reviewed-by: Furquan Shaikh <furquan@google.com>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
2020-05-01 00:26:30 +02:00
|
|
|
romstage-y += mtrr.c
|
2020-05-09 23:26:37 +02:00
|
|
|
romstage-y += config.c
|
2019-04-22 22:55:16 +02:00
|
|
|
|
|
|
|
verstage-y += gpio.c
|
|
|
|
verstage-y += i2c.c
|
|
|
|
verstage-y += pmutil.c
|
2020-05-09 23:26:37 +02:00
|
|
|
verstage-y += config.c
|
2019-06-11 20:18:20 +02:00
|
|
|
verstage-$(CONFIG_PICASSO_UART) += uart.c
|
2019-04-22 22:55:16 +02:00
|
|
|
verstage-y += tsc_freq.c
|
|
|
|
|
|
|
|
ramstage-y += i2c.c
|
|
|
|
ramstage-y += chip.c
|
|
|
|
ramstage-y += cpu.c
|
2020-05-12 00:26:35 +02:00
|
|
|
ramstage-y += data_fabric_util.c
|
2019-07-16 23:46:35 +02:00
|
|
|
ramstage-y += root_complex.c
|
2019-04-22 22:55:16 +02:00
|
|
|
ramstage-y += mca.c
|
|
|
|
ramstage-$(CONFIG_HAVE_ACPI_TABLES) += acpi.c
|
|
|
|
ramstage-y += gpio.c
|
|
|
|
ramstage-y += southbridge.c
|
|
|
|
ramstage-y += pmutil.c
|
2019-08-16 16:45:20 +02:00
|
|
|
ramstage-y += acp.c
|
2019-04-22 22:55:16 +02:00
|
|
|
ramstage-y += sata.c
|
2019-08-03 20:28:40 +02:00
|
|
|
ramstage-y += memmap.c
|
2019-04-22 22:55:16 +02:00
|
|
|
ramstage-$(CONFIG_HAVE_SMI_HANDLER) += smi.c
|
|
|
|
ramstage-$(CONFIG_HAVE_SMI_HANDLER) += smi_util.c
|
2019-06-11 20:18:20 +02:00
|
|
|
ramstage-$(CONFIG_PICASSO_UART) += uart.c
|
2019-04-22 22:55:16 +02:00
|
|
|
ramstage-y += usb.c
|
|
|
|
ramstage-y += tsc_freq.c
|
|
|
|
ramstage-y += finalize.c
|
2020-02-17 21:17:19 +01:00
|
|
|
ramstage-y += soc_util.c
|
2020-01-24 17:42:57 +01:00
|
|
|
ramstage-y += psp.c
|
2020-04-09 22:16:55 +02:00
|
|
|
ramstage-y += fsp_params.c
|
2020-05-09 23:26:37 +02:00
|
|
|
ramstage-y += config.c
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-12-13 17:11:05 +01:00
|
|
|
all-y += reset.c
|
|
|
|
|
2019-04-22 22:55:16 +02:00
|
|
|
smm-y += smihandler.c
|
|
|
|
smm-y += smi_util.c
|
|
|
|
smm-y += tsc_freq.c
|
|
|
|
smm-$(CONFIG_DEBUG_SMI) += uart.c
|
|
|
|
smm-y += gpio.c
|
2020-01-24 17:42:57 +01:00
|
|
|
smm-y += psp.c
|
2020-04-23 14:43:44 +02:00
|
|
|
smm-y += smu.c
|
2020-05-09 23:26:37 +02:00
|
|
|
smm-y += config.c
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-04-23 00:32:58 +02:00
|
|
|
CPPFLAGS_common += -I$(src)/soc/amd/picasso
|
|
|
|
CPPFLAGS_common += -I$(src)/soc/amd/picasso/include
|
|
|
|
CPPFLAGS_common += -I$(src)/soc/amd/picasso/acpi
|
2020-01-21 07:05:31 +01:00
|
|
|
CPPFLAGS_common += -I$(src)/vendorcode/amd/fsp/picasso
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2020-05-13 22:01:09 +02:00
|
|
|
MAINBOARD_BLOBS_DIR:=$(top)/3rdparty/blobs/mainboard/$(MAINBOARDDIR)
|
|
|
|
|
2019-04-22 22:55:16 +02:00
|
|
|
# ROMSIG Normally At ROMBASE + 0x20000
|
|
|
|
# Overridden by CONFIG_AMD_FWM_POSITION_INDEX
|
|
|
|
# +-----------+---------------+----------------+------------+
|
2019-06-19 19:46:06 +02:00
|
|
|
# |0x55AA55AA | | | |
|
2019-04-22 22:55:16 +02:00
|
|
|
# +-----------+---------------+----------------+------------+
|
2019-06-19 19:46:06 +02:00
|
|
|
# | | PSPDIR ADDR | BIOSDIR ADDR |
|
|
|
|
# +-----------+---------------+----------------+
|
|
|
|
|
2019-06-11 20:18:20 +02:00
|
|
|
PICASSO_FWM_POSITION=$(call int-add, \
|
2019-04-22 22:55:16 +02:00
|
|
|
$(call int-subtract, 0xffffffff \
|
|
|
|
$(call int-shift-left, \
|
|
|
|
0x80000 $(CONFIG_AMD_FWM_POSITION_INDEX))) 0x20000 1)
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
#
|
|
|
|
# PSP Directory Table items
|
|
|
|
#
|
|
|
|
# Certain ordering requirements apply, however these are ensured by amdfwtool.
|
|
|
|
# For more information see "AMD Platform Security Processor BIOS Architecture
|
|
|
|
# Design Guide for AMD Family 17h Processors" (PID #55758, NDA only).
|
|
|
|
#
|
|
|
|
|
|
|
|
# type = 0x0
|
2019-04-22 22:55:16 +02:00
|
|
|
FIRMWARE_LOCATE=$(dir $(call strip_quotes, $(CONFIG_AMD_PUBKEY_FILE)))
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
# type = 0x1
|
2020-02-20 21:54:06 +01:00
|
|
|
ifeq ($(CONFIG_PSP_BOOTLOADER_FILE),)
|
|
|
|
$(error CONFIG_PSP_BOOTLOADER_FILE was not defined)
|
2019-06-19 19:46:06 +02:00
|
|
|
endif
|
2020-02-20 21:54:06 +01:00
|
|
|
PSPBTLDR_FILE=$(realpath $(call strip_quotes, $(CONFIG_PSP_BOOTLOADER_FILE)))
|
|
|
|
$(info Adding PSP $(shell md5sum $(PSPBTLDR_FILE)))
|
2019-06-19 19:46:06 +02:00
|
|
|
|
2020-04-24 08:34:17 +02:00
|
|
|
# types = 0x8 and 0x12
|
2019-06-19 19:46:06 +02:00
|
|
|
PSP_SMUFW1_SUB1_FILE=$(top)/$(FIRMWARE_LOCATE)/SmuFirmwareRV2.csbin
|
|
|
|
PSP_SMUFW1_SUB2_FILE=$(top)/$(FIRMWARE_LOCATE)/SmuFirmwarePCO.csbin
|
|
|
|
PSP_SMUFW2_SUB1_FILE=$(top)/$(FIRMWARE_LOCATE)/SmuFirmware2RV2.csbin
|
|
|
|
PSP_SMUFW2_SUB2_FILE=$(top)/$(FIRMWARE_LOCATE)/SmuFirmware2PCO.csbin
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2020-04-25 00:52:04 +02:00
|
|
|
ifeq ($(CONFIG_PSP_UNLOCK_SECURE_DEBUG),y)
|
2019-06-19 19:46:06 +02:00
|
|
|
# type = 0x9
|
|
|
|
PSP_SEC_DBG_KEY_FILE=$(top)/$(FIRMWARE_LOCATE)/RavenSecureDebug_PublicKey.bin
|
2020-04-25 00:52:04 +02:00
|
|
|
# type = 0x13
|
|
|
|
PSP_SEC_DEBUG_FILE=$(top)/$(FIRMWARE_LOCATE)/secure_unlock_prod_RV.sbin
|
2020-04-24 23:04:07 +02:00
|
|
|
# Enable secure debug unlock
|
|
|
|
PSP_SOFTFUSE_BITS += 0
|
2020-04-25 00:52:04 +02:00
|
|
|
PSP_TOKEN_UNLOCK="--token-unlock"
|
|
|
|
endif
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
ifeq ($(CONFIG_USE_PSPSCUREOS),y)
|
2020-04-24 04:48:28 +02:00
|
|
|
# types = 0x2
|
2019-06-19 19:46:06 +02:00
|
|
|
PSPSCUREOS_FILE=$(top)/$(FIRMWARE_LOCATE)/psp_os_combined_prod_RV.sbin
|
2019-04-22 22:55:16 +02:00
|
|
|
endif
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
# type = 0x21
|
|
|
|
PSP_IKEK_FILE=$(top)/$(FIRMWARE_LOCATE)/PspIkekRV.bin
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
# type = 0x24
|
|
|
|
PSP_SECG1_FILE=$(top)/$(FIRMWARE_LOCATE)/security_policy_RV2_FP5_AM4.sbin
|
|
|
|
PSP_SECG2_FILE=$(top)/$(FIRMWARE_LOCATE)/security_policy_PCO_FP5_AM4.sbin
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
ifeq ($(CONFIG_PSP_LOAD_MP2_FW),y)
|
|
|
|
# type = 0x25
|
|
|
|
PSP_MP2FW1_FILE=$(top)/$(FIRMWARE_LOCATE)/MP2I2CFWRV2.sbin
|
|
|
|
PSP_MP2FW2_FILE=$(top)/$(FIRMWARE_LOCATE)/MP2I2CFWPCO.sbin
|
|
|
|
# BIOS type = 0x6a
|
|
|
|
PSP_MP2CFG_FILE=$(top)/$(FIRMWARE_LOCATE)/MP2FWConfig.sbin
|
|
|
|
else
|
2020-04-24 23:04:07 +02:00
|
|
|
# Disable MP2 firmware loading
|
|
|
|
PSP_SOFTFUSE_BITS += 29
|
2019-06-19 19:46:06 +02:00
|
|
|
endif
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
# type = 0x28
|
|
|
|
PSP_DRIVERS_FILE=$(top)/$(FIRMWARE_LOCATE)/drv_sys_prod_RV.sbin
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
ifeq ($(CONFIG_PSP_LOAD_S0I3_FW),y)
|
|
|
|
PSP_S0I3_FILE=$(top)/$(FIRMWARE_LOCATE)/dr_agesa_prod_RV.sbin
|
2019-04-22 22:55:16 +02:00
|
|
|
endif
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
# types = 0x30 - 0x37
|
|
|
|
PSP_ABL0_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader0_prod_RV.csbin
|
|
|
|
PSP_ABL1_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader1_prod_RV.csbin
|
|
|
|
PSP_ABL2_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader2_prod_RV.csbin
|
|
|
|
PSP_ABL3_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader3_prod_RV.csbin
|
|
|
|
PSP_ABL4_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader4_prod_RV.csbin
|
|
|
|
PSP_ABL5_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader5_prod_RV.csbin
|
|
|
|
PSP_ABL6_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader6_prod_RV.csbin
|
|
|
|
PSP_ABL7_FILE=$(top)/$(FIRMWARE_LOCATE)/AgesaBootloader7_prod_RV.csbin
|
|
|
|
|
|
|
|
# type = 0x3a
|
|
|
|
ifeq ($(CONFIG_HAVE_PSP_WHITELIST_FILE),y)
|
|
|
|
PSP_WHITELIST_FILE=$(CONFIG_PSP_WHITELIST_FILE)
|
2019-04-22 22:55:16 +02:00
|
|
|
endif
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
#
|
|
|
|
# BIOS Directory Table items - proper ordering is managed by amdfwtool
|
|
|
|
#
|
|
|
|
|
|
|
|
# type = 0x60
|
2020-05-13 22:01:09 +02:00
|
|
|
PSP_APCB_FILES=$(foreach f, $(APCB_SOURCES), $(obj)/APCB_$(f).bin)
|
2019-06-19 19:46:06 +02:00
|
|
|
|
|
|
|
# type = 0x61
|
2020-01-21 03:56:30 +01:00
|
|
|
PSP_APOB_BASE=$(CONFIG_PSP_APOB_DRAM_ADDRESS)
|
2019-06-19 19:46:06 +02:00
|
|
|
|
|
|
|
# type = 0x62
|
|
|
|
PSP_BIOSBIN_FILE=$(obj)/amd_biospsp.img
|
2020-04-04 02:37:04 +02:00
|
|
|
PSP_ELF_FILE=$(objcbfs)/bootblock.elf
|
|
|
|
# TODO(b/154957411): Refactor amdfwtool to extract the address and size from
|
|
|
|
# the elf file.
|
|
|
|
PSP_BIOSBIN_SIZE=$(CONFIG_C_ENV_BOOTBLOCK_SIZE)
|
|
|
|
# This address must match the BOOTBLOCK logic in arch/x86/memlayout.ld.
|
|
|
|
PSP_BIOSBIN_DEST=$(shell printf "%x" $(call int-subtract, $(call int-add, $(CONFIG_X86_RESET_VECTOR) 0x10) $(PSP_BIOSBIN_SIZE)))
|
2019-06-19 19:46:06 +02:00
|
|
|
|
2020-01-21 03:56:30 +01:00
|
|
|
# type = 0x63 - construct APOB NV base/size from flash map
|
|
|
|
# TODO(b/157068645): Add ability to fmaptool to extract offsets and sizes
|
|
|
|
# This code currently assumes the following FMAP structure. If
|
|
|
|
# the UNIFIED_MRC_CACHE region is present, it must have a 0 offset.
|
|
|
|
# FLASH@* {
|
|
|
|
# BIOS@* {
|
|
|
|
# RW_MRC_CACHE@* {
|
|
|
|
_FLASH_BASE=$(call int-subtract, 0x100000000 $(CONFIG_ROM_SIZE))
|
|
|
|
_GET_FLASH_BASE=grep "FLASH" | sed 's/.*FLASH@//' | sed 's/ .*//'
|
|
|
|
_GET_BIOS_REG_BASE=grep "BIOS" | sed 's/.*BIOS@//' | sed 's/ .*//'
|
|
|
|
_GET_APOBNV_BASE=grep "RW_MRC_CACHE" | sed 's/.*@//' | sed 's/ .*//'
|
|
|
|
_GET_APOBNV_SIZE=grep "RW_MRC_CACHE" | sed 's/.*@//' | sed 's/.* //'
|
2019-06-19 19:46:06 +02:00
|
|
|
|
|
|
|
# type2 = 0x64, 0x65
|
|
|
|
PSP_PMUI_FILE1=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv_1D_Ddr4_Udimm_Imem.csbin
|
|
|
|
PSP_PMUI_FILE2=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv_2D_Ddr4_Imem.csbin
|
|
|
|
PSP_PMUI_FILE3=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv2_1D_ddr4_Udimm_Imem.csbin
|
|
|
|
PSP_PMUI_FILE4=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv2_2D_ddr4_Udimm_Imem.csbin
|
|
|
|
PSP_PMUD_FILE1=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv_1D_Ddr4_Udimm_Dmem.csbin
|
|
|
|
PSP_PMUD_FILE2=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv_2D_Ddr4_Dmem.csbin
|
|
|
|
PSP_PMUD_FILE3=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv2_1D_ddr4_Udimm_Dmem.csbin
|
|
|
|
PSP_PMUD_FILE4=$(top)/$(FIRMWARE_LOCATE)/Appb_Rv2_2D_ddr4_Udimm_Dmem.csbin
|
|
|
|
|
|
|
|
# type = 0x66
|
|
|
|
PSP_UCODE_FILE1=$(top)/$(FIRMWARE_LOCATE)/UcodePatch_PCO_B1.bin
|
|
|
|
PSP_UCODE_FILE2=$(top)/$(FIRMWARE_LOCATE)/UcodePatch_PCO_B0.bin
|
|
|
|
PSP_UCODE_FILE3=$(top)/$(FIRMWARE_LOCATE)/UcodePatch_RV2_A0.bin
|
|
|
|
|
2020-04-24 23:04:07 +02:00
|
|
|
# type = 0xb - See #55758 (NDA) for bit definitions.
|
|
|
|
PSP_SOFTFUSE_BITS += 28
|
|
|
|
|
|
|
|
# Helper function to return a value with given bit set
|
|
|
|
set-bit=$(call int-shift-left, 1 $(call _toint,$1))
|
|
|
|
PSP_SOFTFUSE=$(shell A=$(call int-add, \
|
|
|
|
$(foreach bit,$(PSP_SOFTFUSE_BITS),$(call set-bit,$(bit)))); printf "0x%x" $$A)
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
#
|
|
|
|
# Build the arguments to amdfwtool (order is unimportant). Missing file names
|
|
|
|
# result in empty OPT_ variables, i.e. the argument is not passed to amdfwtool.
|
|
|
|
#
|
|
|
|
|
2019-04-22 22:55:16 +02:00
|
|
|
add_opt_prefix=$(if $(call strip_quotes, $(1)), $(2) $(call strip_quotes, $(1)), )
|
|
|
|
|
|
|
|
OPT_AMD_PUBKEY_FILE=$(call add_opt_prefix, $(CONFIG_AMD_PUBKEY_FILE), --pubkey)
|
|
|
|
OPT_PSPBTLDR_FILE=$(call add_opt_prefix, $(PSPBTLDR_FILE), --bootloader)
|
2019-06-19 19:46:06 +02:00
|
|
|
OPT_SMUFW1_SUB1_FILE=$(call add_opt_prefix, $(PSP_SMUFW1_SUB1_FILE), --subprogram 1 --smufirmware)
|
|
|
|
OPT_SMUFW1_SUB2_FILE=$(call add_opt_prefix, $(PSP_SMUFW1_SUB2_FILE), --subprogram 2 --smufirmware)
|
|
|
|
OPT_SMUFW2_SUB1_FILE=$(call add_opt_prefix, $(PSP_SMUFW2_SUB1_FILE), --subprogram 1 --smufirmware2)
|
|
|
|
OPT_SMUFW2_SUB2_FILE=$(call add_opt_prefix, $(PSP_SMUFW2_SUB2_FILE), --subprogram 2 --smufirmware2)
|
|
|
|
OPT_PSP_SEC_DBG_KEY_FILE=$(call add_opt_prefix, $(PSP_SEC_DBG_KEY_FILE), --securedebug)
|
2020-04-25 00:52:04 +02:00
|
|
|
OPT_TOKEN_UNLOCK=$(call add_opt_prefix, $(PSP_TOKEN_UNLOCK), "")
|
2019-06-19 19:46:06 +02:00
|
|
|
OPT_PSP_SOFTFUSE=$(call add_opt_prefix, $(PSP_SOFTFUSE), --soft-fuse)
|
2019-04-22 22:55:16 +02:00
|
|
|
OPT_PSPSCUREOS_FILE=$(call add_opt_prefix, $(PSPSCUREOS_FILE), --secureos)
|
2019-06-19 19:46:06 +02:00
|
|
|
OPT_SEC_DEBUG_FILE=$(call add_opt_prefix, $(PSP_SEC_DEBUG_FILE), --secdebug)
|
|
|
|
OPT_IKEK_FILE=$(call add_opt_prefix, $(PSP_IKEK_FILE), --ikek)
|
|
|
|
OPT_SECG1_FILE=$(call add_opt_prefix, $(PSP_SECG1_FILE), --subprog 1 --sec-gasket)
|
|
|
|
OPT_SECG2_FILE=$(call add_opt_prefix, $(PSP_SECG2_FILE), --subprog 2 --sec-gasket)
|
|
|
|
OPT_MP2FW1_FILE=$(call add_opt_prefix, $(PSP_MP2FW1_FILE), --subprog 1 --mp2-fw)
|
|
|
|
OPT_MP2FW2_FILE=$(call add_opt_prefix, $(PSP_MP2FW2_FILE), --subprog 2 --mp2-fw)
|
|
|
|
OPT_DRIVERS_FILE=$(call add_opt_prefix, $(PSP_DRIVERS_FILE), --drv-entry-pts)
|
|
|
|
OPT_PSP_S0I3_FILE=$(call add_opt_prefix, $(PSP_S0I3_FILE), --s0i3drv)
|
|
|
|
OPT_ABL0_FILE=$(call add_opt_prefix, $(PSP_ABL0_FILE), --abl-image)
|
|
|
|
OPT_ABL1_FILE=$(call add_opt_prefix, $(PSP_ABL1_FILE), --abl-image)
|
|
|
|
OPT_ABL2_FILE=$(call add_opt_prefix, $(PSP_ABL2_FILE), --abl-image)
|
|
|
|
OPT_ABL3_FILE=$(call add_opt_prefix, $(PSP_ABL3_FILE), --abl-image)
|
|
|
|
OPT_ABL4_FILE=$(call add_opt_prefix, $(PSP_ABL4_FILE), --abl-image)
|
|
|
|
OPT_ABL5_FILE=$(call add_opt_prefix, $(PSP_ABL5_FILE), --abl-image)
|
|
|
|
OPT_ABL6_FILE=$(call add_opt_prefix, $(PSP_ABL6_FILE), --abl-image)
|
|
|
|
OPT_ABL7_FILE=$(call add_opt_prefix, $(PSP_ABL7_FILE), --abl-image)
|
|
|
|
OPT_WHITELIST_FILE=$(call add_opt_prefix, $(PSP_WHITELIST_FILE), --whitelist)
|
|
|
|
|
2020-05-13 22:01:09 +02:00
|
|
|
OPT_PSP_APCB_FILES=$(foreach i, $(shell seq $(words $(PSP_APCB_FILES))), \
|
|
|
|
$(call add_opt_prefix, $(word $(i), $(PSP_APCB_FILES)), \
|
|
|
|
--instance $(shell printf "%x" $$(($(i)-1))) --apcb ))
|
|
|
|
|
2019-06-19 19:46:06 +02:00
|
|
|
OPT_APOB_ADDR=$(call add_opt_prefix, $(PSP_APOB_BASE), --apob-base)
|
|
|
|
OPT_PSP_BIOSBIN_FILE=$(call add_opt_prefix, $(PSP_BIOSBIN_FILE), --bios-bin)
|
|
|
|
OPT_PSP_BIOSBIN_DEST=$(call add_opt_prefix, $(PSP_BIOSBIN_DEST), --bios-bin-dest)
|
|
|
|
OPT_PSP_BIOSBIN_SIZE=$(call add_opt_prefix, $(PSP_BIOSBIN_SIZE), --bios-uncomp-size)
|
|
|
|
OPT_PSP_PMUI_FILE1=$(call add_opt_prefix, $(PSP_PMUI_FILE1), --subprogram 0 --instance 1 --pmu-inst)
|
|
|
|
OPT_PSP_PMUI_FILE2=$(call add_opt_prefix, $(PSP_PMUI_FILE2), --subprogram 0 --instance 4 --pmu-inst)
|
|
|
|
OPT_PSP_PMUI_FILE3=$(call add_opt_prefix, $(PSP_PMUI_FILE3), --subprogram 1 --instance 1 --pmu-inst)
|
|
|
|
OPT_PSP_PMUI_FILE4=$(call add_opt_prefix, $(PSP_PMUI_FILE4), --subprogram 1 --instance 4 --pmu-inst)
|
|
|
|
OPT_PSP_PMUD_FILE1=$(call add_opt_prefix, $(PSP_PMUD_FILE1), --subprogram 0 --instance 1 --pmu-data)
|
|
|
|
OPT_PSP_PMUD_FILE2=$(call add_opt_prefix, $(PSP_PMUD_FILE2), --subprogram 0 --instance 4 --pmu-data)
|
|
|
|
OPT_PSP_PMUD_FILE3=$(call add_opt_prefix, $(PSP_PMUD_FILE3), --subprogram 1 --instance 1 --pmu-data)
|
|
|
|
OPT_PSP_PMUD_FILE4=$(call add_opt_prefix, $(PSP_PMUD_FILE4), --subprogram 1 --instance 4 --pmu-data)
|
|
|
|
OPT_PSP_UCODE_FILE1=$(call add_opt_prefix, $(PSP_UCODE_FILE1), --instance 0 --ucode)
|
|
|
|
OPT_PSP_UCODE_FILE2=$(call add_opt_prefix, $(PSP_UCODE_FILE2), --instance 1 --ucode)
|
|
|
|
OPT_PSP_UCODE_FILE3=$(call add_opt_prefix, $(PSP_UCODE_FILE3), --instance 2 --ucode)
|
|
|
|
OPT_MP2CFG_FILE=$(call add_opt_prefix, $(PSP_MP2CFG_FILE), --mp2-config)
|
2019-04-22 22:55:16 +02:00
|
|
|
|
2020-05-13 22:01:09 +02:00
|
|
|
# Copy prebuild APCBs if they exist
|
|
|
|
$(obj)/APCB_%.bin: $(MAINBOARD_BLOBS_DIR)/APCB_%.bin
|
|
|
|
cp $< $@
|
|
|
|
|
|
|
|
# APCB binary with magic numbers to be replaced by apcb_edit tool
|
2020-05-26 19:34:05 +02:00
|
|
|
APCB_MAGIC_BLOB:=$(FIRMWARE_LOCATE)/APCB_magic.bin
|
2020-05-13 22:01:09 +02:00
|
|
|
|
|
|
|
$(obj)/APCB_empty.bin: $(APCB_MAGIC_BLOB) $(APCB_EDIT_TOOL)
|
|
|
|
$(APCB_EDIT_TOOL) \
|
|
|
|
$(APCB_MAGIC_BLOB) \
|
|
|
|
$@ \
|
|
|
|
--board_id_gpio0 $(APCB_BOARD_ID_GPIO0) \
|
|
|
|
--board_id_gpio1 $(APCB_BOARD_ID_GPIO1) \
|
|
|
|
--board_id_gpio2 $(APCB_BOARD_ID_GPIO2) \
|
|
|
|
--board_id_gpio3 $(APCB_BOARD_ID_GPIO3)
|
|
|
|
|
|
|
|
$(obj)/APCB_%_x1.bin: $$(SPD_SOURCES_DIR)/%.spd.hex \
|
|
|
|
$(APCB_EDIT_TOOL) \
|
|
|
|
$(APCB_MAGIC_BLOB)
|
|
|
|
$(APCB_EDIT_TOOL) \
|
|
|
|
$(APCB_MAGIC_BLOB) \
|
|
|
|
$@ \
|
|
|
|
--hex \
|
|
|
|
--spd_0_0 $< \
|
|
|
|
--board_id_gpio0 $(APCB_BOARD_ID_GPIO0) \
|
|
|
|
--board_id_gpio1 $(APCB_BOARD_ID_GPIO1) \
|
|
|
|
--board_id_gpio2 $(APCB_BOARD_ID_GPIO2) \
|
|
|
|
--board_id_gpio3 $(APCB_BOARD_ID_GPIO3)
|
|
|
|
|
|
|
|
$(obj)/APCB_%_x2.bin: $$(SPD_SOURCES_DIR)/%.spd.hex \
|
|
|
|
$(APCB_EDIT_TOOL) \
|
|
|
|
$(APCB_MAGIC_BLOB)
|
|
|
|
$(APCB_EDIT_TOOL) \
|
|
|
|
$(APCB_MAGIC_BLOB) \
|
|
|
|
$@ \
|
|
|
|
--hex \
|
|
|
|
--spd_0_0 $< \
|
|
|
|
--spd_1_0 $< \
|
|
|
|
--board_id_gpio0 $(APCB_BOARD_ID_GPIO0) \
|
|
|
|
--board_id_gpio1 $(APCB_BOARD_ID_GPIO1) \
|
|
|
|
--board_id_gpio2 $(APCB_BOARD_ID_GPIO2) \
|
|
|
|
--board_id_gpio3 $(APCB_BOARD_ID_GPIO3)
|
|
|
|
|
2019-06-11 20:34:04 +02:00
|
|
|
$(obj)/amdfw.rom: $(call strip_quotes, $(CONFIG_AMD_PUBKEY_FILE)) \
|
2019-04-22 22:55:16 +02:00
|
|
|
$(call strip_quotes, $(PSPBTLDR_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSPSCUREOS_FILE)) \
|
2019-06-19 19:46:06 +02:00
|
|
|
$(call strip_quotes, $(PSP_SEC_DBG_KEY_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_BIOSBIN_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUI_FILE1)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUI_FILE2)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUI_FILE3)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUI_FILE4)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUD_FILE1)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUD_FILE2)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUD_FILE3)) \
|
|
|
|
$(call strip_quotes, $(PSP_PMUD_FILE4)) \
|
|
|
|
$(call strip_quotes, $(PSP_UCODE_FILE1)) \
|
|
|
|
$(call strip_quotes, $(PSP_UCODE_FILE2)) \
|
|
|
|
$(call strip_quotes, $(PSP_UCODE_FILE3)) \
|
|
|
|
$(call strip_quotes, $(PSP_MP2CFG_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SMUFW1_SUB1_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SMUFW1_SUB2_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SMUFW2_SUB1_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SMUFW2_SUB2_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL0_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL1_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL2_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL3_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL4_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL5_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL6_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_ABL7_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_WHITELIST_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SECG1_FILE)) \
|
|
|
|
$(call strip_quotes, $(PSP_SECG2_FILE)) \
|
|
|
|
$(call_strip_quotes, $(PSP_DRIVERS_FILE)) \
|
|
|
|
$(call_strip_quotes, $(PSP_S0I3_FILE)) \
|
|
|
|
$(call_strip_quotes, $(PSP_IKEK_FILE)) \
|
|
|
|
$(call_strip_quotes, $(PSP_SEC_DEBUG_FILE)) \
|
2020-05-13 22:01:09 +02:00
|
|
|
$$(PSP_APCB_FILES) \
|
2020-01-21 03:56:30 +01:00
|
|
|
$(AMDFWTOOL) \
|
|
|
|
$(obj)/fmap.fmd
|
2019-04-22 22:55:16 +02:00
|
|
|
rm -f $@
|
|
|
|
@printf " AMDFWTOOL $(subst $(obj)/,,$(@))\n"
|
|
|
|
$(AMDFWTOOL) \
|
|
|
|
$(OPT_AMD_PUBKEY_FILE) \
|
|
|
|
$(OPT_PSPBTLDR_FILE) \
|
|
|
|
$(OPT_PSPSCUREOS_FILE) \
|
2019-06-19 19:46:06 +02:00
|
|
|
$(OPT_PSP_SEC_DBG_KEY_FILE) \
|
|
|
|
$(OPT_SMUFW1_SUB2_FILE) \
|
|
|
|
$(OPT_SMUFW2_SUB2_FILE) \
|
|
|
|
$(OPT_SMUFW1_SUB1_FILE) \
|
|
|
|
$(OPT_SMUFW2_SUB1_FILE) \
|
2020-05-13 22:01:09 +02:00
|
|
|
$(OPT_PSP_APCB_FILES) \
|
2019-06-19 19:46:06 +02:00
|
|
|
$(OPT_APOB_ADDR) \
|
2020-01-21 03:56:30 +01:00
|
|
|
--apob-nv-size $(shell printf "0x%x" \
|
|
|
|
$(shell cat $(obj)/fmap.fmd | $(_GET_APOBNV_SIZE))) \
|
|
|
|
--apob-nv-base $(shell printf "0x%x" $(call int-add, \
|
|
|
|
$(shell cat $(obj)/fmap.fmd | $(_GET_FLASH_BASE)) \
|
|
|
|
$(shell cat $(obj)/fmap.fmd | $(_GET_BIOS_REG_BASE)) \
|
|
|
|
$(shell cat $(obj)/fmap.fmd | $(_GET_APOBNV_BASE)))) \
|
2019-06-19 19:46:06 +02:00
|
|
|
$(OPT_PSP_BIOSBIN_FILE) \
|
|
|
|
$(OPT_PSP_BIOSBIN_DEST) \
|
|
|
|
$(OPT_PSP_BIOSBIN_SIZE) \
|
|
|
|
$(OPT_PSP_SOFTFUSE) \
|
|
|
|
$(OPT_PSP_PMUI_FILE1) \
|
|
|
|
$(OPT_PSP_PMUI_FILE2) \
|
|
|
|
$(OPT_PSP_PMUI_FILE3) \
|
|
|
|
$(OPT_PSP_PMUI_FILE4) \
|
|
|
|
$(OPT_PSP_PMUD_FILE1) \
|
|
|
|
$(OPT_PSP_PMUD_FILE2) \
|
|
|
|
$(OPT_PSP_PMUD_FILE3) \
|
|
|
|
$(OPT_PSP_PMUD_FILE4) \
|
|
|
|
$(OPT_PSP_UCODE_FILE1) \
|
|
|
|
$(OPT_PSP_UCODE_FILE2) \
|
|
|
|
$(OPT_PSP_UCODE_FILE3) \
|
|
|
|
$(OPT_MP2CFG_FILE) \
|
|
|
|
$(OPT_ABL0_FILE) \
|
|
|
|
$(OPT_ABL1_FILE) \
|
|
|
|
$(OPT_ABL2_FILE) \
|
|
|
|
$(OPT_ABL3_FILE) \
|
|
|
|
$(OPT_ABL4_FILE) \
|
|
|
|
$(OPT_ABL5_FILE) \
|
|
|
|
$(OPT_ABL6_FILE) \
|
|
|
|
$(OPT_ABL7_FILE) \
|
|
|
|
$(OPT_WHITELIST_FILE) \
|
|
|
|
$(OPT_SECG1_FILE) \
|
|
|
|
$(OPT_SECG2_FILE) \
|
|
|
|
$(OPT_MP2FW1_FILE) \
|
|
|
|
$(OPT_MP2FW2_FILE) \
|
|
|
|
$(OPT_DRIVERS_FILE) \
|
|
|
|
$(OPT_PSP_S0I3_FILE) \
|
|
|
|
$(OPT_IKEK_FILE) \
|
|
|
|
$(OPT_SEC_DEBUG_FILE) \
|
2019-04-22 22:55:16 +02:00
|
|
|
--combo-capable \
|
2020-04-25 00:52:04 +02:00
|
|
|
$(OPT_TOKEN_UNLOCK) \
|
2019-04-22 22:55:16 +02:00
|
|
|
--flashsize $(CONFIG_ROM_SIZE) \
|
2019-06-11 20:18:20 +02:00
|
|
|
--location $(shell printf "0x%x" $(PICASSO_FWM_POSITION)) \
|
2019-04-22 22:55:16 +02:00
|
|
|
--output $@
|
|
|
|
|
2020-04-04 02:37:04 +02:00
|
|
|
$(PSP_BIOSBIN_FILE): $(PSP_ELF_FILE) $(AMDCOMPRESS)
|
2019-06-19 19:46:06 +02:00
|
|
|
rm -f $@
|
|
|
|
@printf " AMDCOMPRS $(subst $(obj)/,,$(@))\n"
|
2020-04-04 02:37:04 +02:00
|
|
|
$(AMDCOMPRESS) --infile $(PSP_ELF_FILE) --outfile $@ --compress \
|
2019-06-19 19:46:06 +02:00
|
|
|
--maxsize $(PSP_BIOSBIN_SIZE)
|
|
|
|
|
2019-04-22 22:55:16 +02:00
|
|
|
ifeq ($(CONFIG_AMDFW_OUTSIDE_CBFS),y)
|
|
|
|
PHONY+=add_amdfw
|
|
|
|
INTERMEDIATE+=add_amdfw
|
|
|
|
|
|
|
|
# Calculate firmware position inside the ROM
|
2019-06-11 20:18:20 +02:00
|
|
|
PICASSO_FWM_ROM_POSITION=$(call int-add, \
|
2019-04-22 22:55:16 +02:00
|
|
|
$(call int-subtract, $(CONFIG_ROM_SIZE) \
|
|
|
|
$(call int-shift-left, \
|
|
|
|
0x80000 $(CONFIG_AMD_FWM_POSITION_INDEX))) 0x20000)
|
|
|
|
|
|
|
|
add_amdfw: $(obj)/coreboot.pre $(obj)/amdfw.rom
|
|
|
|
printf " DD Adding AMD Firmware at ROM offset 0x%x\n" \
|
2019-06-11 20:18:20 +02:00
|
|
|
"$(PICASSO_FWM_ROM_POSITION)"
|
2019-06-19 19:46:06 +02:00
|
|
|
dd oflag=seek_bytes \
|
|
|
|
if=$(obj)/amdfw.rom \
|
|
|
|
of=$(obj)/coreboot.pre conv=notrunc \
|
2019-06-11 20:18:20 +02:00
|
|
|
seek=$(PICASSO_FWM_ROM_POSITION) >/dev/null 2>&1
|
2019-04-22 22:55:16 +02:00
|
|
|
|
|
|
|
else # ifeq ($(CONFIG_AMDFW_OUTSIDE_CBFS),y)
|
|
|
|
|
|
|
|
cbfs-files-y += apu/amdfw
|
|
|
|
apu/amdfw-file := $(obj)/amdfw.rom
|
2019-06-11 20:18:20 +02:00
|
|
|
apu/amdfw-position := $(PICASSO_FWM_POSITION)
|
2019-04-22 22:55:16 +02:00
|
|
|
apu/amdfw-type := raw
|
|
|
|
|
|
|
|
endif # ifeq ($(CONFIG_AMDFW_OUTSIDE_CBFS),y)
|
|
|
|
|
2019-04-23 00:08:31 +02:00
|
|
|
endif # ($(CONFIG_SOC_AMD_PICASSO),y)
|