From 7ffbe0a04e5fb2cfa3af10ac05584f535d0b356d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ky=C3=B6sti=20M=C3=A4lkki?= Date: Sat, 26 Jun 2021 14:25:56 +0300 Subject: soc/qualcomm/ipq40xx: Do resource transition MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Change-Id: I93c16b563c7a4f4c653d2ebfd001170cb0fca82e Signed-off-by: Kyösti Mälkki Reviewed-on: https://review.coreboot.org/c/coreboot/+/55918 Tested-by: build bot (Jenkins) Reviewed-by: Arthur Heymans --- src/soc/qualcomm/ipq40xx/soc.c | 28 ++++++---------------------- 1 file changed, 6 insertions(+), 22 deletions(-) (limited to 'src/soc/qualcomm/ipq40xx') diff --git a/src/soc/qualcomm/ipq40xx/soc.c b/src/soc/qualcomm/ipq40xx/soc.c index c99ae6f2d1..f482cff30b 100644 --- a/src/soc/qualcomm/ipq40xx/soc.c +++ b/src/soc/qualcomm/ipq40xx/soc.c @@ -5,6 +5,7 @@ #include #include +/* CONFIG_DRAM_SIZE_MB effectively extends hlos2. */ typedef struct { uint8_t hlos1[112 * MiB], /* <-- 0x80000000 */ appsbl[4 * MiB], /* <-- 0x87000000 */ @@ -13,34 +14,17 @@ typedef struct { hlos2[128 * MiB]; /* <-- 0x88000000 */ } ipq_mem_map_t; -#define LINUX_REGION1_START ((uintptr_t)(ipq_mem_map->hlos1)) -#define LINUX_REGION1_START_KB (LINUX_REGION1_START / KiB) -#define LINUX_REGION1_SIZE (sizeof(ipq_mem_map->hlos1) + \ - sizeof(ipq_mem_map->appsbl) + \ - sizeof(ipq_mem_map->sbl)) -#define LINUX_REGION1_SIZE_KB (LINUX_REGION1_SIZE / KiB) - -#define RESERVED_START ((uintptr_t)(ipq_mem_map->rsvd)) -#define RESERVED_START_KB (RESERVED_START / KiB) -#define RESERVED_SIZE (sizeof(ipq_mem_map->rsvd)) -#define RESERVED_SIZE_KB (RESERVED_SIZE / KiB) - -/* xxx_SIZE defines not needed since it goes till end of memory */ -#define LINUX_REGION2_START ((uintptr_t)(ipq_mem_map->hlos2)) -#define LINUX_REGION2_START_KB (LINUX_REGION2_START / KiB) - static void soc_read_resources(struct device *dev) { ipq_mem_map_t *ipq_mem_map = ((ipq_mem_map_t *)_dram); + uint64_t ram_end = (uintptr_t)_dram + CONFIG_DRAM_SIZE_MB * (uint64_t)MiB; - ram_resource_kb(dev, 0, LINUX_REGION1_START_KB, LINUX_REGION1_SIZE_KB); - - reserved_ram_resource_kb(dev, 1, RESERVED_START_KB, RESERVED_SIZE_KB); + ram_from_to(dev, 0, (uintptr_t)ipq_mem_map->hlos1, (uintptr_t)ipq_mem_map->rsvd); + reserved_ram_from_to(dev, 1, (uintptr_t)ipq_mem_map->rsvd, + (uintptr_t)ipq_mem_map->hlos2); /* 0x88000000 to end, is the second region for Linux */ - ram_resource_kb(dev, 2, LINUX_REGION2_START_KB, - (CONFIG_DRAM_SIZE_MB * KiB) - - LINUX_REGION1_SIZE_KB - RESERVED_SIZE_KB); + ram_from_to(dev, 2, (uintptr_t)ipq_mem_map->hlos2, ram_end); } static void soc_init(struct device *dev) -- cgit v1.2.3