From: Andrew Lunn <andrew@lunn.ch>
To: Liang Xu <lxu@maxlinear.com>
Cc: Florian Fainelli <f.fainelli@gmail.com>,
"hkallweit1@gmail.com" <hkallweit1@gmail.com>,
"netdev@vger.kernel.org" <netdev@vger.kernel.org>,
"davem@davemloft.net" <davem@davemloft.net>,
"kuba@kernel.org" <kuba@kernel.org>,
"vee.khee.wong@linux.intel.com" <vee.khee.wong@linux.intel.com>,
"linux@armlinux.org.uk" <linux@armlinux.org.uk>,
Hauke Mehrtens <hmehrtens@maxlinear.com>,
Thomas Mohren <tmohren@maxlinear.com>
Subject: Re: [PATCH v3] net: phy: add Maxlinear GPY115/21x/24x driver
Date: Fri, 18 Jun 2021 16:01:19 +0200 [thread overview]
Message-ID: <YMynL9c9MpfdC7Se@lunn.ch> (raw)
In-Reply-To: <334b52a6-30e8-0869-6ffb-52e9955235ff@maxlinear.com>
> Net-next:
>
> int genphy_loopback(struct phy_device *phydev, bool enable)
> {
> if (enable) {
> u16 val, ctl = BMCR_LOOPBACK;
> int ret;
>
> if (phydev->speed == SPEED_1000)
> ctl |= BMCR_SPEED1000;
> else if (phydev->speed == SPEED_100)
> ctl |= BMCR_SPEED100;
>
> if (phydev->duplex == DUPLEX_FULL)
> ctl |= BMCR_FULLDPLX;
>
> phy_modify(phydev, MII_BMCR, ~0, ctl);
>
> ret = phy_read_poll_timeout(phydev, MII_BMSR, val,
> val & BMSR_LSTATUS,
> 5000, 500000, true);
> if (ret)
> return ret;
> } else {
> phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, 0);
>
> phy_config_aneg(phydev);
> }
>
> return 0;
> }
>
> v5.12.11:
>
> int genphy_loopback(struct phy_device *phydev, bool enable)
> {
> return phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK,
> enable ? BMCR_LOOPBACK : 0);
> }
>
>
> Not sure whether anyone else reported similar issue.
The commit message says:
net: phy: genphy_loopback: add link speed configuration
In case of loopback, in most cases we need to disable autoneg support
and force some speed configuration. Otherwise, depending on currently
active auto negotiated link speed, the loopback may or may not work.
> Should I use phy_modify to set the LOOPBACK bit only in my driver
> implementation as force speed with loopback enable does not work in our
> device?
So you appear to have the exact opposite problem, you need to use
auto-neg, with yourself, in order to have link. So there are two
solutions:
1) As you say, implement it in your driver
2) Add a second generic implementation, which enables autoneg, if it
is not enabled, sets the loopback bit, and waits for the link to come
up.
Does your PHY driver error out when asked to do a forced mode? It
probably should, if your silicon does not support that part of C22.
Andrew
next prev parent reply other threads:[~2021-06-18 14:01 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-04 16:12 [PATCH v3] net: phy: add Maxlinear GPY115/21x/24x driver Xu Liang
2021-06-04 16:24 ` Florian Fainelli
2021-06-04 18:24 ` Liang Xu
2021-06-04 20:10 ` Andrew Lunn
2021-06-05 3:35 ` Liang Xu
2021-06-05 14:51 ` Andrew Lunn
2021-06-07 4:06 ` Liang Xu
2021-06-18 9:17 ` Liang Xu
2021-06-18 14:01 ` Andrew Lunn [this message]
2021-06-18 15:36 ` Liang Xu
2021-06-21 2:30 ` Andrew Lunn
2021-06-21 5:05 ` Liang Xu
2021-06-21 12:48 ` Andrew Lunn
2021-06-21 13:07 ` Liang Xu
2021-06-04 18:37 ` Liang Xu
2021-06-04 19:44 ` Martin Blumenstingl
2021-06-05 3:32 ` Liang Xu
2021-06-05 17:24 ` Andrew Lunn
2021-06-07 4:37 ` Liang Xu
2021-06-07 20:28 ` Martin Blumenstingl
[not found] ` <MWHPR19MB0077D01E4EAFA9FE521D83ECBD0D9@MWHPR19MB0077.namprd19.prod.outlook.com>
[not found] ` <766ab274-25ff-c9a2-1ed6-fe2aa44b4660@maxlinear.com>
2021-06-23 21:09 ` Martin Blumenstingl
2021-06-24 1:06 ` Andrew Lunn
-- strict thread matches above, loose matches on Subject: below --
2021-06-22 4:21 Ismail, Mohammad Athari
2021-06-22 13:16 ` Andrew Lunn
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YMynL9c9MpfdC7Se@lunn.ch \
--to=andrew@lunn.ch \
--cc=davem@davemloft.net \
--cc=f.fainelli@gmail.com \
--cc=hkallweit1@gmail.com \
--cc=hmehrtens@maxlinear.com \
--cc=kuba@kernel.org \
--cc=linux@armlinux.org.uk \
--cc=lxu@maxlinear.com \
--cc=netdev@vger.kernel.org \
--cc=tmohren@maxlinear.com \
--cc=vee.khee.wong@linux.intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).