Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Changes for Heads on NovaCustom V560TU #609

Merged
merged 15 commits into from
Jan 17, 2025
Merged

Changes for Heads on NovaCustom V560TU #609

merged 15 commits into from
Jan 17, 2025

Conversation

mkopec
Copy link
Member

@mkopec mkopec commented Jan 15, 2025

  • Fix building with FSP from dasharo-blobs
  • Add PR0 lockdown in SMM
  • Enable S3 on MTL
  • Fixes for HAP on MTL
  • Always pull FSP submodule, to ensure SplitFspBin is present
  • Move IOE_P2SB below 4G to reduce MTRR fragmentation (faster boot on 64 and 96 GB RAM configs)
  • Always put I2C and framebuffer below 4G when built for IA32, to make sure we can use them in coreboot
  • Fix for FSP GOP not initializing if an external display with res < 1920x1200 is connected
  • JPEG patches for bootsplash, previously maintaned downstream in Heads

mkopec and others added 7 commits January 15, 2025 17:01
In a server platform many silicon specific register lock operations
are by default in FSP space. CHIPSET_LOCKDOWN_FSP provides an option
to make sure the codes could be used out-of-box to build products.

Change-Id: I8efcc1f27446be8e35f51e2568c4af6f8165486b
Signed-off-by: Shuo Liu <[email protected]>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/82081
Reviewed-by: Angel Pons <[email protected]>
Tested-by: build bot (Jenkins) <[email protected]>
Reviewed-by: Patrick Rudolph <[email protected]>
Heads payload uses APM_CNT_FINALIZE SMI to set and lock down the SPI
controller with PR0 flash protection for pre-Skylake platforms.

Add new option to skip LPC and FAST SPI lock down in coreboot and move
it to APM_CNT_FINALIZE SMI handler. Reuse the INTEL_CHIPSET_LOCKDOWN
option to prevent issuing APM_CNT_FINALIZE SMI on normal boot path,
like it was done on pre-Skylake platforms. As the locking on modern
SOCs became more complicated, separate the SPI and LPC locking into
new modules to make linking to SMM easier.

The expected configuration to leverage the feautre is to unselect
INTEL_CHIPSET_LOCKDOWN and select SOC_INTEL_COMMON_SPI_LOCKDOWN_SMM.

Testing various microarchitectures happens on heads repository:
linuxboot/heads#1818

TEST=Lock the SPI flash using APM_CNT_FINALIZE in heads on Alder Lake
(Protectli VP66xx) and Comet Lake (Protectli VP46xx) platforms. Check
if flash is unlocked in the heads recovery console. Check if flash is
locked in the kexec'ed OS.

Change-Id: Icbcc6fcde90e5b0a999aacb720e2e3dc2748c838
Signed-off-by: Michał Żygowski <[email protected]>
@macpijan macpijan requested a review from miczyg1 January 15, 2025 16:06
@mkopec
Copy link
Member Author

mkopec commented Jan 15, 2025

Should go in before linuxboot/heads#1846

Copy link
Contributor

@miczyg1 miczyg1 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While we are at limiting the necessary resources to 32bit, can you please limit it on the CSE HECI device as well? That way the allocation could work also for other builds than heads, where ME is active.

src/soc/intel/common/block/graphics/graphics.c Outdated Show resolved Hide resolved
src/soc/intel/meteorlake/Kconfig Show resolved Hide resolved
src/soc/intel/meteorlake/include/soc/iomap.h Show resolved Hide resolved
@mkopec
Copy link
Member Author

mkopec commented Jan 16, 2025

While we are at limiting the necessary resources to 32bit, can you please limit it on the CSE HECI device as well? That way the allocation could work also for other builds than heads, where ME is active.

Done 5a313c7 (builds, but untested on a platform with ME enabled)

Without this patch, if RESOURCE_ALLOCATION_TOP_DOWN is enabled and
coreboot is compiled for IA32, the HECI device becomes inaccessible
after resource allocation.

Signed-off-by: Michał Kopeć <[email protected]>
@mkopec
Copy link
Member Author

mkopec commented Jan 16, 2025

@miczyg1 can you take another look?

mkopec and others added 4 commits January 16, 2025 12:59
This frees up two MTRRs for SPI flash caching

IOM_BASE_ADDR has to be hardcoded, otherwise iasl throws an error while
building

```
dsdt.asl   1374:     0x1600,,,)
Error    6050 -          ^ Length is not equal to fixed Min/Max window
```

It seems like IASL can't perform arithmetic operations inside
QWordMemory definitions.

See https://review.coreboot.org/c/coreboot/+/84216

Signed-off-by: Michał Kopeć <[email protected]>
Since commit 1d029b4 ("lib/jpeg: Replace decoder with Wuffs'
implementation"), a relatively large heap allocation is needed to decode
many JPEGs for use as work area. The prior decoder did not need this,
but also had many limitations in the JPEGs it could decode, was not as
memory-safe and quickly crashed under fuzzing.

This commit keeps using Wuffs' JPEG decoder, but it no longer requires
any heap allocation (and thus configuring the heap size depending on how
big a bootsplash image you want to support).

Change-Id: Ie4c52520cbce498539517c4898ff765365a6beba
Signed-off-by: Nigel Tao <[email protected]>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/83895
Tested-by: build bot (Jenkins) <[email protected]>
Reviewed-by: Nico Huber <[email protected]>
Reviewed-by: Felix Singer <[email protected]>
Reviewed-by: Jonathon Hall <[email protected]>
We were previously at Wuffs 0.4.0-alpha.2. The C file was copied from
https://github.com/google/wuffs-mirror-release-c and its hash matches
https://github.com/google/wuffs-mirror-release-c/blob/90e4d81a6a8b7b601e8e568da32a105d7f7705e5/sync.txt#L9-L10

$ sha256sum src/vendorcode/wuffs/wuffs-v0.4.c
6c22caff4af929112601379a73f72461bc4719a5215366bcc90d599cbc442bb6  src/vendorcode/wuffs/wuffs-v0.4.c

Change-Id: Ie90d989384e0db2b23d7d1b3d9a57920ac8a95a2
Signed-off-by: Nigel Tao <[email protected]>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/83894
Reviewed-by: Felix Singer <[email protected]>
Reviewed-by: Nico Huber <[email protected]>
Tested-by: build bot (Jenkins) <[email protected]>
@miczyg1 miczyg1 merged commit 048ca83 into dasharo Jan 17, 2025
55 checks passed
@miczyg1 miczyg1 deleted the mtl_heads branch January 17, 2025 11:57
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants