aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/phy/icplus.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/phy/icplus.c')
-rw-r--r--drivers/net/phy/icplus.c31
1 files changed, 17 insertions, 14 deletions
diff --git a/drivers/net/phy/icplus.c b/drivers/net/phy/icplus.c
index 7ee4f5822bb9..0856e1b7a849 100644
--- a/drivers/net/phy/icplus.c
+++ b/drivers/net/phy/icplus.c
@@ -30,16 +30,16 @@
30#include <asm/irq.h> 30#include <asm/irq.h>
31#include <asm/uaccess.h> 31#include <asm/uaccess.h>
32 32
33MODULE_DESCRIPTION("ICPlus IP175C/IP101A/IC1001 PHY drivers"); 33MODULE_DESCRIPTION("ICPlus IP175C/IP101A/IP101G/IC1001 PHY drivers");
34MODULE_AUTHOR("Michael Barkowski"); 34MODULE_AUTHOR("Michael Barkowski");
35MODULE_LICENSE("GPL"); 35MODULE_LICENSE("GPL");
36 36
37/* IP101A/IP1001 */ 37/* IP101A/G - IP1001 */
38#define IP10XX_SPEC_CTRL_STATUS 16 /* Spec. Control Register */ 38#define IP10XX_SPEC_CTRL_STATUS 16 /* Spec. Control Register */
39#define IP1001_SPEC_CTRL_STATUS_2 20 /* IP1001 Spec. Control Reg 2 */ 39#define IP1001_SPEC_CTRL_STATUS_2 20 /* IP1001 Spec. Control Reg 2 */
40#define IP1001_PHASE_SEL_MASK 3 /* IP1001 RX/TXPHASE_SEL */ 40#define IP1001_PHASE_SEL_MASK 3 /* IP1001 RX/TXPHASE_SEL */
41#define IP1001_APS_ON 11 /* IP1001 APS Mode bit */ 41#define IP1001_APS_ON 11 /* IP1001 APS Mode bit */
42#define IP101A_APS_ON 2 /* IP101A APS Mode bit */ 42#define IP101A_G_APS_ON 2 /* IP101A/G APS Mode bit */
43 43
44static int ip175c_config_init(struct phy_device *phydev) 44static int ip175c_config_init(struct phy_device *phydev)
45{ 45{
@@ -151,7 +151,7 @@ static int ip1001_config_init(struct phy_device *phydev)
151 return 0; 151 return 0;
152} 152}
153 153
154static int ip101a_config_init(struct phy_device *phydev) 154static int ip101a_g_config_init(struct phy_device *phydev)
155{ 155{
156 int c; 156 int c;
157 157
@@ -161,7 +161,7 @@ static int ip101a_config_init(struct phy_device *phydev)
161 161
162 /* Enable Auto Power Saving mode */ 162 /* Enable Auto Power Saving mode */
163 c = phy_read(phydev, IP10XX_SPEC_CTRL_STATUS); 163 c = phy_read(phydev, IP10XX_SPEC_CTRL_STATUS);
164 c |= IP101A_APS_ON; 164 c |= IP101A_G_APS_ON;
165 return c; 165 return c;
166} 166}
167 167
@@ -203,6 +203,7 @@ static struct phy_driver ip1001_driver = {
203 .phy_id_mask = 0x0ffffff0, 203 .phy_id_mask = 0x0ffffff0,
204 .features = PHY_GBIT_FEATURES | SUPPORTED_Pause | 204 .features = PHY_GBIT_FEATURES | SUPPORTED_Pause |
205 SUPPORTED_Asym_Pause, 205 SUPPORTED_Asym_Pause,
206 .flags = PHY_HAS_INTERRUPT,
206 .config_init = &ip1001_config_init, 207 .config_init = &ip1001_config_init,
207 .config_aneg = &genphy_config_aneg, 208 .config_aneg = &genphy_config_aneg,
208 .read_status = &genphy_read_status, 209 .read_status = &genphy_read_status,
@@ -211,13 +212,14 @@ static struct phy_driver ip1001_driver = {
211 .driver = { .owner = THIS_MODULE,}, 212 .driver = { .owner = THIS_MODULE,},
212}; 213};
213 214
214static struct phy_driver ip101a_driver = { 215static struct phy_driver ip101a_g_driver = {
215 .phy_id = 0x02430c54, 216 .phy_id = 0x02430c54,
216 .name = "ICPlus IP101A", 217 .name = "ICPlus IP101A/G",
217 .phy_id_mask = 0x0ffffff0, 218 .phy_id_mask = 0x0ffffff0,
218 .features = PHY_BASIC_FEATURES | SUPPORTED_Pause | 219 .features = PHY_BASIC_FEATURES | SUPPORTED_Pause |
219 SUPPORTED_Asym_Pause, 220 SUPPORTED_Asym_Pause,
220 .config_init = &ip101a_config_init, 221 .flags = PHY_HAS_INTERRUPT,
222 .config_init = &ip101a_g_config_init,
221 .config_aneg = &genphy_config_aneg, 223 .config_aneg = &genphy_config_aneg,
222 .read_status = &genphy_read_status, 224 .read_status = &genphy_read_status,
223 .suspend = genphy_suspend, 225 .suspend = genphy_suspend,
@@ -233,7 +235,7 @@ static int __init icplus_init(void)
233 if (ret < 0) 235 if (ret < 0)
234 return -ENODEV; 236 return -ENODEV;
235 237
236 ret = phy_driver_register(&ip101a_driver); 238 ret = phy_driver_register(&ip101a_g_driver);
237 if (ret < 0) 239 if (ret < 0)
238 return -ENODEV; 240 return -ENODEV;
239 241
@@ -243,7 +245,7 @@ static int __init icplus_init(void)
243static void __exit icplus_exit(void) 245static void __exit icplus_exit(void)
244{ 246{
245 phy_driver_unregister(&ip1001_driver); 247 phy_driver_unregister(&ip1001_driver);
246 phy_driver_unregister(&ip101a_driver); 248 phy_driver_unregister(&ip101a_g_driver);
247 phy_driver_unregister(&ip175c_driver); 249 phy_driver_unregister(&ip175c_driver);
248} 250}
249 251
@@ -253,6 +255,7 @@ module_exit(icplus_exit);
253static struct mdio_device_id __maybe_unused icplus_tbl[] = { 255static struct mdio_device_id __maybe_unused icplus_tbl[] = {
254 { 0x02430d80, 0x0ffffff0 }, 256 { 0x02430d80, 0x0ffffff0 },
255 { 0x02430d90, 0x0ffffff0 }, 257 { 0x02430d90, 0x0ffffff0 },
258 { 0x02430c54, 0x0ffffff0 },
256 { } 259 { }
257}; 260};
258 261