From patchwork Sat Jun 2 04:28:53 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sinan Kaya X-Patchwork-Id: 10444571 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 9D055602BC for ; Sat, 2 Jun 2018 04:29:30 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 8B220288E2 for ; Sat, 2 Jun 2018 04:29:30 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 7F15E288EE; Sat, 2 Jun 2018 04:29:30 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,MAILING_LIST_MULTI autolearn=unavailable version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 181BB288E2 for ; Sat, 2 Jun 2018 04:29:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-Id:Date:Subject:To :From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=VUN+ev9mfXq3ohaouKQaZkhYT0m/ooTq/BZ5MU4FqQQ=; b=Rhn4lorCMDJjL5 sbkh7lpJdWoys98NJz9nVAW7OreYe6c9CNfPyX720z6XulrV8ZrfI3RKg19WlCb8OLhgl8Rd8A9Wp vXQAsLbBMu/sQUNIdCLnjceSYP/qrLIW8GaxVeparozEUHvDJo2R0w/0/70ZNwRyY00tHpTHy3ZnM IXvjOFtsDDZFHvu7eJB/prHzuxCmP6O6XaippvBdC/5WCZGiHBAPfPqkszEVbC/jdJa2Pyneaptw0 WaSefx51NOxMP2eaTBph2L5R+XywrGsfCkhEzuvoPPFUQkNOX3gAsOELpUim5g7DJXcRxALOynSBJ nqUqZcs6/cYe7/6VgK7Q==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1fOyAF-00046M-F9; Sat, 02 Jun 2018 04:29:15 +0000 Received: from smtp.codeaurora.org ([198.145.29.96]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1fOyAB-00043Y-73 for linux-arm-kernel@lists.infradead.org; Sat, 02 Jun 2018 04:29:12 +0000 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 7DA1560764; Sat, 2 Jun 2018 04:29:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1527913740; bh=P5GuapgBv+ZCKVatPT8FNIVsG6vgJrlPC9oXxaBtgss=; h=From:To:Cc:Subject:Date:From; b=ncjpcUhMFGuY8uOTdwWBOuIJJgvHGIzb0ZzveqFxYfpkPZJ2W5B7j5tP+qQtJKkz4 RfX+hjPl0IBDEZi0GEhDdmASQ2SbAAOZTiKKW9aF88Ai/BwWiduKBeHSSiwVJFlBjI YgIsqeNLQpodQSMGDTWyjVs0dNbcXMI6Iz0VtatA= Received: from drakthul.qualcomm.com (global_nat1_iad_fw.qualcomm.com [129.46.232.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: okaya@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 6E22E606DC; Sat, 2 Jun 2018 04:28:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1527913739; bh=P5GuapgBv+ZCKVatPT8FNIVsG6vgJrlPC9oXxaBtgss=; h=From:To:Cc:Subject:Date:From; b=hbn+/sPldOptUUY0b2fV2Gnv3ND6vyP3fikCzJqk/QoJ+DUfSPKwr0iz27cLO1GT0 lh7hVpaSYrHQKtOJLaPxd16EUvimSreok4ZdK0vKRU51pDciIXuykqV9g4twAYF0A9 dAEjzkd8t4cPFRDYNXMCDZ1elpfXb9/b1WzPiLVk= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 6E22E606DC Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=okaya@codeaurora.org From: Sinan Kaya To: linux-pci@vger.kernel.org, timur@codeaurora.org, ryan@finnie.org Subject: [PATCH V5] scsi: hpsa: disable device during shutdown Date: Sat, 2 Jun 2018 00:28:53 -0400 Message-Id: <1527913733-16492-1-git-send-email-okaya@codeaurora.org> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20180601_212911_326497_5EC8F019 X-CRM114-Status: GOOD ( 12.05 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Don Brace , "James E.J. Bottomley" , "open list:HEWLETT-PACKARD SMART ARRAY RAID DRIVER hpsa" , "Martin K. Petersen" , linux-arm-msm@vger.kernel.org, "open list:HEWLETT-PACKARD SMART ARRAY RAID DRIVER hpsa" , open list , stable@vger.kernel.org, Sinan Kaya , linux-arm-kernel@lists.infradead.org Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP 'Commit cc27b735ad3a ("PCI/portdrv: Turn off PCIe services during shutdown")' has been added to kernel to shutdown pending PCIe port service interrupts during reboot so that a newly started kexec kernel wouldn't observe pending interrupts. pcie_port_device_remove() is disabling the root port and switches by calling pci_disable_device() after all PCIe service drivers are shutdown. This has been found to cause crashes on HP DL360 Gen9 machines during reboot due to hpsa driver not clearing the bus master bit during the shutdown procedure by calling pci_disable_device(). Disable device as part of the shutdown sequence. Signed-off-by: Sinan Kaya Link: https://bugzilla.kernel.org/show_bug.cgi?id=199779 Fixes: cc27b735ad3a ("PCI/portdrv: Turn off PCIe services during shutdown") Cc: stable@vger.kernel.org Reported-by: Ryan Finnie Tested-by: Don Brace Acked-by: Don Brace --- drivers/scsi/hpsa.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/drivers/scsi/hpsa.c b/drivers/scsi/hpsa.c index 3a9eca1..b92f86a 100644 --- a/drivers/scsi/hpsa.c +++ b/drivers/scsi/hpsa.c @@ -8869,7 +8869,7 @@ static void hpsa_disable_rld_caching(struct ctlr_info *h) kfree(options); } -static void hpsa_shutdown(struct pci_dev *pdev) +static void __hpsa_shutdown(struct pci_dev *pdev) { struct ctlr_info *h; @@ -8884,6 +8884,12 @@ static void hpsa_shutdown(struct pci_dev *pdev) hpsa_disable_interrupt_mode(h); /* pci_init 2 */ } +static void hpsa_shutdown(struct pci_dev *pdev) +{ + __hpsa_shutdown(pdev); + pci_disable_device(pdev); +} + static void hpsa_free_device_info(struct ctlr_info *h) { int i; @@ -8927,7 +8933,7 @@ static void hpsa_remove_one(struct pci_dev *pdev) scsi_remove_host(h->scsi_host); /* init_one 8 */ /* includes hpsa_free_irqs - init_one 4 */ /* includes hpsa_disable_interrupt_mode - pci_init 2 */ - hpsa_shutdown(pdev); + __hpsa_shutdown(pdev); hpsa_free_device_info(h); /* scan */