| 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); |