]> err.no Git - linux-2.6/commitdiff
[PATCH] Add support for the Cicada 8201 PHY
authorKim Phillips <kim.phillips@freescale.com>
Thu, 29 Jun 2006 02:13:23 +0000 (21:13 -0500)
committerJeff Garzik <jeff@garzik.org>
Wed, 5 Jul 2006 18:07:14 +0000 (14:07 -0400)
Add support for the Cicada 8201 PHY, a.k.a Vitesse VSC8201.  This PHY is present on the MPC8349mITX.

Signed-off-by: Kim Phillips <kim.phillips@freescale.com>
Signed-off-by: Andy Fleming <afleming@freescale.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
drivers/net/phy/cicada.c

index 3efb715c28dcc6f3c45417bba10d71cbf6bab354..ae60e6e4107c09b502c3c111617add99c2f90d32 100644 (file)
@@ -103,7 +103,22 @@ static int cis820x_config_intr(struct phy_device *phydev)
        return err;
 }
 
-/* Cicada 820x */
+/* Cicada 8201, a.k.a Vitesse VSC8201 */
+static struct phy_driver cis8201_driver = {
+       .phy_id         = 0x000fc410,
+       .name           = "Cicada Cis8201",
+       .phy_id_mask    = 0x000ffff0,
+       .features       = PHY_GBIT_FEATURES,
+       .flags          = PHY_HAS_INTERRUPT,
+       .config_init    = &cis820x_config_init,
+       .config_aneg    = &genphy_config_aneg,
+       .read_status    = &genphy_read_status,
+       .ack_interrupt  = &cis820x_ack_interrupt,
+       .config_intr    = &cis820x_config_intr,
+       .driver         = { .owner = THIS_MODULE,},
+};
+
+/* Cicada 8204 */
 static struct phy_driver cis8204_driver = {
        .phy_id         = 0x000fc440,
        .name           = "Cicada Cis8204",
@@ -118,15 +133,30 @@ static struct phy_driver cis8204_driver = {
        .driver         = { .owner = THIS_MODULE,},
 };
 
-static int __init cis8204_init(void)
+static int __init cicada_init(void)
 {
-       return phy_driver_register(&cis8204_driver);
+       int ret;
+
+       ret = phy_driver_register(&cis8204_driver);
+       if (ret)
+               goto err1;
+
+       ret = phy_driver_register(&cis8201_driver);
+       if (ret)
+               goto err2;
+       return 0;
+
+err2:
+       phy_driver_unregister(&cis8204_driver);
+err1:
+       return ret;
 }
 
-static void __exit cis8204_exit(void)
+static void __exit cicada_exit(void)
 {
        phy_driver_unregister(&cis8204_driver);
+       phy_driver_unregister(&cis8201_driver);
 }
 
-module_init(cis8204_init);
-module_exit(cis8204_exit);
+module_init(cicada_init);
+module_exit(cicada_exit);