From 6598df69d10b1b80469b6238fdd13fb6d9dbc67b Mon Sep 17 00:00:00 2001 From: nbd Date: Sun, 20 Apr 2008 02:53:04 +0000 Subject: Add stub driver for ADM6996F switches (configured through MII) The driver currently uses a hardcoded VLAN mapping and has no configuration yet Tested on Accton MR3202a git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10869 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../patches-2.6.23/610-phy_detect.patch | 30 ++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 target/linux/generic-2.6/patches-2.6.23/610-phy_detect.patch (limited to 'target/linux/generic-2.6/patches-2.6.23/610-phy_detect.patch') diff --git a/target/linux/generic-2.6/patches-2.6.23/610-phy_detect.patch b/target/linux/generic-2.6/patches-2.6.23/610-phy_detect.patch new file mode 100644 index 000000000..394cd3704 --- /dev/null +++ b/target/linux/generic-2.6/patches-2.6.23/610-phy_detect.patch @@ -0,0 +1,30 @@ +Index: linux-2.6.23.16/drivers/net/phy/mdio_bus.c +=================================================================== +--- linux-2.6.23.16.orig/drivers/net/phy/mdio_bus.c 2008-02-11 07:06:32.000000000 +0100 ++++ linux-2.6.23.16/drivers/net/phy/mdio_bus.c 2008-04-20 01:55:46.000000000 +0200 +@@ -131,6 +131,9 @@ + struct phy_device *phydev = to_phy_device(dev); + struct phy_driver *phydrv = to_phy_driver(drv); + ++ if (phydrv->detect) ++ return (phydrv->detect(phydev->bus, phydev->addr)); ++ + return ((phydrv->phy_id & phydrv->phy_id_mask) == + (phydev->phy_id & phydrv->phy_id_mask)); + } +Index: linux-2.6.23.16/include/linux/phy.h +=================================================================== +--- linux-2.6.23.16.orig/include/linux/phy.h 2008-04-20 00:36:18.000000000 +0200 ++++ linux-2.6.23.16/include/linux/phy.h 2008-04-20 01:55:04.000000000 +0200 +@@ -319,6 +319,11 @@ + u32 features; + u32 flags; + ++ /* Called during discovery to test if the ++ * device can attach to the bus, even if ++ * phy id and mask do not match */ ++ bool (*detect)(struct mii_bus *bus, int addr); ++ + /* Called to initialize the PHY, + * including after a reset */ + int (*config_init)(struct phy_device *phydev); -- cgit v1.2.3