blob: 056b607e0b8c93433cdf0f2f960647a950a5235e [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +00002/*
3 * SMSC PHY drivers
4 *
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +00005 * Base code from drivers/net/phy/davicom.c
6 * Copyright 2010-2011 Freescale Semiconductor, Inc.
7 * author Andy Fleming
8 *
Robert P. J. Day1bce2ae2013-09-16 07:15:45 -04009 * Some code copied from linux kernel
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000010 * Copyright (c) 2006 Herbert Valerio Riedel <hvr@gnu.org>
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000011 */
Joe Hershberger05b60ac2018-07-25 12:59:22 -050012#include <common.h>
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000013#include <miiphy.h>
14
David Dueckf27f3b52013-11-05 17:23:03 +010015/* This code does not check the partner abilities. */
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000016static int smsc_parse_status(struct phy_device *phydev)
17{
18 int mii_reg;
19
20 mii_reg = phy_read(phydev, MDIO_DEVAD_NONE, MII_BMSR);
21
22 if (mii_reg & (BMSR_100FULL | BMSR_100HALF))
23 phydev->speed = SPEED_100;
24 else
25 phydev->speed = SPEED_10;
26
27 if (mii_reg & (BMSR_10FULL | BMSR_100FULL))
28 phydev->duplex = DUPLEX_FULL;
29 else
30 phydev->duplex = DUPLEX_HALF;
31
32 return 0;
33}
34
35static int smsc_startup(struct phy_device *phydev)
36{
Michal Simekb733c272016-05-18 12:46:12 +020037 int ret;
38
39 ret = genphy_update_link(phydev);
40 if (ret)
41 return ret;
42
43 return smsc_parse_status(phydev);
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000044}
45
Marek Vasut2ea350c2023-03-19 18:03:02 +010046U_BOOT_PHY_DRIVER(lan8700) = {
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000047 .name = "SMSC LAN8700",
48 .uid = 0x0007c0c0,
49 .mask = 0xffff0,
50 .features = PHY_BASIC_FEATURES,
51 .config = &genphy_config_aneg,
52 .startup = &smsc_startup,
53 .shutdown = &genphy_shutdown,
54};
55
Marek Vasut2ea350c2023-03-19 18:03:02 +010056U_BOOT_PHY_DRIVER(lan911x) = {
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000057 .name = "SMSC LAN911x Internal PHY",
58 .uid = 0x0007c0d0,
59 .mask = 0xffff0,
60 .features = PHY_BASIC_FEATURES,
61 .config = &genphy_config_aneg,
62 .startup = &smsc_startup,
63 .shutdown = &genphy_shutdown,
64};
65
Marek Vasut2ea350c2023-03-19 18:03:02 +010066U_BOOT_PHY_DRIVER(lan8710) = {
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000067 .name = "SMSC LAN8710/LAN8720",
68 .uid = 0x0007c0f0,
69 .mask = 0xffff0,
Fabio Estevam25634212013-06-06 21:04:19 -030070 .features = PHY_BASIC_FEATURES,
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000071 .config = &genphy_config_aneg,
David Dueckf27f3b52013-11-05 17:23:03 +010072 .startup = &genphy_startup,
Nobuhiro Iwamatsu5751aa22011-11-23 21:24:15 +000073 .shutdown = &genphy_shutdown,
74};
75
Marek Vasut2ea350c2023-03-19 18:03:02 +010076U_BOOT_PHY_DRIVER(lan8740) = {
Purna Chandra Mandal46c9d932016-01-28 15:30:20 +053077 .name = "SMSC LAN8740",
78 .uid = 0x0007c110,
79 .mask = 0xffff0,
80 .features = PHY_BASIC_FEATURES,
81 .config = &genphy_config_aneg,
82 .startup = &genphy_startup,
83 .shutdown = &genphy_shutdown,
84};
Michael Kurz008ed162017-01-22 16:04:28 +010085
Marek Vasut2ea350c2023-03-19 18:03:02 +010086U_BOOT_PHY_DRIVER(lan8741) = {
Arno Steffensa0fd3812018-01-25 13:08:35 +010087 .name = "SMSC LAN8741",
88 .uid = 0x0007c120,
89 .mask = 0xffff0,
90 .features = PHY_BASIC_FEATURES,
91 .config = &genphy_config_aneg,
92 .startup = &genphy_startup,
93 .shutdown = &genphy_shutdown,
94};
95
Marek Vasut2ea350c2023-03-19 18:03:02 +010096U_BOOT_PHY_DRIVER(lan8742) = {
Michael Kurz008ed162017-01-22 16:04:28 +010097 .name = "SMSC LAN8742",
98 .uid = 0x0007c130,
99 .mask = 0xffff0,
100 .features = PHY_BASIC_FEATURES,
101 .config = &genphy_config_aneg,
102 .startup = &genphy_startup,
103 .shutdown = &genphy_shutdown,
104};