Re: [PATCH v2] lmb: Reserve U-Boot separately if relocation is disabled

2021-10-25 Thread Tom Rini
On Fri, Oct 15, 2021 at 05:48:56PM +0200, marek.va...@gmail.com wrote:

> From: Marek Vasut 
> 
> In case U-Boot starts with GD_FLG_SKIP_RELOC, the U-Boot code is
> not relocated, however the stack and heap is at the end of DRAM
> after relocation. Reserve a LMB area for the non-relocated U-Boot
> code so it won't be overwritten.
> 
> Signed-off-by: Marek Vasut 
> Cc: Simon Glass 
> Cc: Tom Rini 
> Reviewed-by: Simon Glass 
> ---
> V2: Make this fully generic
> ---
>  lib/lmb.c | 5 +
>  1 file changed, 5 insertions(+)
> 
> diff --git a/lib/lmb.c b/lib/lmb.c
> index 676b3a0bda..d868633899 100644
> --- a/lib/lmb.c
> +++ b/lib/lmb.c
> @@ -13,6 +13,7 @@
>  #include 
>  
>  #include 
> +#include 
>  
>  DECLARE_GLOBAL_DATA_PTR;
>  
> @@ -144,6 +145,10 @@ void arch_lmb_reserve_generic(struct lmb *lmb, ulong sp, 
> ulong end, ulong align)
>   bank_end = end - 1;
>  
>   lmb_reserve(lmb, sp, bank_end - sp + 1);
> +
> + if (gd->flags & GD_FLG_SKIP_RELOC)
> + lmb_reserve(lmb, (phys_addr_t)_start, gd->mon_len);
> +
>   break;
>   }
>  }

I now see:
   sandbox:  w+   sandbox
+  150 | lmb_reserve(lmb, (phys_addr_t)_start, 
gd->mon_len);
+  |  ^
w+lib/lmb.c: In function 'arch_lmb_reserve_generic':
w+lib/lmb.c:150:42: warning: cast from pointer to integer of different size 
[-Wpointer-to-int-cast]

-- 
Tom


signature.asc
Description: PGP signature


Re: [PATCH v2] lmb: Reserve U-Boot separately if relocation is disabled

2021-10-24 Thread Simon Glass
On Fri, 15 Oct 2021 at 09:49,  wrote:
>
> From: Marek Vasut 
>
> In case U-Boot starts with GD_FLG_SKIP_RELOC, the U-Boot code is
> not relocated, however the stack and heap is at the end of DRAM
> after relocation. Reserve a LMB area for the non-relocated U-Boot
> code so it won't be overwritten.
>
> Signed-off-by: Marek Vasut 
> Cc: Simon Glass 
> Cc: Tom Rini 
> ---
> V2: Make this fully generic
> ---
>  lib/lmb.c | 5 +
>  1 file changed, 5 insertions(+)

Reviewed-by: Simon Glass 


[PATCH v2] lmb: Reserve U-Boot separately if relocation is disabled

2021-10-15 Thread marek . vasut
From: Marek Vasut 

In case U-Boot starts with GD_FLG_SKIP_RELOC, the U-Boot code is
not relocated, however the stack and heap is at the end of DRAM
after relocation. Reserve a LMB area for the non-relocated U-Boot
code so it won't be overwritten.

Signed-off-by: Marek Vasut 
Cc: Simon Glass 
Cc: Tom Rini 
---
V2: Make this fully generic
---
 lib/lmb.c | 5 +
 1 file changed, 5 insertions(+)

diff --git a/lib/lmb.c b/lib/lmb.c
index 676b3a0bda..d868633899 100644
--- a/lib/lmb.c
+++ b/lib/lmb.c
@@ -13,6 +13,7 @@
 #include 
 
 #include 
+#include 
 
 DECLARE_GLOBAL_DATA_PTR;
 
@@ -144,6 +145,10 @@ void arch_lmb_reserve_generic(struct lmb *lmb, ulong sp, 
ulong end, ulong align)
bank_end = end - 1;
 
lmb_reserve(lmb, sp, bank_end - sp + 1);
+
+   if (gd->flags & GD_FLG_SKIP_RELOC)
+   lmb_reserve(lmb, (phys_addr_t)_start, gd->mon_len);
+
break;
}
 }
-- 
2.33.0