]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
arm: mvebu: AC5: Use finer grained memory map
authorChris Packham <judge.packham@gmail.com>
Fri, 27 Oct 2023 00:44:11 +0000 (13:44 +1300)
committerStefan Roese <sr@denx.de>
Wed, 10 Jan 2024 08:38:55 +0000 (09:38 +0100)
The ATF implementation for AC5/AC5X ends up with bl31 living in some
internal SRAM. This is in the middle of the large MMIO region that we
were using. Adjust this to be finer grained blocks based on the address
map from the AC5X Family Control and Management Subsystem Functional
Datasheet.

Signed-off-by: Chris Packham <judge.packham@gmail.com>
arch/arm/mach-mvebu/alleycat5/cpu.c

index 8204d962751574869a0c9bc10a919b7fdd7063f0..0f72ae1709be37b4dcf1edf30e3d7fb385cbadf2 100644 (file)
 
 DECLARE_GLOBAL_DATA_PTR;
 
-#define RAM_SIZE       SZ_1G
+#define AC5_PTE_BLOCK_DEVICE \
+       (PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | \
+                        PTE_BLOCK_NON_SHARE | \
+                        PTE_BLOCK_PXN | PTE_BLOCK_UXN)
 
 static struct mm_region ac5_mem_map[] = {
        {
@@ -31,30 +34,63 @@ static struct mm_region ac5_mem_map[] = {
                .phys = 0x00000000,
                .virt = 0xa0000000,
                .size = 0x100000,
-
-               .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
-                        PTE_BLOCK_NON_SHARE |
-                        PTE_BLOCK_PXN | PTE_BLOCK_UXN
+               .attrs = AC5_PTE_BLOCK_DEVICE,
        },
        {
                /* MMIO regions */
                .phys = 0x100000,
                .virt = 0x100000,
                .size = 0x3ff00000,
-
-               .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
-                        PTE_BLOCK_NON_SHARE |
-                        PTE_BLOCK_PXN | PTE_BLOCK_UXN
+               .attrs = AC5_PTE_BLOCK_DEVICE,
        },
        {
-               /* MMIO regions */
                .phys = 0x7F000000,
                .virt = 0x7F000000,
-               .size = 0x21000000,
-
-               .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
-                        PTE_BLOCK_NON_SHARE |
-                        PTE_BLOCK_PXN | PTE_BLOCK_UXN
+               .size = SZ_8M,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x7F800000,
+               .virt = 0x7F800000,
+               .size = SZ_4M,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x7FC00000,
+               .virt = 0x7FC00000,
+               .size = SZ_512K,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x7FC80000,
+               .virt = 0x7FC80000,
+               .size = SZ_512K,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x7FD00000,
+               .virt = 0x7FD00000,
+               .size = SZ_512K,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       /* ATF region 0x7FE00000-0x7FE20000 not mapped */
+       {
+               .phys = 0x7FE80000,
+               .virt = 0x7FE80000,
+               .size = SZ_512K,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x7FFF0000,
+               .virt = 0x7FFF0000,
+               .size = SZ_1M,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
+       },
+       {
+               .phys = 0x80000000,
+               .virt = 0x80000000,
+               .size = SZ_2G,
+               .attrs = AC5_PTE_BLOCK_DEVICE,
        },
        {
                0,