From 869dce4a7f48b0642e4c902c5d142503dbd37dda Mon Sep 17 00:00:00 2001
From: Jan Kiszka <jan.kiszka@siemens.com>
Date: Sun, 1 Jan 2017 15:43:37 +0100
Subject: [PATCH] ivshmem-net: Switch to reset state on each net stop and on
 driver removal

Improves the state signaling to the remote side after ifconfig down and
driver removal.

Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
(cherry picked from commit d0f632b2830146d9892a2b1ab93f866f072412bb)
---
 drivers/net/ivshmem-net.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

--- a/drivers/net/ivshmem-net.c
+++ b/drivers/net/ivshmem-net.c
@@ -554,6 +554,8 @@ static void ivshm_net_do_stop(struct net
 {
 	struct ivshm_net *in = netdev_priv(ndev);
 
+	ivshm_net_set_state(in, IVSHM_NET_STATE_RESET);
+
 	if (!test_and_clear_bit(IVSHM_NET_FLAG_RUN, &in->flags))
 		return;
 
@@ -593,7 +595,6 @@ static void ivshm_net_state_change(struc
 		} else {
 			netif_carrier_off(ndev);
 			ivshm_net_do_stop(ndev);
-			ivshm_net_set_state(in, IVSHM_NET_STATE_RESET);
 		}
 		break;
 	}
@@ -899,6 +900,8 @@ static void ivshm_net_remove(struct pci_
 	struct net_device *ndev = pci_get_drvdata(pdev);
 	struct ivshm_net *in = netdev_priv(ndev);
 
+	writel(IVSHM_NET_STATE_RESET, &in->ivshm_regs->lstate);
+
 	if (in->using_msix)  {
 		free_irq(in->msix.vector, ndev);
 		pci_disable_msix(pdev);