blob: e57c4120a3e5b4a55f2b53e110bac70a857a39b8 [file] [log] [blame]
Andy Fleming60ca78b2011-04-07 21:56:05 -05001/*
2 * Atheros PHY drivers
3 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02004 * SPDX-License-Identifier: GPL-2.0+
Andy Fleming60ca78b2011-04-07 21:56:05 -05005 *
Xie Xiaobodcc307e2013-04-10 16:23:39 +08006 * Copyright 2011, 2013 Freescale Semiconductor, Inc.
Andy Fleming60ca78b2011-04-07 21:56:05 -05007 * author Andy Fleming
Andy Fleming60ca78b2011-04-07 21:56:05 -05008 */
9#include <phy.h>
10
11static int ar8021_config(struct phy_device *phydev)
12{
13 phy_write(phydev, MDIO_DEVAD_NONE, 0x1d, 0x05);
14 phy_write(phydev, MDIO_DEVAD_NONE, 0x1e, 0x3D47);
15
Zhao Qiang04f2ba42013-12-23 15:51:33 +080016 phydev->supported = phydev->drv->features;
Andy Fleming60ca78b2011-04-07 21:56:05 -050017 return 0;
18}
19
Xie Xiaobodcc307e2013-04-10 16:23:39 +080020static int ar8035_config(struct phy_device *phydev)
21{
22 int regval;
23
24 phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x0007);
25 phy_write(phydev, MDIO_DEVAD_NONE, 0xe, 0x8016);
26 phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x4007);
27 regval = phy_read(phydev, MDIO_DEVAD_NONE, 0xe);
28 phy_write(phydev, MDIO_DEVAD_NONE, 0xe, (regval|0x0018));
29
30 phy_write(phydev, MDIO_DEVAD_NONE, 0x1d, 0x05);
31 regval = phy_read(phydev, MDIO_DEVAD_NONE, 0x1e);
32 phy_write(phydev, MDIO_DEVAD_NONE, 0x1e, (regval|0x0100));
33
Xiaobo Xieaa09e682014-04-11 16:03:11 +080034 phydev->supported = phydev->drv->features;
Xie Xiaobodcc307e2013-04-10 16:23:39 +080035
Alison Wang5dc3af82016-02-19 15:52:28 +080036 genphy_config_aneg(phydev);
37 genphy_restart_aneg(phydev);
38
Xie Xiaobodcc307e2013-04-10 16:23:39 +080039 return 0;
40}
41
Kim Phillips40c2c032012-10-29 13:34:33 +000042static struct phy_driver AR8021_driver = {
Andy Fleming60ca78b2011-04-07 21:56:05 -050043 .name = "AR8021",
44 .uid = 0x4dd040,
Haijun.Zhang0faa93d2014-03-04 15:56:12 +080045 .mask = 0x4ffff0,
Andy Fleming60ca78b2011-04-07 21:56:05 -050046 .features = PHY_GBIT_FEATURES,
47 .config = ar8021_config,
48 .startup = genphy_startup,
49 .shutdown = genphy_shutdown,
50};
51
Heiko Schocher93ac9b82013-06-04 10:58:00 +020052static struct phy_driver AR8031_driver = {
Shengzhou Liu76f57c32013-08-08 16:33:35 +080053 .name = "AR8031/AR8033",
Heiko Schocher93ac9b82013-06-04 10:58:00 +020054 .uid = 0x4dd074,
Fabio Estevam2edb6062014-01-03 15:55:59 -020055 .mask = 0xffffffef,
Heiko Schocher93ac9b82013-06-04 10:58:00 +020056 .features = PHY_GBIT_FEATURES,
Fabio Estevam95da4ba2016-01-05 17:02:52 -020057 .config = ar8035_config,
Heiko Schocher93ac9b82013-06-04 10:58:00 +020058 .startup = genphy_startup,
59 .shutdown = genphy_shutdown,
60};
61
62static struct phy_driver AR8035_driver = {
Xie Xiaobodcc307e2013-04-10 16:23:39 +080063 .name = "AR8035",
64 .uid = 0x4dd072,
Fabio Estevam2edb6062014-01-03 15:55:59 -020065 .mask = 0xffffffef,
Xie Xiaobodcc307e2013-04-10 16:23:39 +080066 .features = PHY_GBIT_FEATURES,
67 .config = ar8035_config,
68 .startup = genphy_startup,
69 .shutdown = genphy_shutdown,
70};
71
Andy Fleming60ca78b2011-04-07 21:56:05 -050072int phy_atheros_init(void)
73{
74 phy_register(&AR8021_driver);
Heiko Schocher93ac9b82013-06-04 10:58:00 +020075 phy_register(&AR8031_driver);
Xie Xiaobodcc307e2013-04-10 16:23:39 +080076 phy_register(&AR8035_driver);
Andy Fleming60ca78b2011-04-07 21:56:05 -050077
78 return 0;
79}