Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp1761676imj; Fri, 8 Feb 2019 07:00:26 -0800 (PST) X-Google-Smtp-Source: AHgI3IYia1XpWnpGfEZs3ovnU9V9tyy+R2bftodn+GKXJGAVQJa6L4HVw0oA1HSOkzJTZXhac5V9 X-Received: by 2002:a65:6150:: with SMTP id o16mr18618869pgv.434.1549638025890; Fri, 08 Feb 2019 07:00:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549638025; cv=none; d=google.com; s=arc-20160816; b=IJ8ruHXPs+x79DE7yDuR1MnACrHsUQsBROXm3YJWcMxeshxkxWX0m970P/T563SMy1 yAhXNOAV5t7bSy7nRZsr65nBj9agItZmZd4P9iAHl2f50YLpM0rf092vgr8HmrXFL00Z IAqmfw6AFN6SjFl1xCrOZ3PdYKRs99ahWJRrV88RY1IJ6wudEKSIHp+MUNfPbkA/wEpD qJ+iIJuNrM4Ne4Xem51it/KSvq51KWaceP/+KLCFdOxB+b18kWiYhPS87+RB/caSGFo7 Qh5kB3gT4fTR0Mg74ewL64Fd/u8qLvF+Vz9p7DfuNnonDnAdy6JwGY7z0ywI+Ym7DfAZ 8vRg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature; bh=fyLLjyiWbY7rOe5re5qzv5qS3k/XHwB26XkY5igqAaY=; b=dUwL8q+VSFxrPpno6LpZ65asjmEcuStPGYIR3/ZxnY/oIwLpjSRZYxm8vZ0FPDDQNz WdbohMovjItO6TcZvtLBhoMmbaXQPjVFAHKU9snAYuPeukU/HCiCSzXvb9neZSfOfW0s 4maGOWbJOuHTAKwSnq2U/uaau2uQH2Xd4WyHbtp6RQWvm5U4jzmLv2UWhV/1HgcV5WTW Yp6lp50n1WVIYWYq73wXhWDFM0DCaayw2FZcWioan1+EptlSLL9NjU0t6XaL9fgWAV3P MoXr5XJe/qAd3SWeVZcdZ/JCx850bsAFMHmV6uAisVEZdxPGadP3NF3ce3yS8BV4cVzS RApA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=GzaKCzAO; dkim=pass header.i=@codeaurora.org header.s=default header.b=cj+95TKo; 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 l12si2633808plc.0.2019.02.08.07.00.08; Fri, 08 Feb 2019 07:00:25 -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=default header.b=GzaKCzAO; dkim=pass header.i=@codeaurora.org header.s=default header.b=cj+95TKo; 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 S1727767AbfBHPAE (ORCPT + 99 others); Fri, 8 Feb 2019 10:00:04 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:40494 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726887AbfBHPAD (ORCPT ); Fri, 8 Feb 2019 10:00:03 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id EE783607F5; Fri, 8 Feb 2019 15:00:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1549638002; bh=m4ebvndvj6wOhv2+cwWHIwhoH4d9fTb+xxFBkTd5OH4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=GzaKCzAOqK2MvQ/C4usBtEKd/4IeGglyWImuHv46mhFgsIWdN+ZV9qS2SJyvZXur5 gukvcJo599LxzIV8+f0ygLRAkcVQaZE6lc3xPQ+a5TXfg88So/idE8obY3QIDmdHi+ JjdEmX6ZFbIV22f5PQb8SgqRwuftpVP8bocTUek4= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from [10.226.60.81] (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: jhugo@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id C88F660208; Fri, 8 Feb 2019 14:59:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1549638000; bh=m4ebvndvj6wOhv2+cwWHIwhoH4d9fTb+xxFBkTd5OH4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=cj+95TKokUw2OEMlPg5H0yGesc1YXChFvofJyhMZiEN7FnBuoykhm/wmaCROBcR9H ah1CbbGlBxIf6/c6RgDtdusnX0XmbLGJ4RIPsyiGKCWeocmTiOmPB6ZE6WbkFO1oF+ BhM/n6sc439otAEeJ8JTxw8fk59j7xb3Hkju5Yrc= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org C88F660208 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=jhugo@codeaurora.org Subject: Re: [PATCH v3 5/5] Revert "scsi: ufs: disable vccq if it's not needed by UFS device" To: Alim Akhtar , Marc Gonzalez , MSM , LKML Cc: Bjorn Andersson , Andy Gross , David Brown , Evan Green , Douglas Anderson , Avri Altman , Pedro Sousa , Subhash Jadavani , Bart Van Assche , SCSI , Hannes Reinecke References: <70618c25-83f0-b9db-51a3-c1d74b605a45@free.fr> <5f2a8378-1f22-6a52-356d-56d3b393ab1d@samsung.com> <05d2d193-4181-12ce-b4fb-4e8dec5aef27@free.fr> <7610c262-1451-9bb2-48a6-4daf6f534f6c@free.fr> <42c86292-22e9-4c5e-d64d-bc6107af45bf@free.fr> <740e6332-b54f-ab62-915a-0aec6be450d3@samsung.com> <2a59c11a-037f-c8c3-235a-9b21183a0801@free.fr> <90f24b35-89b0-cea0-1ab3-13c2a419b138@samsung.com> <81b85f39-49b5-901b-ec79-19708509965e@codeaurora.org> <2c0e5f03-0bb8-e5db-b5de-790da439fcfe@samsung.com> From: Jeffrey Hugo Message-ID: <349da668-6bb5-fcf4-c3f2-f7f7e113ed67@codeaurora.org> Date: Fri, 8 Feb 2019 07:59:57 -0700 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <2c0e5f03-0bb8-e5db-b5de-790da439fcfe@samsung.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2/8/2019 2:09 AM, Alim Akhtar wrote: > Hi Jeffrey, > > On 07/02/19 8:22 PM, Jeffrey Hugo wrote: >> On 2/7/2019 1:50 AM, Alim Akhtar wrote: >>> Hi Marc, >>> >>> On 06/02/19 9:22 PM, Marc Gonzalez wrote: >>>> On 06/02/2019 16:27, Alim Akhtar wrote: >>>> >>>>> On 06/02/19 8:29 PM, Marc Gonzalez wrote: >>>>> >>>>>> [    2.405734] regulator_disable: ENTER vdd_l26 >>>>>> [    2.405958] regulator_disable: EXIT vdd_l26 >>>>>> [    2.406032]   regulator_set_load: vdd_l26 = 0 uA >>>>>> [    3.930447] ufshcd-qcom 1da4000.ufshc: ufshcd_query_attr: opcode >>>>>> 0x04 for idn 13 failed, index 0, err = -11 >>>>>> [    5.434358] ufshcd-qcom 1da4000.ufshc: ufshcd_query_attr: opcode >>>>>> 0x04 for idn 13 failed, index 0, err = -11 >>>>>> [    6.938318] ufshcd-qcom 1da4000.ufshc: ufshcd_query_attr: opcode >>>>>> 0x04 for idn 13 failed, index 0, err = -11 >>>>>> [    6.938414] ufshcd-qcom 1da4000.ufshc: ufshcd_query_attr_retry: >>>>>> query attribute, idn 13, failed with error -11 after 3 retires >>>>>> [    6.946959] ufshcd-qcom 1da4000.ufshc: >>>>>> ufshcd_disable_auto_bkops: failed to enable exception event -11 >>>>>> [    6.958523] ufshcd-qcom 1da4000.ufshc: dme-peer-get: attr-id >>>>>> 0x1587 failed 3 retries >>>>>> [    6.967730] ufshcd-qcom 1da4000.ufshc: dme-peer-get: attr-id >>>>>> 0x1586 failed 3 retries >>>>>> [    6.975576] ufshcd-qcom 1da4000.ufshc: ufshcd_get_max_pwr_mode: >>>>>> invalid max pwm tx gear read = 0 >>>>>> [    6.983306] ufshcd-qcom 1da4000.ufshc: ufshcd_probe_hba: Failed >>>>>> getting max supported power mode >>>>>> [    8.506314] ufshcd-qcom 1da4000.ufshc: ufshcd_query_flag: >>>>>> Sending flag query for idn 3 failed, err = -11 >>>>>> [   10.010352] ufshcd-qcom 1da4000.ufshc: ufshcd_query_flag: >>>>>> Sending flag query for idn 3 failed, err = -11 >>>>>> [   11.514313] ufshcd-qcom 1da4000.ufshc: ufshcd_query_flag: >>>>>> Sending flag query for idn 3 failed, err = -11 >>>>>> [   11.514412] ufshcd-qcom 1da4000.ufshc: ufshcd_query_flag_retry: >>>>>> query attribute, opcode 5, idn 3, failed with error -11 after 3 >>>>>> retires >>>>>> [   13.050354] ufshcd-qcom 1da4000.ufshc: >>>>>> __ufshcd_query_descriptor: opcode 0x01 for idn 8 failed, index 0, >>>>>> err = -11 >>>>>> [   14.554313] ufshcd-qcom 1da4000.ufshc: >>>>>> __ufshcd_query_descriptor: opcode 0x01 for idn 8 failed, index 0, >>>>>> err = -11 >>>>>> [   16.058313] ufshcd-qcom 1da4000.ufshc: >>>>>> __ufshcd_query_descriptor: opcode 0x01 for idn 8 failed, index 0, >>>>>> err = -11 >>>>>> [   16.058421] ufshcd-qcom 1da4000.ufshc: ufshcd_read_desc_param: >>>>>> Failed reading descriptor. desc_id 8, desc_index 0, param_offset 0, >>>>>> ret -11 >>>>>> [   16.067654] ufshcd-qcom 1da4000.ufshc: ufshcd_init_icc_levels: >>>>>> Failed reading power descriptor.len = 98 ret = -11 >>>>>> [   37.074334] ufshcd-qcom 1da4000.ufshc: link startup failed 1 >>>>> >>>>> Can you check if your UFS device RESET_N is asserted correctly. It >>>>> might >>>>> be connected to some regulator and may be you can try keeping that >>>>> regulator as "regulator-always-on" from your DT node. >>>> >>>> How do I check RESET_N? In software or hardware? >>>> >>> RST_N is the reset logic for UFS device core logic and it is input to >>> the device from UFS host controller.So, in your platform please check if >>> this line somehow connected to (pulled up) a PMIC supply. If that is the >>> case, please keep that regulator ON and see if this issue is resolved. >> >> The reset line is routed though the global clock controller (GCC), and >> must be explicitly asserted within the GCC to trigger a reset.  As far >> as I am aware, Linux is not touching this. >> >> Additionally, I fail to see how if this was a reset issue, reverting >> 60f0187031c0 would have any impact (which doing so addresses our issue) >> > OK, that's again implementation dependent and your platform used that > way. My point was to make sure that reset part is ok, if reset/power is > not proper to the UFS device core logic this kind of issues comes. We are following the Hardware Programming Guide written by the platform designers with regard to UFS, including the reset logic. I really don't think the reset logic is an issue here. > >>>> Do you think it is not a good idea to revert >>>> 60f0187031c05e04cbadffb62f557d0ff3564490 ? >>>> >>> Please hold on till we understand the real cause of this issue. Or we >>> have a consensuses for reverting the said commit. >>> Thanks! >> >> Did you see https://lkml.org/lkml/2019/2/5/659 where I indicated VCCQ >> powers components within the host controller, and by not setting load on >> the regulator properly, we are likely undervolting those components due >> to the current draw? >> > In theory may be true. But looks like we dont have a solid evidence yet > (correct me if I am wrong or misunderstood anything here The evidence seems simple. We have properly described in DT all the regulators that are consumed by the UFS host controller, and by extension, the UFS storage chip as well. By default, with no kernel changes, UFS does not work. Marc and I debugged the issue, and found that the VCCQ regulator was not being handled properly, and reverting the change we are discussing fixes the the VCCQ regulator issue, and as a result UFS works. Again, despite the fact that we may have a Samsung UFS storage chip, which triggers the quirk, the UFS host controller which talks to that chip requires VCCQ, therefore this quirk breaks us. > So that means its some short of hardware/board quirk, right? No > Can you please recheck the schematic and see what Bjorn is telling > (about having right entries in the DT for regulator) resolve your issue? Already done. The schematic defines vcc, vccq, and vccq2. All of those are listed in DT, and have been since Marc and I have been trying to utilize UFS. > > Marc, Can you disabled pmic on that board (hope your board boots with > default PMIC supply) and see if this issue still occurs? The PMIC is required the boot the board. I doubt the board will be functional with the PMIC disabled. > I am just trying to understand and see what is the real cause. Our analysis is that VCCQ is required and 60f0187031c05e04cbadffb62f557d0ff3564490 prevents the proper configuration of VCCQ, thus a required resource (VCCQ) is not in the proper state. > > @Yaniv Gardi, will you be able to comment on reason for adding > 60f0187031c05e04cbadffb62f557d0ff3564490 (any issue faced)? > -- Jeffrey Hugo Qualcomm Datacenter Technologies as an affiliate of Qualcomm Technologies, Inc. Qualcomm Technologies, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project.