[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a6487dbc-8f86-447a-ba12-21652f3313e8@lunn.ch>
Date: Fri, 19 Jan 2024 20:44:10 +0100
From: Andrew Lunn <andrew@...n.ch>
To: Asmaa Mnebhi <asmaa@...dia.com>
Cc: "Russell King (Oracle)" <linux@...linux.org.uk>,
"davem@...emloft.net" <davem@...emloft.net>,
"netdev@...r.kernel.org" <netdev@...r.kernel.org>,
David Thompson <davthompson@...dia.com>
Subject: Re: [PATCH v1 1/1] net: phy: micrel: Add workaround for incomplete
autonegotiation
On Fri, Jan 19, 2024 at 06:11:56PM +0000, Asmaa Mnebhi wrote:
>
> > Is there any status registers which indicate energy detection? No point doing
> > retries if there is no sign of a link partner.
> >
> > I would also suggest moving the timeout into a driver private data structure,
> > and rely on phylib polling the PHY once per second and restart autoneg from
> > that. That will avoid holding the lock for a long time.
> >
> Hi Andrew,
>
> Thank you for your feedback.
Lets try to figure out some more about the situation when it fails to
link up.
What is the value of BMSR when it fails to report complete? You say
you are using interrupts, so i just want to make sure its not an
interrupt problem, you are using edge interrupts instead of level,
etc. Maybe i'm remembering wrong, but i though i made a comment about
this once when reviewing one of your drivers. What about the contents
of registers 0x1b and 0x1f?
Thanks
Andrew
Powered by blists - more mailing lists