[PATCH] clk: versal: Store driver data in data section

Michal Simek michal.simek at amd.com
Wed Feb 26 10:52:26 CET 2025



On 2/18/25 06:24, Padmarao Begari wrote:
> Line 171 in README is describing that before relocation
> no code should use global variable because global variables
> are placed to BSS section which is initialized to 0 after
> relocation.
> 
> On Versal platforms clock driver is initialized before
> relocation (via using dm,bootph-all flag in DT) and global
> variables are initialized which works if this is used only
> before relocation. But the variables are used after
> relocation too but values are zeroed which is ending up
> incorrect behavior.
> 
> That's why place variables to data section to ensure that
> values are not cleared which is for now the quickest
> temporary solution. The correct way to do it is to move
> all global variables to private data to avoid it.
> 
> Signed-off-by: Padmarao Begari <padmarao.begari at amd.com>
> ---
>   drivers/clk/clk_versal.c | 8 ++++----
>   1 file changed, 4 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/clk/clk_versal.c b/drivers/clk/clk_versal.c
> index 35ee56d0693..675bdb7ac0e 100644
> --- a/drivers/clk/clk_versal.c
> +++ b/drivers/clk/clk_versal.c
> @@ -106,8 +106,8 @@ struct versal_clk_priv {
>   	struct versal_clock *clk;
>   };
>   
> -static ulong pl_alt_ref_clk;
> -static ulong ref_clk;
> +static ulong pl_alt_ref_clk __section(".data");
> +static ulong ref_clk __section(".data");
>   
>   struct versal_pm_query_data {
>   	u32 qid;
> @@ -116,8 +116,8 @@ struct versal_pm_query_data {
>   	u32 arg3;
>   };
>   
> -static struct versal_clock *clock;
> -static unsigned int clock_max_idx;
> +static struct versal_clock *clock __section(".data");
> +static unsigned int clock_max_idx __section(".data");
>   
>   #define PM_QUERY_DATA	35
>   

Applied.
M


More information about the U-Boot mailing list