Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2522331imu; Thu, 29 Nov 2018 06:22:04 -0800 (PST) X-Google-Smtp-Source: AFSGD/WMeTbcoUBuqBKqPSgcEV5esCOETWjbYz1XuvST/x6EYtK/nAeQyss/ZEfnbiUEVqQXHssE X-Received: by 2002:a62:8c11:: with SMTP id m17mr1575437pfd.224.1543501324907; Thu, 29 Nov 2018 06:22:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543501324; cv=none; d=google.com; s=arc-20160816; b=Ti2gJTU1/Lpdzn5NIBaeuZLX/JH5atEN0qcpAeqNq6HPkTxag53sOKGJ6kS2D2qanL g+M2elc5nGpot3vi/Ch98Edyv3YhrdQSlNTfvNA9cXSu35Nqh/JZ9M1SXCv1h5uBTVum xveWrWs9QW31PBERZM1uM9mxSxG0j9WcqgbDVPumajWrNtNvugH3J7/dbAydhx9TC4a9 YFyNwLOaQ4841tkcef4VdCh9+MHff4MQv1cLaV9HG2mqo6MFSZ2IfxwnFuUuEe45aMCU xDeZukWmF/urRsEC+IEHzOllWTRt5ui41AgTh+9XndEpUMq3M9iaNNmZZZ3O1KP33bMP tclg== 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=ax7ePzMm+Yr1nhsMK3X0DTqzOpmREFlcRCobqJLUxlU=; b=WWfban3Ghv3rzbXqLZ0kKzLVCwtJD/DqxgIFtw4O+p8a6zU2ofWZN+HxRcir3kvFJb IsufgxXyy8RdwRhYFdIbY58WfatioT0saMo+aJoC0gixsD8cus5hUQtxnGgpPLvPjCTd IrXg/qHmk2A+AvkW9vn1PChY0j5UV8C2FdYzxuHxsXUtVQyx9TF+114iGEV4PP4NEQ9R EUMtF4pSDqbNF0Zrfp+Qtw991+bYcWjTTfo9cBTieeRS7V/C81JHfYP7YzmhM8EvygZe eeIn0IaWnIadn45/NfJh9X5Vol6BFMDq2Iv0wcFO0VajkouJJuVAesFbFc+VQfu+zc5O +KGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=VZC0NV2H; 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 y12si2106411pgh.289.2018.11.29.06.21.49; Thu, 29 Nov 2018 06:22:04 -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=VZC0NV2H; 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 S1731330AbeK3BZz (ORCPT + 99 others); Thu, 29 Nov 2018 20:25:55 -0500 Received: from mail.kernel.org ([198.145.29.99]:49412 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728855AbeK3BZy (ORCPT ); Thu, 29 Nov 2018 20:25:54 -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 D7B7C208E7; Thu, 29 Nov 2018 14:20:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1543501223; bh=9f0NZHIo9B5Jy+TtHbZmk/spTtNCmb2shePnUN3mroE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VZC0NV2H5xahhVGTJRKrYVYYo+gcynY73xZ81hqUx5RIFz1Jq4auWIFgznGb6dkgm OvR8lQJwyG7gRzrjHdyOyMAIaa/hbEf8WT08LbHGpnccxLvNS+cJlo4/XFzxSPuFO0 AE5dMt8xY+4t7dXfuDmG6ZdVYMFcsQb3BKsaB/rA= 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 4.4 77/86] scsi: qla2xxx: do not queue commands when unloading Date: Thu, 29 Nov 2018 15:12:42 +0100 Message-Id: <20181129140116.052349217@linuxfoundation.org> X-Mailer: git-send-email 2.19.2 In-Reply-To: <20181129140109.832117862@linuxfoundation.org> References: <20181129140109.832117862@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 4.4-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 @@ -685,6 +685,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,