Commit graph

16550 commits

Author SHA1 Message Date
Lauren Wehrmeister
e83738c074 Merge "fix(bl1): prevent null pointer dereference" into integration 2025-04-02 22:29:24 +02:00
Yann Gautier
0c9b38b61b Merge "fix(tools): change data type to size_t for doimage" into integration 2025-04-02 09:30:33 +02:00
Govindraj Raja
aac3e34f62 Merge changes I2c33105f,I010b3932 into integration
* changes:
  feat(stm32mp25-fdts): update 2GB DDR configs
  feat(stm32mp25-fdts): enable WDQS for LPDDR4
2025-04-01 18:38:42 +02:00
Manish V Badarkhe
2d3b44e307 fix(bl1): prevent null pointer dereference
Added an assertion to ensure ptr is not NULL before
dereferencing it. This prevents potential null pointer
dereference issues detected by Coverity.

Change-Id: I2e3325cd7cbdf141959bacd6135461be24ae6169
Signed-off-by: Manish V Badarkhe <Manish.Badarkhe@arm.com>
2025-04-01 17:33:12 +01:00
Jaiprakash Singh
fbf6555790 fix(tools): change data type to size_t for doimage
In image_encrypt function, vulnerability arises
due to a mismatch between unsigned and signed
integer types. When a large unsigned integer
is returned by strlen and stored into signed
integer k, the value represented is a large
negative integer. This bypasses the subsequent
check against AES_BLOCK_SZ and allows a buffer
overflow to happen at memcpy.

Similar, vulnerability issue is fixed in
function verify_and_copy_file_name_entry.

Change-Id: I658521c1eec1c79933ba8082ba507df04d174e52
Signed-off-by: Jaiprakash Singh <jaiprakashs@marvell.com>
2025-04-01 18:19:45 +02:00
Nicolas Le Bayon
388cb47cf0 feat(stm32mp25-fdts): update 2GB DDR configs
Update the 2GB LpDDR4 and DDR4 DT settings.

Signed-off-by: Nicolas Le Bayon <nicolas.le.bayon@foss.st.com>
Change-Id: I2c33105f31364ff15a66a0749b2400dd69db33e3
2025-04-01 17:09:03 +02:00
Nicolas Le Bayon
29917d3a12 feat(stm32mp25-fdts): enable WDQS for LPDDR4
Enable WDQS extension mode requested by some device manufacturers.
No impact on other devices.

Signed-off-by: Nicolas Le Bayon <nicolas.le.bayon@foss.st.com>
Change-Id: I010b3932dd363c03e34b879fd68adae6dd28c27a
2025-04-01 17:05:14 +02:00
Govindraj Raja
811b8b47fb Merge "feat(st-pmic): add defines for NVM shadow registers" into integration 2025-04-01 16:02:51 +02:00
Manish V Badarkhe
e87e13c15b Merge "feat(fvp): give bootargs on all configs" into integration 2025-04-01 14:19:23 +02:00
Joanna Farley
069232f553 Merge "feat(versal2): is OCM configured as coherent" into integration 2025-04-01 13:34:16 +02:00
Boerge Struempfel
c1222e7b8e
feat(st-pmic): add defines for NVM shadow registers
Change-Id: I28e194fbec7c7879bbbf46c602dc4587d74e31e9
Signed-off-by: Boerge Struempfel <boerge.struempfel@gmail.com>
2025-04-01 12:21:59 +02:00
Joanna Farley
376e3e8c92 Merge changes from topic "versal2-qemu" into integration
* changes:
  fix(versal2): align QEMU APU GT frequency with silicon
  fix(zynqmp): fix syscnt frequency for QEMU
2025-04-01 08:57:57 +02:00
Bipin Ravi
1eb8983f6f Merge "fix(cpus): remove errata setting PF_MODE to conservative" into integration 2025-03-31 22:26:03 +02:00
Govindraj Raja
c997a8deab Merge changes from topic "jc/tc_fw_handoff" into integration
* changes:
  refactor(arm): simplify early platform setup function in BL31
  refactor(arm): simplify early platform setup function in BL2
  feat(arm): add support for Transfer List creation
2025-03-31 20:33:44 +02:00
Yann Gautier
e86efe4b14 Merge changes I1dfb95aa,I9eb61c48 into integration
* changes:
  feat(intel): support FCS commands with SiPSVC V3 framework
  feat(intel): implementation of SiPSVC-V3 protocol framework
2025-03-31 19:16:19 +02:00
Jayanth Dodderi Chidanand
b6e6e2e610 refactor(arm): simplify early platform setup function in BL31
Refactor `arm_bl31_early_platform_setup` to accept generic u_register_t
values, enabling support for firmware handoff boot arguments in
common code. This simplifies the interface for early platform setup.

Signed-off-by: Jayanth Dodderi Chidanand <jayanthdodderi.chidanand@arm.com>
Change-Id: Iff20300d2372e1a9825827ddccbd1b3bc6751e40
2025-03-31 17:24:42 +01:00
Jayanth Dodderi Chidanand
8187b95ec0 refactor(arm): simplify early platform setup function in BL2
Refactor `arm_bl2_early_platform_setup` to accept generic u_register_t
values, enabling support for firmware handoff boot arguments in
common code. This simplifies the interface for early platform setup.

Signed-off-by: Jayanth Dodderi Chidanand <jayanthdodderi.chidanand@arm.com>
Change-Id: Ie0dbe4d32bbef22bd185fdafe50091a2ea5f550f
2025-03-31 16:45:35 +01:00
Jayanth Dodderi Chidanand
4c5ccbf43c feat(arm): add support for Transfer List creation
This patch introduces Firmware Handoff support for Arm based
platforms listed under Firmware_Handoff specification.
[https://firmwarehandoff.github.io/firmware_handoff/main/transfer_list.html]

Signed-off-by: Jayanth Dodderi Chidanand <jayanthdodderi.chidanand@arm.com>
Change-Id: Ie3f30ffe38f809db907b663a8dbf1e48944ec690
2025-03-31 16:45:35 +01:00
Govindraj Raja
a4d8012f41 Merge "refactor: report features supported to secure world" into integration 2025-03-31 16:28:55 +02:00
Yann Gautier
952f1f4aca Merge "fix(nxp-tools): fix2 create_pbl buildroot build" into integration 2025-03-31 11:52:01 +02:00
Govindraj Raja
ac9f4b4da6 fix(cpus): remove errata setting PF_MODE to conservative
The erratum titled “Disabling of data prefetcher with outstanding
prefetch TLB miss might cause a deadlock” should not be handled within
TF-A. The current workaround attempts to follow option 2 but
misapplies it. Specifically, it statically sets PF_MODE to
conservative, which is not the recommended approach. According to the
erratum documentation, PF_MODE should be configured in conservative
mode only when we disable data prefetcher however this is not done
in TF-A and thus the workaround is not needed in TF-A.

The static setting of PF_MODE in TF-A does not correctly address the
erratum and may introduce unnecessary performance degradation on
platforms that adopt it without fully understanding its implications.

To prevent incorrect or unintended use, the current implementation of
this erratum workaround should be removed from TF-A and not adopted by
platforms.

List of Impacted CPU's with Errata Numbers and reference to SDEN -

Cortex-A78  - 2132060 - https://developer.arm.com/documentation/SDEN1401784/latest
Cortex-A78C - 2132064 - https://developer.arm.com/documentation/SDEN-2004089/latest
Cortex-A710 - 2058056 - https://developer.arm.com/documentation/SDEN-1775101/latest
Cortex-X2   - 2058056 - https://developer.arm.com/documentation/SDEN-1775100/latest
Cortex-X3   - 2070301 - https://developer.arm.com/documentation/SDEN2055130/latest
Neoverse-N2 - 2138953 - https://developer.arm.com/documentation/SDEN-1982442/latest
Neoverse-V1 - 2108267 - https://developer.arm.com/documentation/SDEN-1401781/latest
Neoverse-V2 - 2331132 - https://developer.arm.com/documentation/SDEN-2332927/latest

Change-Id: Icf4048508ae070b2df073cc46c63be058b2779df
Signed-off-by: Govindraj Raja <govindraj.raja@arm.com>
2025-03-31 01:00:27 +01:00
Luc Michel
f7a380e23c fix(versal2): align QEMU APU GT frequency with silicon
The APU generic timer frequency in QEMU is now aligned on silicon to the
value of 100MHz.

Signed-off-by: Luc Michel <luc.michel@amd.com>
Change-Id: I4ef0a040c14fdb2fbb3f2d9d4e6ca6ee8ac8e229
2025-03-28 13:24:17 +01:00
Luc Michel
55ae162fd5 fix(zynqmp): fix syscnt frequency for QEMU
QEMU uses a 62.5MHz clock frequency for the ARM generic timers.

Signed-off-by: Luc Michel <luc.michel@amd.com>
Change-Id: Ib846e17feb3cd44878a62add320fa4795fd5c69e
2025-03-28 13:24:14 +01:00
Karl Meakin
d0ee0ec1c6 refactor: report features supported to secure world
Report `FFA_MEM_PERM_GET` and `FFA_MEM_PERM_SET` supported to secure
world instances.

Signed-off-by: Karl Meakin <karl.meakin@arm.com>
Change-Id: I90e6b0ab601ae1142b419cacfa56109c183ab640
2025-03-27 17:24:37 +00:00
Vincent Jardin
bfe7f80189 fix(nxp-tools): fix2 create_pbl buildroot build
For some unknown reasons I did miss this '+' which does not make
sense when I submitted the former commit. We all did miss
it during codre reviews, sorry for the confusion. I do not understand
how it happened, late commits -> stupid issues.

Revert and fix: 634c7d81 fix create_pbl buildroot build
  Wall -Werror -pedantic -std=c99 -O2 -DVERSION='"v2.12.0(release):master"' -D_GNU_SOURCE -D_XOPEN_SOURCE=700 -c -o create_pbl.o create_pbl.c
  make[3]: Wall: No such file or directory

Change-Id: I1e17e4793061966ce5fa5e0c122914bfaed27952
Signed-off-by: Vincent Jardin <vjardin@free.fr>
2025-03-27 18:00:05 +01:00
Govindraj Raja
2377542785 Merge changes from topic "xlnx_fix_gen_datatype_cast" into integration
* changes:
  fix(psci): add const qualifier
  fix(el3-runtime): add const qualifier
  fix(bl31): add const qualifier
  fix(console): typecast expressions to match data type
  fix(arm-drivers): typecast expressions to match data type
  fix(arm-drivers): align essential type categories
  fix(arm-drivers): typecast expression to match data type
2025-03-27 15:53:57 +01:00
Manish Pandey
a008954990 Merge "fix(guid-partition): initialise the mbr_entry variable" into integration 2025-03-27 15:43:28 +01:00
Saivardhan Thatikonda
c3ab09d1c5 feat(versal2): is OCM configured as coherent
Warn users about disabled OCM coherency which is not enabled by
default in designs. If it is not enabled and TF-A is running out
of OCM,TF-A won't work properly.
This check is done only in Debug mode and isolation disabled.

Change-Id: I7661e0183503b71085c57fa35014341d14522203
Signed-off-by: Saivardhan Thatikonda <saivardhan.thatikonda@amd.com>
2025-03-27 05:51:14 +00:00
Soby Mathew
8661845026 Merge "fix(rme): do not trap access to MPAM system registers in Realm mode" into integration 2025-03-27 06:25:30 +01:00
Javier Almansa Sobrino
d048af0da1 fix(rme): do not trap access to MPAM system registers in Realm mode
Change-Id: I77496ee962727687b28f71a1a15b4fe4133c613c
Signed-off-by: Javier Almansa Sobrino <javier.almansasobrino@arm.com>
2025-03-26 17:09:57 +00:00
Soby Mathew
ca3f2eee11 Merge "feat(rmmd): verify FEAT_MEC present before calling plat hoook" into integration 2025-03-26 17:39:57 +01:00
Juan Pablo Conde
609ada9691 feat(rmmd): verify FEAT_MEC present before calling plat hoook
Some platforms do not support FEAT_MEC. Hence, they do not provide
an interface to update the update of the key corresponding to a
MECID.

This patch adds a condition in order to verify FEAT_MEC is present
before calling the corresponding platform hook, thus preventing it
from being called when the platform does not support the feature.

Change-Id: Ib1eb9e42f475e27ec31529569e888b93b207148c
Signed-off-by: Juan Pablo Conde <juanpablo.conde@arm.com>
2025-03-26 15:46:38 +01:00
Joanna Farley
2869609ca7 Merge changes from topic "xlnx_fix_plat_invalid_entry" into integration
* changes:
  fix(versal): handle invalid entry point in cpu hotplug scenario
  fix(versal-net): handle invalid entry point in cpu hotplug scenario
  fix(zynqmp): handle invalid entry point in cpu hotplug scenario
2025-03-26 11:13:57 +01:00
Maheedhar Bollapalli
435bc14a94 fix(versal): handle invalid entry point in cpu hotplug scenario
Invalid addresses are from 2G-4G and also address where TF-A is.

Change-Id: I3d07808821da3bdd46be819ad829cb284f9d53d3
Signed-off-by: Maheedhar Bollapalli <maheedharsai.bollapalli@amd.com>
2025-03-26 06:33:21 +00:00
Maheedhar Bollapalli
e5e417ddec fix(versal-net): handle invalid entry point in cpu hotplug scenario
Invalid addresses are from 2G-4G and also address where TF-A is.

Change-Id: I153d26bd92ea26efcd7f236e2f1d89c3e5442ba4
Signed-off-by: Maheedhar Bollapalli <maheedharsai.bollapalli@amd.com>
2025-03-26 06:33:21 +00:00
Maheedhar Bollapalli
df44616a12 fix(zynqmp): handle invalid entry point in cpu hotplug scenario
Invalid addresses are from 2G-4G and also address where TF-A is.

Change-Id: Iedb817a2f9667b7d0b9a3ac03891a5b93295bf87
Signed-off-by: Maheedhar Bollapalli <maheedharsai.bollapalli@amd.com>
2025-03-26 06:33:09 +00:00
Boyan Karatotev
ec48d52e78 fix(guid-partition): initialise the mbr_entry variable
The compiler complains that it may be used unitialised. Give it some
confidence that won't be the case.

Change-Id: I14bddd48e4b205121415025175f157b92a89aa26
Signed-off-by: Boyan Karatotev <boyan.karatotev@arm.com>
2025-03-25 16:51:02 +00:00
Govindraj Raja
8fb8b93984 Merge "refactor(mediatek): fix mcusys off issue for MTK GIC v3 driver" into integration 2025-03-25 16:33:40 +01:00
Soby Mathew
90f9c9bef5 Merge "feat(rme): add SMMU and PCIe information to Boot manifest" into integration 2025-03-25 12:35:47 +01:00
AlexeiFedorov
90552c612e feat(rme): add SMMU and PCIe information to Boot manifest
- Define information structures for SMMU, root complex,
  root port and BDF mappings.
- Add entries for SMMU and PCIe root complexes to Boot manifest.
- Update RMMD_MANIFEST_VERSION_MINOR from 4 to 5.

Change-Id: I0a76dc18edbaaff40116f376aeb56c750d57c7c1
Signed-off-by: AlexeiFedorov <Alexei.Fedorov@arm.com>
2025-03-25 10:26:18 +00:00
Manish Pandey
518b278bed Merge changes from topic "hm/handoff-aarch32" into integration
* changes:
  refactor(arm): simplify early platform setup functions
  feat(bl32): enable r3 usage for boot args
  feat(handoff): add lib to sp-min sources
  feat(handoff): add 32-bit variant of SRAM layout
  feat(handoff): add 32-bit variant of ep info
  fix(aarch32): avoid using r12 to store boot params
  fix(arm): reinit secure and non-secure tls
  refactor(handoff): downgrade error messages
2025-03-24 17:29:57 +01:00
Bipin Ravi
b78c307ca6 Merge changes from topic "ar/cvereorder" into integration
* changes:
  chore(cpus): rearrange the errata and cve in order in Cortex-X4
  chore(cpus): rearrange the errata and cve in order in Neoverse-V3
2025-03-21 17:22:00 +01:00
Bipin Ravi
6059e4232d Merge "chore(cpus): rearrange cve and errata order in Cortex-X3" into integration 2025-03-21 17:21:18 +01:00
Bipin Ravi
eeb16181f5 Merge changes from topic "ar/cvereorder" into integration
* changes:
  chore(cpus): fix cve order in Neoverse-V2
  chore(cpus): rearrange the errata and cve in order in Cortex-A710
2025-03-21 17:12:25 +01:00
Bipin Ravi
4a871b56b4 Merge changes from topic "ar/cvereorder" into integration
* changes:
  chore(cpus): rearrange the errata and cve order in Neoverse-N2
  chore(cpus): rearrange cve in order in Cortex-X1
  chore(cpus): fix cve order in Neoverse-V1
  chore(cpus): fix cve order in Cortex-X2
  chore(cpus): fix cve order in Cortex-A78C
  chore(cpus): fix cve order in Cortex-A78_AE
  chore(cpus): fix cve order in Cortex-A78
  chore(cpus): fix cve order in Cortex-A77
2025-03-21 17:08:04 +01:00
Bipin Ravi
43b56d9111 Merge "refactor(cpus): don't panic if errata out of order" into integration 2025-03-21 17:07:06 +01:00
Sona Mathew
ede127e66c chore(cpus): rearrange the errata and cve in order in Cortex-X4
Patch sorts the errata IDs in ascending order and the
CVE's in ascending order based on the year and index
for CPU Cortex-X4.

Change-Id: Ic304c2f68e7d0b96bbb30760696b7bceabe1ae2d
Signed-off-by: Sona Mathew <sonarebecca.mathew@arm.com>
2025-03-21 10:50:14 -05:00
Sona Mathew
6b922fe0f3 chore(cpus): rearrange cve and errata order in Cortex-X3
Patch sorts the errata IDs in ascending order and the
CVE-2024-5660 in order based on the year and index
for Cortex-X3.

Change-Id: I2a4baebe0c3133528c089d999bdffa8c992f4989
Signed-off-by: Sona Mathew <sonarebecca.mathew@arm.com>
2025-03-21 10:50:14 -05:00
Sona Mathew
174ed6188a chore(cpus): fix cve order in Neoverse-V2
Patch rearranges CVE-2024-5660 in order based on
the year and index for Neoverse-V2.

Change-Id: I092a93ef3299fd733abae9c462c019f94d881413
Signed-off-by: Sona Mathew <sonarebecca.mathew@arm.com>
2025-03-21 10:50:14 -05:00
Sona Mathew
216d437c0d chore(cpus): rearrange the errata and cve order in Neoverse-N2
Patch sorts the errata IDs in ascending order and the
CVE's in ascending order based on the year and index
for CPU Neoverse N2.

Change-Id: Ieb4a8ab0030ea4e83efdef86a0ff1e2990b3e0dd
Signed-off-by: Sona Mathew <sonarebecca.mathew@arm.com>
2025-03-21 10:50:14 -05:00