linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Nested function in drivers/of/of_mdio.c
@ 2009-10-07 15:15 Jérôme Pouiller
  2009-10-07 16:11 ` Grant Likely
  0 siblings, 1 reply; 7+ messages in thread
From: Jérôme Pouiller @ 2009-10-07 15:15 UTC (permalink / raw)
  To: Grant Likely; +Cc: netdev, linuxppc, Andy Fleming, David S. Miller

Dear,

I have a problem with commit 8bc487d150b939e69830c39322df4ee486efe381=20
in file drivers/of/of_mdio.c in function of_phy_find_device.

As you see, this function define match() as a nested function. My=20
compiler (powerpc-e500-linux-gnu-gcc-3.4.1) raise an error during link=20
due to this nested definition:
  drivers/built-in.o(.text+0x5e2a4): In function `of_phy_find_device': /hom=
e/jezz/linux-next/drivers/of/of_mdio.c:107:=20
undefined reference to `__trampoline_setup'

I am sure I could solve problem by rebuilding my toolchain.=20
Nevertheless, I think nested function definition is not perfectly=20
supported by all compilers. Also, I suggest to place function match()=20
outside of scope of of_phy_find_device as in following patch.

diff --git a/drivers/of/of_mdio.c b/drivers/of/of_mdio.c
index bacaa53..c7b2e26 100644
=2D-- a/drivers/of/of_mdio.c
+++ b/drivers/of/of_mdio.c
@@ -97,6 +97,10 @@ int of_mdiobus_register(struct mii_bus *mdio, struct dev=
ice_node *np)
 }
 EXPORT_SYMBOL(of_mdiobus_register);

+static int match(struct device *dev, void *phy_np)
+{
+       return dev_archdata_get_node(&dev->archdata) =3D=3D phy_np;
+}
 /**
  * of_phy_find_device - Give a PHY node, find the phy_device
  * @phy_np: Pointer to the phy's device tree node
@@ -106,11 +110,6 @@ EXPORT_SYMBOL(of_mdiobus_register);
 struct phy_device *of_phy_find_device(struct device_node *phy_np)
 {
        struct device *d;
=2D       int match(struct device *dev, void *phy_np)
=2D       {
=2D               return dev_archdata_get_node(&dev->archdata) =3D=3D phy_n=
p;
=2D       }
=2D
        if (!phy_np)
                return NULL;


What do you think about it?

Best regards,

=2D-=20
J=E9r=F4me Pouiller (jezz AT sysmic DOT org)

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2009-10-08 11:14 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-10-07 15:15 Nested function in drivers/of/of_mdio.c Jérôme Pouiller
2009-10-07 16:11 ` Grant Likely
2009-10-07 16:23   ` vb
2009-10-08  8:45     ` Jérôme Pouiller
2009-10-08 11:14       ` Gabriel Paubert
2009-10-08  8:34   ` [PATCH] Remove nested function Jérôme Pouiller
2009-10-08  9:10     ` David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).