Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2361683ybc; Sun, 17 Nov 2019 19:59:35 -0800 (PST) X-Google-Smtp-Source: APXvYqzDstk06K7CP5fHritje4aNKmoFXhowmFltsLhrvyy95zqFaM9dZBFDY14espsRMKrlgvg/ X-Received: by 2002:a17:906:c41:: with SMTP id t1mr23292567ejf.282.1574049575840; Sun, 17 Nov 2019 19:59:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574049575; cv=none; d=google.com; s=arc-20160816; b=CmoO63TyEG7PA5b8bDBixVZfyxAZtyRdFAbL8L2UZbXSKk2Mc9MW7mm85KvtzVEt92 HqP5DCGDfetewL7kG8LQp9KJpR2by8eqbDdpbZ5Gqv3NJBSWL9wdeZKRNPDlMYE0wWwn KmfAMuDmcmw+9J6Yx8hXX7O6uswAKLJld5u64zafp872uUeuUQza0xWtXa8vdPWwXnBo Zy8FyZrYKtNx49APtDxXKmqVJDNq5v7+BkWd8ZwGZZp61/BQ4J5YoZZMvGqBm8VbZulE 8j2LstAon749MhdhgBGdcL0XV8/hSZuVNE8C07YUL3wylElaPhcolYaN7DNTiqrrSjb3 hhNw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:feedback-id:references:in-reply-to :message-id:date:subject:cc:to:from:dmarc-filter:dkim-signature :dkim-signature; bh=ilDbeqyNaj+ZC+cmiXN3UcugGe9iomX9wWix+xJflbs=; b=fwZmof8yboipgU9qsqJ8hORNY7l3fyIDfWgYfd9N4o/8CFO2+WfqalKtANpo/OqDMD 7fBy6DzTPQ41hoTLYTXpS4doMAO8I7dBvPKUxp7lKYI0OxniEXdgReQ62jvMYQUPFdaF sTqNI4JCGARPELMD65fuLY266wWO9Oiea+ZVmJgNdBDqH7o67P3IpFIUy5nVZrx9SjW7 LM3mVoVGsTfWwEq/rj1u07tusve1ROAmSrhepcD5cyn2/0aeR3yS09V2Ua6+utBbuTW4 uH4chxEj8z9pWZ7L3TWtVwkcvN/GhJzPj2VX4P5DsTA79r26Yyrhy3wVbFKQzAc5Pkyt w3Fg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=zsmsymrwgfyinv5wlfyidntwsjeeldzt header.b=foWo0eI6; dkim=pass header.i=@amazonses.com header.s=gdwg2y3kokkkj5a55z2ilkup5wp5hhxx header.b="O/LIzen3"; 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 op11si10797262ejb.107.2019.11.17.19.59.11; Sun, 17 Nov 2019 19:59:35 -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=@codeaurora.org header.s=zsmsymrwgfyinv5wlfyidntwsjeeldzt header.b=foWo0eI6; dkim=pass header.i=@amazonses.com header.s=gdwg2y3kokkkj5a55z2ilkup5wp5hhxx header.b="O/LIzen3"; 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 S1726895AbfKRDzJ (ORCPT + 99 others); Sun, 17 Nov 2019 22:55:09 -0500 Received: from a27-11.smtp-out.us-west-2.amazonses.com ([54.240.27.11]:36600 "EHLO a27-11.smtp-out.us-west-2.amazonses.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726568AbfKRDzI (ORCPT ); Sun, 17 Nov 2019 22:55:08 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple; s=zsmsymrwgfyinv5wlfyidntwsjeeldzt; d=codeaurora.org; t=1574049308; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References; bh=jnQ6gPfvysIeaYlF2DJKBoJIeVx0/Yhs6OcMo97QSuE=; b=foWo0eI6Wj26veKwhU9aphamrrpKEkyQYwriICxlTbWksvkrU2vh3SeipqBB0bqG aiY3PLBxQYQqUTA6If3sQxgZpNeS0RV4vkv+awLgGRFNm8KK7r6EyO7jLAMmQMbdbY8 /G6hfkWbma6kbU+Qd/wz2f3jrIuwU7724dSB1iNQ= DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple; s=gdwg2y3kokkkj5a55z2ilkup5wp5hhxx; d=amazonses.com; t=1574049308; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References:Feedback-ID; bh=jnQ6gPfvysIeaYlF2DJKBoJIeVx0/Yhs6OcMo97QSuE=; b=O/LIzen3NN6D8StYvDEY4hi9czlJl6yjOyLB0pKyYTJ/KVcDCXh+XfVLwzg8C9BN fGRPuldH2NDT8a2KKbt/ZBqpvn9xO3U6iLJP3H3e9c93CYGcY9xKzXsgXgGI7Sp/tB9 K5NiMzXmMZdJzxUPvE1PPgQ7Va1PMJVkNAlq8k18= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED,SPF_NONE, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 419BDC4479D Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=cang@codeaurora.org From: Can Guo To: asutoshd@codeaurora.org, nguyenb@codeaurora.org, rnayak@codeaurora.org, linux-scsi@vger.kernel.org, kernel-team@android.com, saravanak@google.com, salyzyn@google.com, cang@codeaurora.org Cc: Alim Akhtar , Avri Altman , Pedro Sousa , "James E.J. Bottomley" , "Martin K. Petersen" , Stanley Chu , Bean Huo , Tomas Winkler , Venkat Gopalakrishnan , Bjorn Andersson , Arnd Bergmann , linux-kernel@vger.kernel.org (open list) Subject: [PATCH v2 4/4] scsi: ufs: Complete pending requests in host reset and restore path Date: Mon, 18 Nov 2019 03:55:07 +0000 Message-ID: <0101016e7ca65cf9-32682ea5-6aaf-4431-917b-218b9ff30dbb-000000@us-west-2.amazonses.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1574049277-13477-1-git-send-email-cang@codeaurora.org> References: <1574049277-13477-1-git-send-email-cang@codeaurora.org> X-SES-Outgoing: 2019.11.18-54.240.27.11 Feedback-ID: 1.us-west-2.CZuq2qbDmUIuT3qdvXlRHZZCpfZqZ4GtG9v3VKgRyF0=:AmazonSES Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In UFS host reset and restore path, before probe, we stop and start the host controller once. After host controller is stopped, the pending requests, if any, are cleared from the doorbell, but no completion IRQ would be raised due to the hba is stopped. These pending requests shall be completed along with the first NOP_OUT command(as it is the first command which can raise a transfer completion IRQ) sent during probe. Since the OCSs of these pending requests are not SUCCESS(because they are not yet literally finished), their UPIUs shall be dumped. When there are multiple pending requests, the UPIU dump can be overwhelming and may lead to stability issues because it is in atomic context. Therefore, before probe, complete these pending requests right after host controller is stopped and silence the UPIU dump from them. Signed-off-by: Can Guo --- drivers/scsi/ufs/ufshcd.c | 24 ++++++++++-------------- drivers/scsi/ufs/ufshcd.h | 2 ++ 2 files changed, 12 insertions(+), 14 deletions(-) diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index 5950a7c..b92a3f4 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -4845,7 +4845,7 @@ static void ufshcd_slave_destroy(struct scsi_device *sdev) break; } /* end of switch */ - if (host_byte(result) != DID_OK) + if ((host_byte(result) != DID_OK) && !hba->silence_err_logs) ufshcd_print_trs(hba, 1 << lrbp->task_tag, true); return result; } @@ -5404,8 +5404,8 @@ static void ufshcd_err_handler(struct work_struct *work) /* * if host reset is required then skip clearing the pending - * transfers forcefully because they will automatically get - * cleared after link startup. + * transfers forcefully because they will get cleared during + * host reset and restore */ if (needs_reset) goto skip_pending_xfer_clear; @@ -6333,9 +6333,15 @@ static int ufshcd_host_reset_and_restore(struct ufs_hba *hba) int err; unsigned long flags; - /* Reset the host controller */ + /* + * Stop the host controller and complete the requests + * cleared by h/w + */ spin_lock_irqsave(hba->host->host_lock, flags); ufshcd_hba_stop(hba, false); + hba->silence_err_logs = true; + ufshcd_complete_requests(hba); + hba->silence_err_logs = false; spin_unlock_irqrestore(hba->host->host_lock, flags); /* scale up clocks to max frequency before full reinitialization */ @@ -6369,7 +6375,6 @@ static int ufshcd_host_reset_and_restore(struct ufs_hba *hba) static int ufshcd_reset_and_restore(struct ufs_hba *hba) { int err = 0; - unsigned long flags; int retries = MAX_HOST_RESET_RETRIES; do { @@ -6379,15 +6384,6 @@ static int ufshcd_reset_and_restore(struct ufs_hba *hba) err = ufshcd_host_reset_and_restore(hba); } while (err && --retries); - /* - * After reset the door-bell might be cleared, complete - * outstanding requests in s/w here. - */ - spin_lock_irqsave(hba->host->host_lock, flags); - ufshcd_transfer_req_compl(hba); - ufshcd_tmc_handler(hba); - spin_unlock_irqrestore(hba->host->host_lock, flags); - return err; } diff --git a/drivers/scsi/ufs/ufshcd.h b/drivers/scsi/ufs/ufshcd.h index e0fe247..1e51034 100644 --- a/drivers/scsi/ufs/ufshcd.h +++ b/drivers/scsi/ufs/ufshcd.h @@ -513,6 +513,7 @@ struct ufs_stats { * @uic_error: UFS interconnect layer error status * @saved_err: sticky error mask * @saved_uic_err: sticky UIC error mask + * @silence_err_logs: flag to silence error logs * @dev_cmd: ufs device management command information * @last_dme_cmd_tstamp: time stamp of the last completed DME command * @auto_bkops_enabled: to track whether bkops is enabled in device @@ -670,6 +671,7 @@ struct ufs_hba { u32 saved_err; u32 saved_uic_err; struct ufs_stats ufs_stats; + bool silence_err_logs; /* Device management request data */ struct ufs_dev_cmd dev_cmd; -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project