[PATCH 2/2] platform: introduce DT-based configurable heap size
Xiang W
wxjstz at 126.com
Thu Sep 19 22:33:51 PDT 2024
在 2024-09-16星期一的 15:25 +0800,Inochi Amaoto写道:
> The default heap size will work for most platforms, but for some
> special platforms, the heap is too small to hold all the information
> or is too big so that it take too much ram. Introduce configurable
> heap should solve this problem and make all generic platforms happy.
>
> Add DT-based heap-size for the generic platform.
>
> Signed-off-by: Inochi Amaoto <inochiama at gmail.com>
LGTM
Reviewed-by: Xiang W <wxjstz at 126.com>
> ---
> docs/opensbi_config.md | 4 ++++
> platform/generic/platform.c | 28 +++++++++++++++++++++++++---
> 2 files changed, 29 insertions(+), 3 deletions(-)
>
> diff --git a/docs/opensbi_config.md b/docs/opensbi_config.md
> index 1b710f1..c620379 100644
> --- a/docs/opensbi_config.md
> +++ b/docs/opensbi_config.md
> @@ -23,6 +23,9 @@ The DT properties of a domain configuration DT node are as follows:
> set of harts is permitted to perform a cold boot. Otherwise, all
> harts are allowed to cold boot.
>
> +* **heap-size** (Optional) - When present, the SBI will initialize
> + the heap with the set value (This value is in byte).
> +
> * **system-suspend-test** (Optional) - When present, enable a system
> suspend test implementation which simply waits five seconds and issues a WFI.
>
> @@ -36,6 +39,7 @@ The OpenSBI Configuration Node will be deleted at the end of cold boot
> opensbi-config {
> compatible = "opensbi,config";
> cold-boot-harts = <&cpu1 &cpu2 &cpu3 &cpu4>;
> + heap-size = <0x400000>;
> system-suspend-test;
> };
> };
> diff --git a/platform/generic/platform.c b/platform/generic/platform.c
> index 49d877d..c8e988e 100644
> --- a/platform/generic/platform.c
> +++ b/platform/generic/platform.c
> @@ -69,6 +69,28 @@ static u32 fw_platform_calculate_heap_size(u32 hart_count)
> return BIT_ALIGN(heap_size, HEAP_BASE_ALIGN);
> }
>
> +static u32 fw_platform_get_heap_size(const void *fdt, u32 hart_count)
> +{
> + int chosen_offset, config_offset, len;
> + const fdt32_t *val;
> +
> + /* Get the heap size from device tree */
> + chosen_offset = fdt_path_offset(fdt, "/chosen");
> + if (chosen_offset < 0)
> + goto default_config;
> +
> + config_offset = fdt_node_offset_by_compatible(fdt, chosen_offset, "opensbi,config");
> + if (config_offset < 0)
> + goto default_config;
> +
> + val = (fdt32_t *)fdt_getprop(fdt, config_offset, "heap-size", &len);
> + if (len > 0 && val)
> + return fdt32_to_cpu(*val);
> +
> +default_config:
> + return fw_platform_calculate_heap_size(hart_count);
> +}
> +
> extern struct sbi_platform platform;
> static bool platform_has_mlevel_imsic = false;
> static u32 generic_hart_index2id[SBI_HARTMASK_MAX_BITS] = { 0 };
> @@ -76,9 +98,9 @@ static u32 generic_hart_index2id[SBI_HARTMASK_MAX_BITS] = { 0 };
> static DECLARE_BITMAP(generic_coldboot_harts, SBI_HARTMASK_MAX_BITS);
>
> /*
> - * The fw_platform_coldboot_harts_init() function is called by fw_platform_init()
> + * The fw_platform_coldboot_harts_init() function is called by fw_platform_init()
> * function to initialize the cold boot harts allowed by the generic platform
> - * according to the DT property "cold-boot-harts" in "/chosen/opensbi-config"
> + * according to the DT property "cold-boot-harts" in "/chosen/opensbi-config"
> * DT node. If there is no "cold-boot-harts" in DT, all harts will be allowed.
> */
> static void fw_platform_coldboot_harts_init(const void *fdt)
> @@ -185,7 +207,7 @@ unsigned long fw_platform_init(unsigned long arg0, unsigned long arg1,
> }
>
> platform.hart_count = hart_count;
> - platform.heap_size = fw_platform_calculate_heap_size(hart_count);
> + platform.heap_size = fw_platform_get_heap_size(fdt, hart_count);
> platform_has_mlevel_imsic = fdt_check_imsic_mlevel(fdt);
>
> fw_platform_coldboot_harts_init(fdt);
More information about the opensbi
mailing list