From patchwork Sat Jan 2 13:59:32 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Can Guo X-Patchwork-Id: 356281 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.8 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 35AD9C433DB for ; Sat, 2 Jan 2021 14:00:25 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id EA471224D4 for ; Sat, 2 Jan 2021 14:00:24 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726596AbhABOAV (ORCPT ); Sat, 2 Jan 2021 09:00:21 -0500 Received: from labrats.qualcomm.com ([199.106.110.90]:20241 "EHLO labrats.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726561AbhABOAV (ORCPT ); Sat, 2 Jan 2021 09:00:21 -0500 IronPort-SDR: 4AYuvZ2XLtu3GoWyVA4I53Sdc7TmBJ2yU6gFzQz7PADJxfC9bnP5Mft6YyTr3LRgtczkKpQVi3 C4g4Ir04HNVAuoZlE8pAy985CVWCY5PU62Wiq2W3xtCYdN9Tl0XUPJh/CXls29UoynoWHlATtK 37Ts7MZmW8DQnsLYmR/KfffvIRiaaLoKddeR9e9hPTkTV/ebC0q/pQh0C+jdTcD0KPVFCsmxQW s5r3Z4m89N5zHrbbxnxfB3+nif153JT7ju/Wz6ZxDSHzc5za8RjrJlr1b+ggPZPRBuka/UXUya A38= X-IronPort-AV: E=Sophos;i="5.78,469,1599548400"; d="scan'208";a="29476448" Received: from unknown (HELO ironmsg01-sd.qualcomm.com) ([10.53.140.141]) by labrats.qualcomm.com with ESMTP; 02 Jan 2021 05:59:40 -0800 X-QCInternal: smtphost Received: from wsp769891wss.qualcomm.com (HELO stor-presley.qualcomm.com) ([192.168.140.85]) by ironmsg01-sd.qualcomm.com with ESMTP; 02 Jan 2021 05:59:40 -0800 Received: by stor-presley.qualcomm.com (Postfix, from userid 359480) id F1AA62187E; Sat, 2 Jan 2021 05:59:39 -0800 (PST) From: Can Guo To: asutoshd@codeaurora.org, nguyenb@codeaurora.org, hongwus@codeaurora.org, ziqichen@codeaurora.org, rnayak@codeaurora.org, linux-scsi@vger.kernel.org, kernel-team@android.com, saravanak@google.com, salyzyn@google.com, cang@codeaurora.org Subject: [PATCH v3 0/2] Synchronize user layer access with system PM ops and error handling Date: Sat, 2 Jan 2021 05:59:32 -0800 Message-Id: <1609595975-12219-1-git-send-email-cang@codeaurora.org> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-scsi@vger.kernel.org This series contains two changes and it is based on 5.11/scsi-queue The 1st change is just a minor fix. The 2nd change is to synchronize user layer access through UFS sysfs nodes, so that system PM ops (suspend, resume and shutdown), error handling and async probe won't be disturbed by user layer access. The protection is only added to some sysfs nodes, not all of them. Change since v2: - Updated the 1st change, added a global boolean flag to tell if system suspend is invoked when hba is NULL, it is used during resume in case of hba becomes not NULL. Change since v1: - Slightly updated the 2nd change, added a dedicated inline func to check hba->shutting_down in ufshcd.h. This inline func can be updated to add more rules for sysfs passage in future. Can Guo (2): scsi: ufs: Fix a possible NULL pointer issue scsi: ufs: Protect PM ops and err_handler from user access through sysfs drivers/scsi/ufs/ufs-sysfs.c | 104 ++++++++++++++++++++++++++++++++++++------- drivers/scsi/ufs/ufshcd.c | 49 ++++++++++++-------- drivers/scsi/ufs/ufshcd.h | 10 ++++- 3 files changed, 128 insertions(+), 35 deletions(-)