public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
* [edk2-devel] [PATCH edk2-non-osi 0/1] Qemu/Sbsa: Update TF-A binaries
@ 2023-09-20 11:44 Marcin Juszkiewicz
  2023-09-20 11:44 ` [edk2-devel] [PATCH edk2-non-osi 1/1] " Marcin Juszkiewicz
  2023-09-20 19:26 ` [edk2-devel] [PATCH edk2-non-osi 0/1] " Leif Lindholm
  0 siblings, 2 replies; 3+ messages in thread
From: Marcin Juszkiewicz @ 2023-09-20 11:44 UTC (permalink / raw)
  To: devel; +Cc: Leif Lindholm, Ard Biesheuvel, Graeme Gregory, Marcin Juszkiewicz

Update the TF-A binaries to have:

- fixed FIP size
- Neoverse-N2 cpu support

This support was merged into TF-A:
https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23417
(align FIP base to BL1 size)
https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23409
(add "neoverse-n2" cpu support)

FIP size was too small to fit TF-A debug builds with RME (WIP) support
enabled. We need it to merge fixed FIP size in EDK2-platforms.

CPU enablement allows SBSA Reference Platform to boot Linux on
"neoverse-n2" cpu.

Marcin Juszkiewicz (1):
  Qemu/Sbsa: Update TF-A binaries

 Platform/Qemu/Sbsa/License.txt |   2 +-
 Platform/Qemu/Sbsa/Readme.md   |  52 ++++++++++++++++++++++++---------
 Platform/Qemu/Sbsa/bl1.bin     | Bin 19557 -> 22933 bytes
 Platform/Qemu/Sbsa/fip.bin     | Bin 66338 -> 82722 bytes
 4 files changed, 40 insertions(+), 14 deletions(-)

-- 
2.41.0



-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#108906): https://edk2.groups.io/g/devel/message/108906
Mute This Topic: https://groups.io/mt/101476431/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



^ permalink raw reply	[flat|nested] 3+ messages in thread

* [edk2-devel] [PATCH edk2-non-osi 1/1] Qemu/Sbsa: Update TF-A binaries
  2023-09-20 11:44 [edk2-devel] [PATCH edk2-non-osi 0/1] Qemu/Sbsa: Update TF-A binaries Marcin Juszkiewicz
@ 2023-09-20 11:44 ` Marcin Juszkiewicz
  2023-09-20 19:26 ` [edk2-devel] [PATCH edk2-non-osi 0/1] " Leif Lindholm
  1 sibling, 0 replies; 3+ messages in thread
From: Marcin Juszkiewicz @ 2023-09-20 11:44 UTC (permalink / raw)
  To: devel; +Cc: Leif Lindholm, Ard Biesheuvel, Graeme Gregory, Marcin Juszkiewicz

Update the TF-A binaries to have:

- fixed FIP size
- Neoverse-N2 cpu support

This support was merged into TF-A:
https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23417
(align FIP base to BL1 size)
https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23409
(add "neoverse-n2" cpu support)

FIP size was too small to fit TF-A debug builds with RME (WIP) support
enabled.

CPU enablement allows SBSA Reference Platform to boot Linux on
"neoverse-n2" cpu.

Signed-off-by: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org>
---
 Platform/Qemu/Sbsa/License.txt |   2 +-
 Platform/Qemu/Sbsa/Readme.md   |  52 ++++++++++++++++++++++++---------
 Platform/Qemu/Sbsa/bl1.bin     | Bin 19557 -> 22933 bytes
 Platform/Qemu/Sbsa/fip.bin     | Bin 66338 -> 82722 bytes
 4 files changed, 40 insertions(+), 14 deletions(-)

diff --git a/Platform/Qemu/Sbsa/License.txt b/Platform/Qemu/Sbsa/License.txt
index 6be66733e482..02cff6b1d867 100644
--- a/Platform/Qemu/Sbsa/License.txt
+++ b/Platform/Qemu/Sbsa/License.txt
@@ -1,4 +1,4 @@
-Copyright (c) 2020, Linaro Ltd. All rights reserved.
+Copyright (c) Linaro Ltd. All rights reserved.
 
 Redistribution and use in source and binary forms, with or without
 modification, are permitted provided that the following conditions
diff --git a/Platform/Qemu/Sbsa/Readme.md b/Platform/Qemu/Sbsa/Readme.md
index 20a471452685..b8759403bf05 100644
--- a/Platform/Qemu/Sbsa/Readme.md
+++ b/Platform/Qemu/Sbsa/Readme.md
@@ -4,29 +4,55 @@ Qemu SBSA TF-A binaries
 These binaries have been created from the mainline TF-A
 code checked out at the following commit ID:
 
-commit 2503c8f3204c60013de8caa2e165b2875ad735e5 (HEAD -> master, origin/master, origin/HEAD)
-Merge: 9b81d117b bd596a101
-Author: Bipin Ravi <bipin.ravi@arm.com>
-Date:   Thu Jul 13 16:45:54 2023 +0200
+commit 84de50c7d8ca416e504aedb228bb4cab6eed806f (HEAD -> master, origin/master, origin/integration, origin/HEAD)
+Merge: 1e038c94d 4796d2d9b
+Author: Olivier Deprez <olivier.deprez@arm.com>
+Date:   Tue Sep 19 18:15:12 2023 +0200
 
-    Merge "build(fpga): remove a710 from fpga build" into integration
+    Merge "feat(ethos-n): update npu error handling" into integration
 
 
-This ensures that the following feature for qemu_sbsa platform is
-merged upstream and is included in the build:
+This ensures that the following features for qemu_sbsa platform are
+merged upstream and included in the build:
 
-commit 214de62c92b2fc4b7edda9d9d637b7a4c0ba1fa5
+commit 408cde8a59080ac2caa11c4d99474b2ef09f90df
 Author: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org>
-Date:   Tue Jul 4 15:41:40 2023 +0200
+Date:   Mon Sep 18 12:47:45 2023 +0200
 
-    feat(qemu): add "neoverse-v1" cpu support
+    fix(qemu_sbsa): align FIP base to BL1 size
 
-    Add support to qemu "neoverse-v1" cpu for "qemu_sbsa" ('sbsa-ref')
-    platform.
+    RME patch series shown that we can build larger BL1 than we can run:
 
-    Change-Id: Id710e2b960e7938d2dbe7a88d9e158a7009fc3d1
+    NOTICE:  Booting Trusted Firmware
+    NOTICE:  BL1: v2.9(debug):v2.9.0-736-g08548888a
+    NOTICE:  BL1: Built : 12:10:39, Sep 18 2023
+    INFO:    BL1: RAM 0x3ffee000 - 0x3fffb000
+    INFO:    BL1: Loading BL2
+    WARNING: Firmware Image Package header check failed.
+
+    RME pushed debug build BL1 over 0x8000 in size.
+    This exposed an error where FIP_BASE (supposed to be at BL1_SIZE offset
+    from start of flash) was actually 0x8000 and not 0x12000.
+    Make sure we have space for BL1 by deriving FIP_BASE from it.
+
+    Note: this is a breaking change for edk2 FD image generation, which had
+    similarly hardcoded a 0x8000 offset. These images must be updated in
+    lock-step.
+
+    Change-Id: I8a1a85e82319945a4412c424467d818d5b6e4ecd
     Signed-off-by: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org>
 
+commit 408f9cb485796a73c5b87da70644665a13c685e4
+Author: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org>
+Date:   Fri Sep 15 22:44:04 2023 +0200
+
+    feat(qemu): add "neoverse-n2" cpu support
+
+    Add support to qemu "neoverse-n2" cpu for "qemu" platform.
+    This one has 2^48 address space so will be used by both systems.
+
+    Signed-off-by: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org>
+    Change-Id: I9f0fa23a4934d9464379495225e08adc121325b4
 
 NOTE: No modifications to the source code have been done.
       The binaries have been generated for the AARCH64 platform
diff --git a/Platform/Qemu/Sbsa/bl1.bin b/Platform/Qemu/Sbsa/bl1.bin
index 3cdd7495e105e7d55311e5c1d3c98bcbab8f8e0e..22875fe6fc7b471c909fa25f0e57bfd763eec991 100755
GIT binary patch
delta 10063
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
Co{}B_

delta 4805
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

diff --git a/Platform/Qemu/Sbsa/fip.bin b/Platform/Qemu/Sbsa/fip.bin
index e1cba08014ca2bebe36218446e66dfdb99f57a5b..ed39152c684314d36f1734ba223e35be3b67835f 100644
GIT binary patch
delta 19258
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
JHQF{v{~HK@Z%_aL

delta 13004
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
UH}!8WmmkREw};SH8}ae~12UJFO8@`>

-- 
2.41.0



-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#108907): https://edk2.groups.io/g/devel/message/108907
Mute This Topic: https://groups.io/mt/101476433/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [edk2-devel] [PATCH edk2-non-osi 0/1] Qemu/Sbsa: Update TF-A binaries
  2023-09-20 11:44 [edk2-devel] [PATCH edk2-non-osi 0/1] Qemu/Sbsa: Update TF-A binaries Marcin Juszkiewicz
  2023-09-20 11:44 ` [edk2-devel] [PATCH edk2-non-osi 1/1] " Marcin Juszkiewicz
@ 2023-09-20 19:26 ` Leif Lindholm
  1 sibling, 0 replies; 3+ messages in thread
From: Leif Lindholm @ 2023-09-20 19:26 UTC (permalink / raw)
  To: devel, marcin.juszkiewicz; +Cc: Ard Biesheuvel, Graeme Gregory

On Wed, Sep 20, 2023 at 13:44:22 +0200, Marcin Juszkiewicz wrote:
> Update the TF-A binaries to have:
> 
> - fixed FIP size
> - Neoverse-N2 cpu support
> 
> This support was merged into TF-A:
> https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23417
> (align FIP base to BL1 size)
> https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/23409
> (add "neoverse-n2" cpu support)
> 
> FIP size was too small to fit TF-A debug builds with RME (WIP) support
> enabled. We need it to merge fixed FIP size in EDK2-platforms.
> 
> CPU enablement allows SBSA Reference Platform to boot Linux on
> "neoverse-n2" cpu.

Tweaked the commit message slightly and pushed as cac013780ae1.
Thanks!

/
    Leif

> Marcin Juszkiewicz (1):
>   Qemu/Sbsa: Update TF-A binaries
> 
>  Platform/Qemu/Sbsa/License.txt |   2 +-
>  Platform/Qemu/Sbsa/Readme.md   |  52 ++++++++++++++++++++++++---------
>  Platform/Qemu/Sbsa/bl1.bin     | Bin 19557 -> 22933 bytes
>  Platform/Qemu/Sbsa/fip.bin     | Bin 66338 -> 82722 bytes
>  4 files changed, 40 insertions(+), 14 deletions(-)
> 
> -- 
> 2.41.0
> 
> 
> 
> 
> 
> 


-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#108927): https://edk2.groups.io/g/devel/message/108927
Mute This Topic: https://groups.io/mt/101476431/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/leave/12367111/7686176/1913456212/xyzzy [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2023-09-20 19:26 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-09-20 11:44 [edk2-devel] [PATCH edk2-non-osi 0/1] Qemu/Sbsa: Update TF-A binaries Marcin Juszkiewicz
2023-09-20 11:44 ` [edk2-devel] [PATCH edk2-non-osi 1/1] " Marcin Juszkiewicz
2023-09-20 19:26 ` [edk2-devel] [PATCH edk2-non-osi 0/1] " Leif Lindholm

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox