[PATCH v2 3/6] lib: fix fdt_parse_plmt_node()

Xiang W wxjstz at 126.com
Mon Nov 28 04:52:14 PST 2022


在 2022-11-28星期一的 10:14 +0100,Heinrich Schuchardt写道:
> cpu_offset, cpu_intc_offset must be int to discover failed invocations of
> fdt_node_offset_by_phandle() or fdt_parent_offset().
> 
> After determining cpu_offset we have to check this value and not
> cpu_intc_offset.
> 
> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
Look good to me

Reviewed-by: Xiang W <wxjstz at 126.com>
> ---
> v2:
>         check correct variable
> ---
>  lib/utils/fdt/fdt_helper.c | 6 ++++--
>  1 file changed, 4 insertions(+), 2 deletions(-)
> 
> diff --git a/lib/utils/fdt/fdt_helper.c b/lib/utils/fdt/fdt_helper.c
> index 87b9fb2..976c96e 100644
> --- a/lib/utils/fdt/fdt_helper.c
> +++ b/lib/utils/fdt/fdt_helper.c
> @@ -805,7 +805,7 @@ int fdt_parse_plmt_node(void *fdt, int nodeoffset, unsigned long *plmt_base,
>  {
>         const fdt32_t *val;
>         int rc, i, count;
> -       uint64_t reg_addr, reg_size, cpu_offset, cpu_intc_offset;
> +       uint64_t reg_addr, reg_size;
>         u32 phandle, hwirq, hartid, hcount;
>  
>         if (nodeoffset < 0 || !fdt || !plmt_base ||
> @@ -826,6 +826,8 @@ int fdt_parse_plmt_node(void *fdt, int nodeoffset, unsigned long *plmt_base,
>  
>         hcount = 0;
>         for (i = 0; i < (count / 2); i++) {
> +               int cpu_offset, cpu_intc_offset;
> +
>                 phandle = fdt32_to_cpu(val[2 * i]);
>                 hwirq = fdt32_to_cpu(val[2 * i + 1]);
>  
> @@ -834,7 +836,7 @@ int fdt_parse_plmt_node(void *fdt, int nodeoffset, unsigned long *plmt_base,
>                         continue;
>  
>                 cpu_offset = fdt_parent_offset(fdt, cpu_intc_offset);
> -               if (cpu_intc_offset < 0)
> +               if (cpu_offset < 0)
>                         continue;
>  
>                 rc = fdt_parse_hart_id(fdt, cpu_offset, &hartid);





More information about the opensbi mailing list