diff mbox

[edk2,4/4] ArmVExpressPkg: add embedded DTB blobs for all FVP AArch64 variants

Message ID 1430824625-26772-5-git-send-email-ard.biesheuvel@linaro.org
State New
Headers show

Commit Message

Ard Biesheuvel May 5, 2015, 11:17 a.m. UTC
This adds DTBs for all AArch64 FVP platform variants so that
they can be loaded straight from the firmware image instead of
from a file system.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
---
 ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.fdf              |  23 +++++++++++++++++++++++
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2-psci.dtb             | Bin 0 -> 10151 bytes
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2legacy-psci.dtb       | Bin 0 -> 10151 bytes
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv3-psci.dtb             | Bin 0 -> 10779 bytes
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2-psci.dtb       | Bin 0 -> 7520 bytes
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2legacy-psci.dtb | Bin 0 -> 7520 bytes
 ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv3-psci.dtb       | Bin 0 -> 8148 bytes
 7 files changed, 23 insertions(+)

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..89318c1874f35951c1ee93c7ca6c219808045294
GIT binary patch
literal 10151
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
X3T9VAf-_mygxMJLEXYf<mFMPv@jKGt

literal 0
HcmV?d00001

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2legacy-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2legacy-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..0d176201d72dcaf4d40573220e9750ecb03dac0e
GIT binary patch
literal 10151
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
Zrbw7=2?@?*T@z+w%(Eab%|@P^{{v&e(zpNs

literal 0
HcmV?d00001

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv3-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv3-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..f1dc75eeb8b7cac39a82f0f5db655473a4dbd501
GIT binary patch
literal 10779
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

literal 0
HcmV?d00001

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..e45791813acf9562a198dd8ba4fc24c772867e92
GIT binary patch
literal 7520
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

literal 0
HcmV?d00001

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2legacy-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2legacy-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..ac7555d91ec1dc00d75f0fe190746308a8cc9635
GIT binary patch
literal 7520
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

literal 0
HcmV?d00001

diff --git a/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv3-psci.dtb b/ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv3-psci.dtb
new file mode 100644
index 0000000000000000000000000000000000000000..f3e0c5d3aa0b47bdb278d044f3f010b382336eab
GIT binary patch
literal 8148
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

literal 0
HcmV?d00001

Comments

Ard Biesheuvel May 5, 2015, 2:15 p.m. UTC | #1
On 5 May 2015 at 15:34, Olivier Martin <olivier.martin@arm.com> wrote:
> It is actually something I was planning to do at some point. The issue

The reason we are proposing it now is that we are trying to eliminate
the delta between the Linaro tree and upstream, and building the
FVP/AArch64 platforms with the DTB already built in is on of the
pieces of functionality we want to retain but rather using the
existing foundations.

> is the lack of coherence in the device tree repositories. At the moment,
> the device trees for ARM development platforms live in two locations:
> 1. Linux kernel repository
> 2. The ARM Trusted Firmware repository
> (https://github.com/ARM-software/arm-trusted-firmware/tree/master/fdts).
>

Yes, I agree. I used the ones from #2, in fact, and one would assume
that a hardware description does not change if the hardware does not
change, but the kernel folks still don't seem to have received that
memo :-)

> At the moment I would say the ones we should use are the one from the
> ARM Trusted Firmware because they have been validated with a specific
> set of firmware/kernel.
>
> ARM Ltd has taken in action to consolidate the ARM development platform
> device trees. I was thinking to add a build script to pull these
> consolidated device trees instead of copying them into a third
> repository that might not be well maintained.
>
> If really we go into duplicating again the device trees then we should
> add a README to tell where they come from.
>

Instead, let's factor it out completely, and do something like:

!ifdef $(DTB_DIR)
  #
  # Embed flattened device tree (FDT) images for all known
  # variants of this platform
  #
  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpBaseAEMv8x4GicV2) {
    $(DTB_DIR)/fvp-base-gicv2-psci.dtb
  }
  ...
!endif

This way, we have no DTBs in the TIanocore repo at all, and it is up
to whoever does the build to decide whether and which FDTs he would
like to incorporate.
diff mbox

Patch

diff --git a/ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.fdf b/ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.fdf
index 1c709771b571..484cdaec6eff 100644
--- a/ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.fdf
+++ b/ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.fdf
@@ -210,6 +210,29 @@  READ_LOCK_STATUS   = TRUE
   # FV Filesystem
   INF MdeModulePkg/Universal/FvSimpleFileSystemDxe/FvSimpleFileSystemDxe.inf
 
+  #
+  # Embed flattened device tree (FDT) images for all known
+  # variants of this platform
+  #
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpBaseAEMv8x4GicV2) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2-psci.dtb
+  }
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpBaseAEMv8x4GicV2Legacy) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv2legacy-psci.dtb
+  }
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpBaseAEMv8x4GicV3) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-base-gicv3-psci.dtb
+  }
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpFoundationGicV2) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2-psci.dtb
+  }
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpFoundationGicV2Legacy) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv2legacy-psci.dtb
+  }
+  FILE RAW = PCD (gArmVExpressTokenSpaceGuid.PcdFdtFvpFoundationGicV3) {
+    ArmPlatformPkg/ArmVExpressPkg/Fdts/fvp-foundation-gicv3-psci.dtb
+  }
+
 [FV.FVMAIN_COMPACT]
 FvAlignment        = 16
 ERASE_POLARITY     = 1