Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp3123176pxb; Tue, 20 Apr 2021 00:43:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxqQx8fjpvaVwwuhyfFWK7OUatkOceRTxAoF4u2EzqaVE1GivnYJiCWnohRKFS/qOTJ08U0 X-Received: by 2002:a05:6402:b66:: with SMTP id cb6mr30223872edb.248.1618904610776; Tue, 20 Apr 2021 00:43:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618904610; cv=none; d=google.com; s=arc-20160816; b=CmwP1M0WaRmDCfEhvYwYiK3RftCWJu3sSSb1xxzmCmRKjLUYAMFpG29N20dAMtVLhH mM++V0rO0iDMET+iSs/7Pf9viVDekhF058jLw294u+DgC10GNlC65uNcQ5HN6TJihOza vCB6i3+tmhrLImS7sWtg5Etaz/SI7DCknaN5Ix/AA5RjxmfT3i7KZr76Lz0YvfFX9hFi uVq8/qwLFh8ZLNun8eGtJmkZXXBB0UN74WJkjVcSd1BEyxXe0oUPrKSSg3kG1gWw8fJg bhSPXXdcUlEkeObhbxoRG5/FOOuHx9Nm1hZZfhsw1rxwAxxIqNvI/ygIAZ8vb/5SPpyG DRXA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :references:cc:to:from:subject:ironport-sdr:ironport-sdr; bh=Vtaz5OojCsVg/F1NmGJlIsjnV00ZKb/NJTJ5i5aBFg0=; b=pfZRReriZEz08heAYIGJJRNQrEHAnBhVpbowpcIPtm+pvdIljZqcKUjD9TwEfuhjce l2dP0eVk6TERd+0czEBskx1sG8x/nSfDrX78gROBxzIqFQizCBmJneQAZ9eqbYIx/Ees Kt2HLx6JeoxmnOJKw7ET7iZaxTAD2zVQ9dKvotmSqGuoG/tODSj+zYlyNwDHVJVPhv+X 0wZxy6uRRbxRUjQ238L52WVhX2NQBZDfMap/u2bZ5vxwtk6k5KNjtZfu9MpoaN5LJzin OS/pjKWNL2ShM7AssGTXYAlfwR8SUKMdeV9mS4QujSAfpkeyjJsqbQ0ImIpsVsmp/Qxx ZZCw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d9si12211507edy.174.2021.04.20.00.43.07; Tue, 20 Apr 2021 00:43:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229721AbhDTHmh (ORCPT + 99 others); Tue, 20 Apr 2021 03:42:37 -0400 Received: from mga17.intel.com ([192.55.52.151]:21110 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229471AbhDTHmg (ORCPT ); Tue, 20 Apr 2021 03:42:36 -0400 IronPort-SDR: 0JiMYGbegb0EzC2jbahOQsGwpY89gWqSehfmkDpbEp7Wx23MUuGW37aBQaV3TFxNlQ79sAdt4v X8PwhzSMgFnQ== X-IronPort-AV: E=McAfee;i="6200,9189,9959"; a="175569116" X-IronPort-AV: E=Sophos;i="5.82,236,1613462400"; d="scan'208";a="175569116" Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Apr 2021 00:42:05 -0700 IronPort-SDR: 630eycZorH3K8PN4kq3rhhrk9E4j2rPjNnDU6tsH/ECPJJuZQCjRasfUswTdXrRAyZCb5RXNvR nmxqLdK//Ofw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.82,236,1613462400"; d="scan'208";a="420306465" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.174]) ([10.237.72.174]) by fmsmga008.fm.intel.com with ESMTP; 20 Apr 2021 00:41:55 -0700 Subject: Re: [PATCH v20 1/2] scsi: ufs: Enable power management for wlun From: Adrian Hunter To: "Asutosh Das (asd)" , cang@codeaurora.org, martin.petersen@oracle.com, linux-scsi@vger.kernel.org Cc: linux-arm-msm@vger.kernel.org, Alim Akhtar , Avri Altman , "James E.J. Bottomley" , Krzysztof Kozlowski , Stanley Chu , Andy Gross , Bjorn Andersson , Steven Rostedt , Ingo Molnar , Matthias Brugger , Lee Jones , Bean Huo , Kiwoong Kim , Colin Ian King , Wei Yongjun , Yue Hu , Bart van Assche , "Gustavo A. R. Silva" , Dinghao Liu , Jaegeuk Kim , Satya Tangirala , open list , "moderated list:ARM/SAMSUNG S3C, S5P AND EXYNOS ARM ARCHITECTURES" , "open list:ARM/SAMSUNG S3C, S5P AND EXYNOS ARM ARCHITECTURES" , "moderated list:UNIVERSAL FLASH STORAGE HOST CONTROLLER DRIVER..." References: <07e3ea07-e1c3-7b8c-e398-8b008f873e6d@codeaurora.org> <90809796-1c32-3709-13d3-65e4d5c387cc@intel.com> Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: <1bc4a73e-b22a-6bad-2583-3a0ffa979414@intel.com> Date: Tue, 20 Apr 2021 10:42:09 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <90809796-1c32-3709-13d3-65e4d5c387cc@intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20/04/21 7:15 am, Adrian Hunter wrote: > On 20/04/21 12:53 am, Asutosh Das (asd) wrote: >> On 4/19/2021 11:37 AM, Adrian Hunter wrote: >>> On 16/04/21 10:49 pm, Asutosh Das wrote: >>>> >>>> Co-developed-by: Can Guo >>>> Signed-off-by: Can Guo >>>> Signed-off-by: Asutosh Das >>>> --- >>> >>> I came across 3 issues while testing.  See comments below. >>> >> Hi Adrian >> Thanks for the comments. >>> >>> >>>> @@ -5794,7 +5839,7 @@ static void ufshcd_err_handling_unprepare(struct ufs_hba *hba) >>>>       if (ufshcd_is_clkscaling_supported(hba)) >>>>           ufshcd_clk_scaling_suspend(hba, false); >>>>       ufshcd_clear_ua_wluns(hba); >>> >>> ufshcd_clear_ua_wluns() deadlocks trying to clear UFS_UPIU_RPMB_WLUN >>> if sdev_rpmb is suspended and sdev_ufs_device is suspending. >>> e.g. ufshcd_wl_suspend() is waiting on host_sem while ufshcd_err_handler() >>> is running, at which point sdev_rpmb has already suspended. >>> >> Umm, I didn't understand this deadlock. >> When you say, sdev_rpmb is suspended, does it mean runtime_suspended? >> sdev_ufs_device is suspending - this can't be runtime_suspending, while ufshcd_err_handling_unprepare is running. >> >> If you've a call-stack of this deadlock, please can you share it with me. I'll also try to reproduce this. > > Yes it is system suspend. sdev_rpmb has suspended, sdev_ufs_device is waiting on host_sem. > ufshcd_err_handler() holds host_sem. ufshcd_clear_ua_wlun(UFS_UPIU_RPMB_WLUN) gets stuck. > I will get some call-stacks. Here are the call stacks [ 34.094321] Workqueue: ufs_eh_wq_0 ufshcd_err_handler [ 34.094788] Call Trace: [ 34.095281] __schedule+0x275/0x6c0 [ 34.095743] schedule+0x41/0xa0 [ 34.096240] blk_queue_enter+0x10d/0x230 [ 34.096693] ? wait_woken+0x70/0x70 [ 34.097167] blk_mq_alloc_request+0x53/0xc0 [ 34.097610] blk_get_request+0x1e/0x60 [ 34.098053] __scsi_execute+0x3c/0x260 [ 34.098529] ufshcd_clear_ua_wlun.cold+0xa6/0x14b [ 34.098977] ufshcd_clear_ua_wluns.part.0+0x4d/0x92 [ 34.099456] ufshcd_err_handler+0x97a/0x9ff [ 34.099902] process_one_work+0x1cc/0x360 [ 34.100384] worker_thread+0x45/0x3b0 [ 34.100851] ? process_one_work+0x360/0x360 [ 34.101308] kthread+0xf6/0x130 [ 34.101728] ? kthread_park+0x80/0x80 [ 34.102186] ret_from_fork+0x1f/0x30 [ 34.640751] task:kworker/u10:9 state:D stack:14528 pid: 255 ppid: 2 flags:0x00004000 [ 34.641253] Workqueue: events_unbound async_run_entry_fn [ 34.641722] Call Trace: [ 34.642217] __schedule+0x275/0x6c0 [ 34.642683] schedule+0x41/0xa0 [ 34.643179] schedule_timeout+0x18b/0x290 [ 34.643645] ? del_timer_sync+0x30/0x30 [ 34.644131] __down_timeout+0x6b/0xc0 [ 34.644568] ? ufshcd_clkscale_enable_show+0x20/0x20 [ 34.645014] ? async_schedule_node_domain+0x17d/0x190 [ 34.645496] down_timeout+0x42/0x50 [ 34.645947] ufshcd_wl_suspend+0x79/0xa0 [ 34.646432] ? scmd_printk+0x100/0x100 [ 34.646917] scsi_bus_suspend_common+0x56/0xc0 [ 34.647405] ? scsi_bus_freeze+0x10/0x10 [ 34.647858] dpm_run_callback+0x45/0x110 [ 34.648347] __device_suspend+0x117/0x460 [ 34.648788] async_suspend+0x16/0x90 [ 34.649251] async_run_entry_fn+0x26/0x110 [ 34.649676] process_one_work+0x1cc/0x360 [ 34.650137] worker_thread+0x45/0x3b0 [ 34.650563] ? process_one_work+0x360/0x360 [ 34.650994] kthread+0xf6/0x130 [ 34.651455] ? kthread_park+0x80/0x80 [ 34.651882] ret_from_fork+0x1f/0x30 > >> >> I'll address the other comments in the next version. >> >> >> Thank you! >> >>>> -    pm_runtime_put(hba->dev); >>>> +    ufshcd_rpm_put(hba); >>>>   } >>> >>> >>> >>>> +void ufshcd_resume_complete(struct device *dev) >>>> +{ >> >