[PATCH] RM: shmobile: lager: phy fixup needs CONFIG_PHYLIB

Simon Horman horms at verge.net.au
Thu Oct 31 20:43:59 EDT 2013


On Fri, Nov 01, 2013 at 12:31:02AM +0300, Sergei Shtylyov wrote:
> On 10/31/2013 09:31 AM, Simon Horman wrote:
> 
> >Do not build the phy fixup unless CONFIG_PHYLIB is enabled.
> >Other than not being useful it is also not possible to compile
> 
>    s/compile/link/.
> 
> >the code under this condition as phy_register_fixup_for_id()
> >is not defined.
> 
>    Not only this function is absent...
> 
> >This problem was introduced by 48c8b96f21817aad
> >("ARM: shmobile: Lager: add Micrel KSZ8041 PHY fixup")
> 
> >Cc: Sergei Shtylyov <sergei.shtylyov at cogentembedded.com>
> >Signed-off-by: Simon Horman <horms+renesas at verge.net.au>
> >---
> >  arch/arm/mach-shmobile/board-lager.c | 4 +++-
> >  1 file changed, 3 insertions(+), 1 deletion(-)
> 
> >diff --git a/arch/arm/mach-shmobile/board-lager.c b/arch/arm/mach-shmobile/board-lager.c
> >index 78a31b6..d1a8ddd 100644
> >--- a/arch/arm/mach-shmobile/board-lager.c
> >+++ b/arch/arm/mach-shmobile/board-lager.c
> >@@ -245,7 +245,9 @@ static void __init lager_init(void)
> >  {
> >  	lager_add_standard_devices();
> >
> >-	phy_register_fixup_for_id("r8a7790-ether-ff:01", lager_ksz8041_fixup);
> >+	if (IS_ENABLED(CONFIG_PHYLIB))
> >+		phy_register_fixup_for_id("r8a7790-ether-ff:01",
> >+					  lager_ksz8041_fixup);
> 
>    Perhaps you would consider enclosing the fixup function itself
> into #ifdef as it causes link errors as well?  Doesn't seem
> necessary as gcc probably drops it anyway but for completeness'
> sake...

My understanding of the motivation for IS_ENABLED() is to
take advantage of gcc optimising away unused code and making such
problems disappear.

With this patch in place do you still see any warnings?



More information about the linux-arm-kernel mailing list