ARM: imx: bootaux: Fix LTO -Wlto-type-mismatch
authorMarek Vasut <marex@denx.de>
Tue, 13 Dec 2022 04:46:07 +0000 (05:46 +0100)
committerStefano Babic <sbabic@denx.de>
Mon, 30 Jan 2023 22:23:02 +0000 (23:23 +0100)
Commit 56c2dbdabab5 ("imx: bootaux: cleanup code") introduces the
following LTO related warning:

"
arch/arm/mach-imx/imx_bootaux.c:24:31: warning: type of ‘hostmap’ does not match original declaration [-Wlto-type-mismatch]
   24 | const __weak struct rproc_att hostmap[] = { };
      |                               ^
arch/arm/mach-imx/imx8m/soc.c:1590:24: note: array types have different bounds
 1590 | const struct rproc_att hostmap[] = {
      |                        ^
arch/arm/mach-imx/imx8m/soc.c:1590:24: note: ‘hostmap’ was previously declared here
../aarch64-linux-gnu/bin/ld: warning: u-boot has a LOAD segment with RWX permissions
"

This is because the weak empty array of structures "hostmap" is eventually
replaced by non-empty array of structures with different number of elements.
Fix this by avoiding weak variable size array, instead use a weak function
which returns single pointer to the array.

Fixes: 56c2dbdabab5 ("imx: bootaux: cleanup code")
Signed-off-by: Marek Vasut <marex@denx.de>
Reviewed-by: Peng Fan <peng.fan@nxp.com>
arch/arm/include/asm/mach-imx/sys_proto.h
arch/arm/mach-imx/imx8m/soc.c
arch/arm/mach-imx/imx_bootaux.c
arch/arm/mach-imx/mx7/soc.c

index dd0d3f2..27fdc16 100644 (file)
@@ -149,6 +149,8 @@ struct rproc_att {
        u32 size; /* size of reg range */
 };
 
+const struct rproc_att *imx_bootaux_get_hostmap(void);
+
 struct rom_api {
        u16 ver;
        u16 tag;
index 8050406..90a59bd 100644 (file)
@@ -1610,4 +1610,9 @@ const struct rproc_att hostmap[] = {
        { 0x40000000, 0x40000000, 0x80000000 },
        { /* sentinel */ }
 };
+
+const struct rproc_att *imx_bootaux_get_hostmap(void)
+{
+       return hostmap;
+}
 #endif
index 433c1f8..888c53d 100644 (file)
 #define SRC_M4_REG_OFFSET              0
 #endif
 
-const __weak struct rproc_att hostmap[] = { };
+__weak const struct rproc_att *imx_bootaux_get_hostmap(void)
+{
+       return NULL;
+}
 
 static const struct rproc_att *get_host_mapping(unsigned long auxcore)
 {
-       const struct rproc_att *mmap = hostmap;
+       const struct rproc_att *mmap = imx_bootaux_get_hostmap();
 
        while (mmap && mmap->size) {
                if (mmap->da <= auxcore &&
index 02af0d5..689dbef 100644 (file)
@@ -224,6 +224,11 @@ const struct rproc_att hostmap[] = {
        { 0x80000000, 0x80000000, 0x60000000 }, /* DDRC */
        { /* sentinel */ }
 };
+
+const struct rproc_att *imx_bootaux_get_hostmap(void)
+{
+       return hostmap;
+}
 #endif
 
 #if !CONFIG_IS_ENABLED(SKIP_LOWLEVEL_INIT)