[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1484246716.4651.5.camel@redhat.com>
Date: Thu, 12 Jan 2017 12:45:16 -0600
From: Dan Williams <dcbw@...hat.com>
To: Andrew Lunn <andrew@...n.ch>, Mason <slash.tmp@...e.fr>
Cc: netdev <netdev@...r.kernel.org>, Mans Rullgard <mans@...sr.com>,
Florian Fainelli <f.fainelli@...il.com>,
Thibaud Cornic <thibaud_cornic@...madesigns.com>
Subject: Re: Setting link down or up in software
On Thu, 2017-01-12 at 16:28 +0100, Andrew Lunn wrote:
> > Here's an example of "Link is Down" printed when I set link up:
> >
> > At [ 62.750220] I run ip link set dev eth0 down
> > Then leave the system idle for 10 minutes.
> > At [ 646.263041] I run ip link set dev eth0 up
> > At [ 647.364079] it prints "Link is Down"
> > At [ 649.417434] it prints "Link is Up - 1Gbps/Full - flow control
> > rx/tx"
>
> Purely a guess, but when you up the interface, it starts auto
> negotiation. That often involves resetting the PHY. If the PHY has
> already once completed autoneg, e.g. because of the boot loader, it
> will be initially UP. The reset will put it DOWN, and then once
> autoneg is complete, it will be Up again.
>
> Pure guess. Go read the code and see if i'm write.
Historically, !IFF_UP meant the phy could be powered down or go into
some kind of low-power mode where link negotiation and communication
was unavailable. Some drivers implemented that, some keep the PHY up
because who knows why, or because they just never got around to real
power management.
Dan
Powered by blists - more mailing lists