Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp748471imm; Wed, 25 Jul 2018 05:40:23 -0700 (PDT) X-Google-Smtp-Source: AAOMgpenEGIcUKbXegULaxSpreU8oEK5R1MXFWl4CbYjTTRtgtGzHvj20gU9iYiz4gNypRd1BwIz X-Received: by 2002:a17:902:6b0b:: with SMTP id o11-v6mr21294403plk.101.1532522423484; Wed, 25 Jul 2018 05:40:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532522423; cv=none; d=google.com; s=arc-20160816; b=uLlHSmoVy4c66fWumozjdKs8P8afPLPkjGDwQliM/6YUnEDi/xItV+6Lo/yIzz5zfP /ASbtZAKqkoCp2RhcLUTY/nFOhO48JMca7gv9jTq/N7tmA7msrgZGGMasix0AsdVZM5J dZ9VfwOAyPw3BKlbQoi8s66MSd7BDmBUpnfVuW/itx4uveqbYFCutPrHnc57PahmDW9+ KshcYWLfGHpG7Wesn0/lpIK9w+n7VDdPMsn2jw4XEZM87W9FOOrZVGsU9taBV8w1md5S abahMdKaF6IHdV1PZJc9dj5tCD79Gndly8C2P7q1vlqZqB0buTZahiydGomZtaOgIPVi 8eNA== 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:organization:from:references:cc:to:subject :arc-authentication-results; bh=B7DqS7ePbmhn03tXzFghMu6Ik1taASVsWfnZLsfc+so=; b=wQpYXyEaBjmmnXE6fz58zhDF/gtnLIWMgHRPChL4Sp88MHVXGQvHBllNXEAYJHxR6Z FZwTMhQ53Ly8kGEGnIvkAR9FQwtTrZsj69cWiC4OdbRPQaqL/xDjFooyzY/8IbQDlnpx JO8gD/PiAow0BoagTrTaJl5rVLvCJYI9LJDAhDqPJDcgK62qLAr1OlIcjSqyzdtagJoZ 5S1aNGaJnKU+RbL0JeC/9JacnYBUu/pNgJvhOwAei5bpA8YqCQaDtIY/eEmRcIoJcRyQ lwuZKJkJ0VwhN1BnKhvEMpkleRx2FOgfiDuERc+0GXvcsoRcrrN6cx+l53jv/2pqS8Sd Smdw== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n9-v6si12905849pff.370.2018.07.25.05.40.08; Wed, 25 Jul 2018 05:40:23 -0700 (PDT) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729043AbeGYNun (ORCPT + 99 others); Wed, 25 Jul 2018 09:50:43 -0400 Received: from mga04.intel.com ([192.55.52.120]:10757 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728667AbeGYNun (ORCPT ); Wed, 25 Jul 2018 09:50:43 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 25 Jul 2018 05:39:12 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,401,1526367600"; d="scan'208";a="57769477" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.168]) ([10.237.72.168]) by fmsmga008.fm.intel.com with ESMTP; 25 Jul 2018 05:39:07 -0700 Subject: Re: [PATCH V1 1/3] mmc: sdhci: Allow platform controlled voltage switching To: Vijay Viswanath , ulf.hansson@linaro.org, robh+dt@kernel.org, mark.rutland@arm.com Cc: linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, shawn.lin@rock-chips.com, linux-arm-msm@vger.kernel.org, georgi.djakov@linaro.org, devicetree@vger.kernel.org, asutoshd@codeaurora.org, stummala@codeaurora.org, venkatg@codeaurora.org, jeremymc@redhat.com, bjorn.andersson@linaro.org, riteshh@codeaurora.org, vbadigan@codeaurora.org, evgreen@chromium.org, dianders@google.com, sayalil@codeaurora.org, rampraka@codeaurora.org References: <1532083566-43215-1-git-send-email-vviswana@codeaurora.org> <1532083566-43215-2-git-send-email-vviswana@codeaurora.org> <33e12e51-4b96-032f-845f-7910d654018c@intel.com> <42ee57f7-8a99-b815-12db-2727ed67872b@codeaurora.org> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: Date: Wed, 25 Jul 2018 15:37:29 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.0 MIME-Version: 1.0 In-Reply-To: <42ee57f7-8a99-b815-12db-2727ed67872b@codeaurora.org> Content-Type: text/plain; charset=utf-8 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 25/07/18 15:23, Vijay Viswanath wrote: > Hi Adrian, > > > On 7/25/2018 5:23 PM, Adrian Hunter wrote: >> On 20/07/18 13:46, Vijay Viswanath wrote: >>> Some controllers can have internal mechanism to inform the SW that it >>> is ready for voltage switching. For such controllers, changing voltage >>> before the HW is ready can result in various issues. >>> >>> During setup/cleanup of host, check whether regulator enable/disable >>> was already done by platform driver. >>> >>> Signed-off-by: Vijay Viswanath >>> --- >>>   drivers/mmc/host/sdhci.c | 21 ++++++++++++++++----- >>>   1 file changed, 16 insertions(+), 5 deletions(-) >>> >>> diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c >>> index 1c828e0..494a1e2 100644 >>> --- a/drivers/mmc/host/sdhci.c >>> +++ b/drivers/mmc/host/sdhci.c >>> @@ -3472,6 +3472,7 @@ int sdhci_setup_host(struct sdhci_host *host) >>>       unsigned int override_timeout_clk; >>>       u32 max_clk; >>>       int ret; >>> +    bool enable_vqmmc = false; >>>         WARN_ON(host == NULL); >>>       if (host == NULL) >>> @@ -3485,7 +3486,12 @@ int sdhci_setup_host(struct sdhci_host *host) >>>        * the host can take the appropriate action if regulators are not >>>        * available. >>>        */ >>> -    ret = mmc_regulator_get_supply(mmc); >>> +    if (!mmc->supply.vmmc) { >>> +        ret = mmc_regulator_get_supply(mmc); >>> +        enable_vqmmc  = true; >>> +    } else { >>> +        ret = 0; >>> +    } >>>       if (ret) >>>           return ret; >> >> Why not >> >>     if (!mmc->supply.vmmc) { >>         ret = mmc_regulator_get_supply(mmc); >>           if (ret) >>                return ret; >>         enable_vqmmc  = true; >>     } >> > > looks neater. Will do. > >>>   @@ -3736,7 +3742,10 @@ int sdhci_setup_host(struct sdhci_host *host) >>>         /* If vqmmc regulator and no 1.8V signalling, then there's no UHS */ >>>       if (!IS_ERR(mmc->supply.vqmmc)) { >>> -        ret = regulator_enable(mmc->supply.vqmmc); >>> +        if (enable_vqmmc) >>> +            ret = regulator_enable(mmc->supply.vqmmc); >> >> Please introduce host->vqmmc_enabled = !ret; >> > > Any reason to introduce vqmmc_enabled variable in sdhci_host structure ? We > can get around with a local variable and using regulator_is_enabled API. regulator_enable() uses reference counting, so we have to use regulator_disable() exactly the same number of times that we use regulator_enable(). > >>> +        else >>> +            ret = 0; >>>           if (!regulator_is_supported_voltage(mmc->supply.vqmmc, 1700000, >>>                               1950000)) >>>               host->caps1 &= ~(SDHCI_SUPPORT_SDR104 | >>> @@ -3984,7 +3993,7 @@ int sdhci_setup_host(struct sdhci_host *host) >>>       return 0; >>>     unreg: >>> -    if (!IS_ERR(mmc->supply.vqmmc)) >>> +    if (!IS_ERR(mmc->supply.vqmmc) && enable_vqmmc) >> >> And just make this >> >>     if (host->vqmmc_enabled) >> >>>           regulator_disable(mmc->supply.vqmmc); >>>   undma: >>>       if (host->align_buffer) >>> @@ -4002,7 +4011,8 @@ void sdhci_cleanup_host(struct sdhci_host *host) >>>   { >>>       struct mmc_host *mmc = host->mmc; >>>   -    if (!IS_ERR(mmc->supply.vqmmc)) >>> +    if (!IS_ERR(mmc->supply.vqmmc) && >>> +            (regulator_is_enabled(mmc->supply.vqmmc) > 0)) >> >>     if (host->vqmmc_enabled) >> >>>           regulator_disable(mmc->supply.vqmmc); >>>         if (host->align_buffer) >>> @@ -4135,7 +4145,8 @@ void sdhci_remove_host(struct sdhci_host *host, int >>> dead) >>>         tasklet_kill(&host->finish_tasklet); >>>   -    if (!IS_ERR(mmc->supply.vqmmc)) >>> +    if (!IS_ERR(mmc->supply.vqmmc) && >>> +            (regulator_is_enabled(mmc->supply.vqmmc) > 0)) >> >>     if (host->vqmmc_enabled) >> >>>           regulator_disable(mmc->supply.vqmmc); >>>         if (host->align_buffer) >>> >> >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-mmc" in >> the body of a message to majordomo@vger.kernel.org >> More majordomo info at  http://vger.kernel.org/majordomo-info.html >> > > Thanks, > Vijay >