mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-24 09:13:20 -05:00
net/ncsi: Enforce failover on link monitor timeout
The NCSI channel has been configured to provide service if its link monitor timer is enabled, regardless of its state (inactive or active). So the timeout event on the link monitor indicates the out-of-service on that channel, for which a failover is needed. This sets NCSI_DEV_RESHUFFLE flag to enforce failover on link monitor timeout, regardless the channel's original state (inactive or active). Also, the link is put into "down" state to give the failing channel lowest priority when selecting for the active channel. The state of failing channel should be set to active in order for deinitialization and failover to be done. Signed-off-by: Gavin Shan <gwshan@linux.vnet.ibm.com> Signed-off-by: Samuel Mendoza-Jonas <sam@mendozajonas.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
100ef01f3e
commit
52b4c8627f
1 changed files with 5 additions and 3 deletions
|
@ -189,6 +189,7 @@ static void ncsi_channel_monitor(unsigned long data)
|
|||
struct ncsi_channel *nc = (struct ncsi_channel *)data;
|
||||
struct ncsi_package *np = nc->package;
|
||||
struct ncsi_dev_priv *ndp = np->ndp;
|
||||
struct ncsi_channel_mode *ncm;
|
||||
struct ncsi_cmd_arg nca;
|
||||
bool enabled, chained;
|
||||
unsigned int monitor_state;
|
||||
|
@ -228,20 +229,21 @@ static void ncsi_channel_monitor(unsigned long data)
|
|||
case NCSI_CHANNEL_MONITOR_WAIT ... NCSI_CHANNEL_MONITOR_WAIT_MAX:
|
||||
break;
|
||||
default:
|
||||
if (!(ndp->flags & NCSI_DEV_HWA) &&
|
||||
state == NCSI_CHANNEL_ACTIVE) {
|
||||
if (!(ndp->flags & NCSI_DEV_HWA)) {
|
||||
ncsi_report_link(ndp, true);
|
||||
ndp->flags |= NCSI_DEV_RESHUFFLE;
|
||||
}
|
||||
|
||||
ncsi_stop_channel_monitor(nc);
|
||||
|
||||
ncm = &nc->modes[NCSI_MODE_LINK];
|
||||
spin_lock_irqsave(&nc->lock, flags);
|
||||
nc->state = NCSI_CHANNEL_INVISIBLE;
|
||||
ncm->data[2] &= ~0x1;
|
||||
spin_unlock_irqrestore(&nc->lock, flags);
|
||||
|
||||
spin_lock_irqsave(&ndp->lock, flags);
|
||||
nc->state = NCSI_CHANNEL_INACTIVE;
|
||||
nc->state = NCSI_CHANNEL_ACTIVE;
|
||||
list_add_tail_rcu(&nc->link, &ndp->channel_queue);
|
||||
spin_unlock_irqrestore(&ndp->lock, flags);
|
||||
ncsi_process_next_channel(ndp);
|
||||
|
|
Loading…
Add table
Reference in a new issue