Commit 22be2e6e authored by Asai Thambi S P's avatar Asai Thambi S P Committed by Jens Axboe

mtip32xx: fix incorrect value set for drv_cleanup_done, and re-initialize and...

mtip32xx: fix incorrect value set for drv_cleanup_done, and re-initialize and start port in mtip_restart_port()

This patch includes two changes:
	* fix incorrect value set for drv_cleanup_done
	* re-initialize and start port in mtip_restart_port()
Signed-off-by: default avatarAsai Thambi S P <asamymuthupa@micron.com>
Signed-off-by: default avatarSam Bradshaw <sbradshaw@micron.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent bc67f636
...@@ -422,6 +422,10 @@ static void mtip_init_port(struct mtip_port *port) ...@@ -422,6 +422,10 @@ static void mtip_init_port(struct mtip_port *port)
/* Clear any pending interrupts for this port */ /* Clear any pending interrupts for this port */
writel(readl(port->mmio + PORT_IRQ_STAT), port->mmio + PORT_IRQ_STAT); writel(readl(port->mmio + PORT_IRQ_STAT), port->mmio + PORT_IRQ_STAT);
/* Clear any pending interrupts on the HBA. */
writel(readl(port->dd->mmio + HOST_IRQ_STAT),
port->dd->mmio + HOST_IRQ_STAT);
/* Enable port interrupts */ /* Enable port interrupts */
writel(DEF_PORT_IRQ, port->mmio + PORT_IRQ_MASK); writel(DEF_PORT_IRQ, port->mmio + PORT_IRQ_MASK);
} }
...@@ -490,11 +494,9 @@ static void mtip_restart_port(struct mtip_port *port) ...@@ -490,11 +494,9 @@ static void mtip_restart_port(struct mtip_port *port)
dev_warn(&port->dd->pdev->dev, dev_warn(&port->dd->pdev->dev,
"COM reset failed\n"); "COM reset failed\n");
/* Clear SError, the PxSERR.DIAG.x should be set so clear it */ mtip_init_port(port);
writel(readl(port->mmio + PORT_SCR_ERR), port->mmio + PORT_SCR_ERR); mtip_start_port(port);
/* Enable the DMA engine */
mtip_enable_engine(port, 1);
} }
/* /*
...@@ -3359,9 +3361,6 @@ static int mtip_pci_probe(struct pci_dev *pdev, ...@@ -3359,9 +3361,6 @@ static int mtip_pci_probe(struct pci_dev *pdev,
return -ENOMEM; return -ENOMEM;
} }
/* Set the atomic variable as 1 in case of SRSI */
atomic_set(&dd->drv_cleanup_done, true);
atomic_set(&dd->resumeflag, false); atomic_set(&dd->resumeflag, false);
/* Attach the private data to this PCI device. */ /* Attach the private data to this PCI device. */
...@@ -3434,8 +3433,8 @@ static int mtip_pci_probe(struct pci_dev *pdev, ...@@ -3434,8 +3433,8 @@ static int mtip_pci_probe(struct pci_dev *pdev,
pci_set_drvdata(pdev, NULL); pci_set_drvdata(pdev, NULL);
return rv; return rv;
done: done:
/* Set the atomic variable as 0 in case of SRSI */ /* Set the atomic variable as 0 */
atomic_set(&dd->drv_cleanup_done, true); atomic_set(&dd->drv_cleanup_done, false);
return rv; return rv;
} }
...@@ -3463,8 +3462,6 @@ static void mtip_pci_remove(struct pci_dev *pdev) ...@@ -3463,8 +3462,6 @@ static void mtip_pci_remove(struct pci_dev *pdev)
} }
} }
} }
/* Set the atomic variable as 1 in case of SRSI */
atomic_set(&dd->drv_cleanup_done, true);
/* Clean up the block layer. */ /* Clean up the block layer. */
mtip_block_remove(dd); mtip_block_remove(dd);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment