public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Andre Przywara <andre.przywara@arm.com>
To: Samuel Holland <samuel@sholland.org>
Cc: Jagan Teki <jagan@amarulasolutions.com>,
	Hans de Goede <hdegoede@redhat.com>,
	u-boot@lists.denx.de
Subject: Re: [PATCH] sunxi: Load sun8i secure monitor to SRAM A2
Date: Tue, 27 Jul 2021 13:12:29 +0100	[thread overview]
Message-ID: <20210727131229.4eab7dfb@slackpad.fritz.box> (raw)
In-Reply-To: <20210419032141.33620-1-samuel@sholland.org>

On Sun, 18 Apr 2021 22:21:41 -0500
Samuel Holland <samuel@sholland.org> wrote:

Hi,

> Most sun6i-derived SoCs contain SRAM A2, a secure SRAM area for ARISC
> SCP firmware. H3 has a smaller SRAM than other SoCs (A31/A33/A23/A83T).
> 
> On sun8i SoCs which do not have SRAM B, we can use part of this SRAM for
> the secure monitor. Follow the design of 64-bit SoCs and use the first
> part for the monitor, and the last 16 KiB for the SCP firmware. With
> this change, the monitor no longer needs to reserve a region in DRAM.

I was about to merge this, but this breaks the build of R40 and V3s boards:
       arm:  +   Bananapi_M2_Ultra                                     
+u-boot.lds:51: undefined symbol `SUNXI_SRAM_A2_SIZE' referenced in expression
+make[1]: *** [u-boot] Error 1
+make: *** [sub-make] Error 2
...

I fixed it by protecting the parts in sun8i.h with #ifdef
SUNXI_SRAM_A2_SIZE, please yell if you disagree:
https://source.denx.de/u-boot/custodians/u-boot-sunxi/-/commit/488397ea3801a27f6cba38bbf09a7ac7c6747c3f

Otherwise I will send a PR soonish.

Cheers,
Andre


> Signed-off-by: Samuel Holland <samuel@sholland.org>
> ---
>  arch/arm/include/asm/arch-sunxi/cpu_sun4i.h | 11 +++++++++++
>  include/configs/sun8i.h                     |  7 +++++++
>  2 files changed, 18 insertions(+)
> 
> diff --git a/arch/arm/include/asm/arch-sunxi/cpu_sun4i.h b/arch/arm/include/asm/arch-sunxi/cpu_sun4i.h
> index 02ce73954d..d4c795d89c 100644
> --- a/arch/arm/include/asm/arch-sunxi/cpu_sun4i.h
> +++ b/arch/arm/include/asm/arch-sunxi/cpu_sun4i.h
> @@ -11,7 +11,18 @@
>  #define SUNXI_SRAM_A1_BASE		0x00000000
>  #define SUNXI_SRAM_A1_SIZE		(16 * 1024)	/* 16 kiB */
>  
> +#if defined(CONFIG_SUNXI_GEN_SUN6I) && \
> +    !defined(CONFIG_MACH_SUN8I_R40) && \
> +    !defined(CONFIG_MACH_SUN8I_V3S)
> +#define SUNXI_SRAM_A2_BASE		0x00040000
> +#ifdef CONFIG_MACH_SUN8I_H3
> +#define SUNXI_SRAM_A2_SIZE		(48 * 1024)	/* 16+32 kiB */
> +#else
> +#define SUNXI_SRAM_A2_SIZE		(80 * 1024)	/* 16+64 kiB */
> +#endif
> +#else
>  #define SUNXI_SRAM_A2_BASE		0x00004000	/* 16 kiB */
> +#endif
>  #define SUNXI_SRAM_A3_BASE		0x00008000	/* 13 kiB */
>  #define SUNXI_SRAM_A4_BASE		0x0000b400	/* 3 kiB */
>  #define SUNXI_SRAM_D_BASE		0x00010000	/* 4 kiB */
> diff --git a/include/configs/sun8i.h b/include/configs/sun8i.h
> index 9b4675e4c3..545d27996c 100644
> --- a/include/configs/sun8i.h
> +++ b/include/configs/sun8i.h
> @@ -12,6 +12,13 @@
>   * A23 specific configuration
>   */
>  
> +/*
> + * Skip the first 16 KiB of SRAM A2, which is not usable, as only certain bytes
> + * are writable. Reserve the last 17 KiB for the resume shim and SCP firmware.
> + */
> +#define CONFIG_ARMV7_SECURE_BASE	(SUNXI_SRAM_A2_BASE + 16 * 1024)
> +#define CONFIG_ARMV7_SECURE_MAX_SIZE	(SUNXI_SRAM_A2_SIZE - 33 * 1024)
> +
>  /*
>   * Include common sunxi configuration where most the settings are
>   */


  parent reply	other threads:[~2021-07-27 12:13 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-04-19  3:21 [PATCH] sunxi: Load sun8i secure monitor to SRAM A2 Samuel Holland
2021-07-10 23:51 ` Andre Przywara
2021-07-27 12:12 ` Andre Przywara [this message]
2021-07-27 12:34   ` Samuel Holland

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20210727131229.4eab7dfb@slackpad.fritz.box \
    --to=andre.przywara@arm.com \
    --cc=hdegoede@redhat.com \
    --cc=jagan@amarulasolutions.com \
    --cc=samuel@sholland.org \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox