MIPS: Use address-of operator on section symbols
When building xway_defconfig with clang:
arch/mips/lantiq/prom.c:82:23: error: array comparison always evaluates
to true [-Werror,-Wtautological-compare]
else if (__dtb_start != __dtb_end)
^
1 error generated.
These are not true arrays, they are linker defined symbols, which are
just addresses. Using the address of operator silences the warning
and does not change the resulting assembly with either clang/ld.lld
or gcc/ld (tested with diff + objdump -Dr). Do the same thing across
the entire MIPS subsystem to ensure there are no more warnings around
this type of comparison.
Link: https://github.com/ClangBuiltLinux/linux/issues/1232
Signed-off-by: Nathan Chancellor <natechancellor@gmail.com>
Acked-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
This commit is contained in:
committed by
Thomas Bogendoerfer
parent
ecd3e70974
commit
d422c6c064
@@ -167,7 +167,7 @@ void __init plat_mem_setup(void)
|
|||||||
dtb = phys_to_virt(fw_arg2);
|
dtb = phys_to_virt(fw_arg2);
|
||||||
else if (fw_passed_dtb) /* UHI interface or appended dtb */
|
else if (fw_passed_dtb) /* UHI interface or appended dtb */
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
else
|
else
|
||||||
panic("no dtb found");
|
panic("no dtb found");
|
||||||
|
|||||||
@@ -79,7 +79,7 @@ void __init plat_mem_setup(void)
|
|||||||
|
|
||||||
if (fw_passed_dtb) /* UHI interface */
|
if (fw_passed_dtb) /* UHI interface */
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
else
|
else
|
||||||
panic("no dtb found");
|
panic("no dtb found");
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ static ulong get_fdtaddr(void)
|
|||||||
if (fw_passed_dtb && !fw_arg2 && !fw_arg3)
|
if (fw_passed_dtb && !fw_arg2 && !fw_arg3)
|
||||||
return (ulong)fw_passed_dtb;
|
return (ulong)fw_passed_dtb;
|
||||||
|
|
||||||
if (__dtb_start < __dtb_end)
|
if (&__dtb_start < &__dtb_end)
|
||||||
ftaddr = (ulong)__dtb_start;
|
ftaddr = (ulong)__dtb_start;
|
||||||
|
|
||||||
return ftaddr;
|
return ftaddr;
|
||||||
|
|||||||
@@ -75,7 +75,7 @@ void __init plat_mem_setup(void)
|
|||||||
*/
|
*/
|
||||||
if (fw_passed_dtb)
|
if (fw_passed_dtb)
|
||||||
dtb = (void *)fw_passed_dtb;
|
dtb = (void *)fw_passed_dtb;
|
||||||
else if (__dtb_start != __dtb_end)
|
else if (&__dtb_start != &__dtb_end)
|
||||||
dtb = (void *)__dtb_start;
|
dtb = (void *)__dtb_start;
|
||||||
|
|
||||||
__dt_setup_arch(dtb);
|
__dt_setup_arch(dtb);
|
||||||
|
|||||||
Reference in New Issue
Block a user