diff options
author | Haiyang Zhang <haiyangz@microsoft.com> | 2016-04-22 01:13:01 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-04-25 05:27:58 +0200 |
commit | 15cfd40771e18a4e9b788c64c9db2606f958b93d (patch) | |
tree | c6da0d9154f35255ecb57a28453556d3664bc4db | |
parent | tcp-tso: do not split TSO packets at retransmit time (diff) | |
download | linux-15cfd40771e18a4e9b788c64c9db2606f958b93d.tar.xz linux-15cfd40771e18a4e9b788c64c9db2606f958b93d.zip |
hv_netvsc: Fix the list processing for network change event
RNDIS_STATUS_NETWORK_CHANGE event is handled as two "half events" --
media disconnect & connect. The second half should be added to the list
head, not to the tail. So all events are processed in normal order.
Signed-off-by: Haiyang Zhang <haiyangz@microsoft.com>
Reviewed-by: K. Y. Srinivasan <kys@microsoft.com>
Reviewed-by: Vitaly Kuznetsov <vkuznets@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/hyperv/netvsc_drv.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/hyperv/netvsc_drv.c b/drivers/net/hyperv/netvsc_drv.c index bfdb568ac6b8..ba3f3f3d48ef 100644 --- a/drivers/net/hyperv/netvsc_drv.c +++ b/drivers/net/hyperv/netvsc_drv.c @@ -1125,7 +1125,7 @@ static void netvsc_link_change(struct work_struct *w) netif_tx_stop_all_queues(net); event->event = RNDIS_STATUS_MEDIA_CONNECT; spin_lock_irqsave(&ndev_ctx->lock, flags); - list_add_tail(&event->list, &ndev_ctx->reconfig_events); + list_add(&event->list, &ndev_ctx->reconfig_events); spin_unlock_irqrestore(&ndev_ctx->lock, flags); reschedule = true; } |