From: Stephen Hemminger <stephen@networkplumber.org>
Date: Fri, 2 Mar 2018 21:49:04 +0000 (-0800)
Subject: hv_netvsc: cancel subchannel setup before halting device
X-Git-Tag: v4.16-rc5~37^2^2~5
X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=a7483ec0267c69b34e818738da60b392623da94b;p=users%2Fjedix%2Flinux-maple.git

hv_netvsc: cancel subchannel setup before halting device

Block setup of multiple channels earlier in the teardown
process. This avoids possible races between halt and subchannel
initialization.

Suggested-by: Haiyang Zhang <haiyangz@microsoft.com>
Signed-off-by: Stephen Hemminger <sthemmin@microsoft.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
---

diff --git a/drivers/net/hyperv/rndis_filter.c b/drivers/net/hyperv/rndis_filter.c
index c3ca191fea7f..1cba767c6453 100644
--- a/drivers/net/hyperv/rndis_filter.c
+++ b/drivers/net/hyperv/rndis_filter.c
@@ -1340,6 +1340,9 @@ void rndis_filter_device_remove(struct hv_device *dev,
 {
 	struct rndis_device *rndis_dev = net_dev->extension;
 
+	/* Don't try and setup sub channels if about to halt */
+	cancel_work_sync(&net_dev->subchan_work);
+
 	/* Halt and release the rndis device */
 	rndis_filter_halt_device(rndis_dev);