[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CAATEi5=pe+A8bUp=JqoMUcqQWp9uZ+4b0A92QxVRmsNj0H0ayw@mail.gmail.com>
Date: Fri, 24 May 2024 18:32:46 +0900
From: DaeRo Lee <skseofh@...il.com>
To: Rob Herring <robh@...nel.org>
Cc: lkp@...el.com, daero_le.lee@...sung.com, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org, llvm@...ts.linux.dev,
oe-kbuild-all@...ts.linux.dev, rppt@...nel.org, saravanak@...gle.com
Subject: Re: [PATCH v2] of: of_reserved_mem: clean-up reserved memory with no-map
2024년 5월 22일 (수) 오후 11:31, Rob Herring <robh@...nel.org>님이 작성:
>
> On Wed, May 01, 2024 at 10:23:59PM +0900, skseofh@...il.com wrote:
> > From: Daero Lee <daero_le.lee@...sung.com>
> >
> > In early_init_dt_reserve_memory we only add memory w/o no-map flag to
> > memblock.reserved. But we need to add memory w/ no-map flag to
> > memblock.reserved, because NOMAP and memblock.reserved are semantically
> > different.
> >
> > Signed-off-by: Daero Lee <daero_le.lee@...sung.com>
> > ---
> > drivers/of/of_reserved_mem.c | 6 +++++-
> > 1 file changed, 5 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/of/of_reserved_mem.c b/drivers/of/of_reserved_mem.c
> > index 8236ecae2953..d00a17a9cebc 100644
> > --- a/drivers/of/of_reserved_mem.c
> > +++ b/drivers/of/of_reserved_mem.c
> > @@ -81,6 +81,7 @@ static void __init fdt_reserved_mem_save_node(unsigned long node, const char *un
> > static int __init early_init_dt_reserve_memory(phys_addr_t base,
> > phys_addr_t size, bool nomap)
> > {
> > + int err = 0;
> > if (nomap) {
> > /*
> > * If the memory is already reserved (by another region), we
> > @@ -91,7 +92,10 @@ static int __init early_init_dt_reserve_memory(phys_addr_t base,
> > memblock_is_region_reserved(base, size))
> > return -EBUSY;
> >
> > - return memblock_mark_nomap(base, size);
> > +
> > + err = memblock_mark_nomap(base, size);
>
> The last time this was touched, it was to make the handling aligned with
> EFI memory map handling. Is that still going to be the case with this
> change? Or does EFI memory map handling have the same issue?
Can I get more information about EFI memory map handling that you're saying?
1) Are you talking about uefi_mem in the reserved-memory node like below?
ex) arm64/boot/dts/qcom/qcs404.dtsi
uefi_mem: memory@...00000 {
reg = <0 0x9f800000 0 0x800000>;
no-map;
};
2) Or, about handling EFI memory map function efi_init() -> reserve_regions()?
>
> > + if (err)
> > + return err;
> > }
> > return memblock_reserve(base, size);
> > }
> > --
> > 2.25.1
> >
Powered by blists - more mailing lists