Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2573214imu; Thu, 29 Nov 2018 07:05:45 -0800 (PST) X-Google-Smtp-Source: AFSGD/W8CDa3x6RBDKOOv2UBfgbZBKQwtClizVux6cgN9J6x3quzkE18SOW65MB4yszdOvC/LoWu X-Received: by 2002:a65:4381:: with SMTP id m1mr1515795pgp.358.1543503945157; Thu, 29 Nov 2018 07:05:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543503945; cv=none; d=google.com; s=arc-20160816; b=xhjZmVKExJwboybvx6dwHCexeArbMFEJaS7fiPu0ExFLy4ou1hqAHMj070X99hAlYg 6514Nn/hD6eC0RYpLvO/lSqsw8/hbMXD4tV9QI8hJAXMKwSC/u+VXjsfXozl0kv+4dfa KBjez79kJwwy3WAqjEDlSAbkopCC85ChkJt02acCpJp9WVEMu0E+GqBBimvP3nKKy8EG sU2x4ApyEtk4uvf4NhpNIImE1f0XXbOMe6Ir9m1Oo8sQDRed7accOO5YkWHo8j6nO6K7 6cf7HaTNOvLkeVfoO7OP4H2/0tUDworbm+c4o+/RZxlKlbonUVDp9wn+cQGY4eRN3XnM XQQQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=sfjhs5mlQwNBpXy+XlUtLqsrbTYAmMKlHvdm46/cmTg=; b=Ea01VlPCI6Hqr8hrX8FqB8aXHycK6Nn832L9rcoCEV8diZD6A5yhROzW+oG1XTTyuf atnWdXlkIE0Q57vSvwUKQbPCpcS0u8CMtyeJLhJj70udOkFHjPrD1s7Mro2Sb3jPv/jh C6MpbCZYCdjDdumfldheaWMiavc5PFm+3xvnugPvN/kPcJCdwE3w4lHGJKlZeHDoe3EO Xoz6WKtZOhMlOC/+JTkcKcoDn5At3c7G1VKvF+++3CTPX7yiXvqEnzZxR+MICcRPcO2Z W3u7/7XZ4tw4xVf/GvO3iXemThy7GyOpWku8t1e43/9rEDr0EAcN5iNFI6O3huI18PMv 9m9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pNhq0wjF; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n12si2171437pgb.563.2018.11.29.07.05.30; Thu, 29 Nov 2018 07:05:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pNhq0wjF; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730181AbeK3BWY (ORCPT + 99 others); Thu, 29 Nov 2018 20:22:24 -0500 Received: from mail.kernel.org ([198.145.29.99]:44058 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728190AbeK3BWW (ORCPT ); Thu, 29 Nov 2018 20:22:22 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4AD1A21019; Thu, 29 Nov 2018 14:16:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543501012; bh=6sp7bgyZ3Jd5R1lrU88yA7Ifhqti8H69YBWTD6z4SkY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pNhq0wjFfagQUIesDpZOL6VFfTQqQJgnFLhIAX3dOWzLcuxN4XkL20mRtDs96+PTF 6kdejRhC9t3ZhAcBod6bml+FbNV1Efh9YjmCsSjhQm9dxuPVZmI8d6xesuzF6Qk1lV x3wuNr+kgWCA8VXb/LFwnqalw+dnRJsaO8Afd2hg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mauricio Faria de Oliveira , Himanshu Madhani , "Martin K. Petersen" , Amit Pundir Subject: [PATCH 3.18 79/83] scsi: qla2xxx: do not queue commands when unloading Date: Thu, 29 Nov 2018 15:12:37 +0100 Message-Id: <20181129140142.551530931@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181129140138.002176596@linuxfoundation.org> References: <20181129140138.002176596@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Mauricio Faria de Oliveira commit 04dfaa53a0b6e66b328a5bc549e3af8f8b6eac02 upstream. When the driver is unloading, in qla2x00_remove_one(), there is a single call/point in time to abort ongoing commands, qla2x00_abort_all_cmds(), which is still several steps away from the call to scsi_remove_host(). If more commands continue to arrive and be processed during that interval, when the driver is tearing down and releasing its structures, it might potentially hit an oops due to invalid memory access: Unable to handle kernel paging request for data at address 0x00000138 <...> NIP [d000000004700a40] qla2xxx_queuecommand+0x80/0x3f0 [qla2xxx] LR [d000000004700a10] qla2xxx_queuecommand+0x50/0x3f0 [qla2xxx] So, fail commands in qla2xxx_queuecommand() if the UNLOADING bit is set. Signed-off-by: Mauricio Faria de Oliveira Acked-by: Himanshu Madhani Signed-off-by: Martin K. Petersen Signed-off-by: Amit Pundir Signed-off-by: Greg Kroah-Hartman --- drivers/scsi/qla2xxx/qla_os.c | 5 +++++ 1 file changed, 5 insertions(+) --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c @@ -687,6 +687,11 @@ qla2xxx_queuecommand(struct Scsi_Host *h srb_t *sp; int rval; + if (unlikely(test_bit(UNLOADING, &base_vha->dpc_flags))) { + cmd->result = DID_NO_CONNECT << 16; + goto qc24_fail_command; + } + if (ha->flags.eeh_busy) { if (ha->flags.pci_channel_io_perm_failure) { ql_dbg(ql_dbg_aer, vha, 0x9010,