Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2513484pxb; Tue, 21 Sep 2021 01:15:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz3QQ4Ky5u0XXMErBkP8dxlj9jaB77kbpEQe7NKeWvhW+WJNRiMmne/tTw9HVEIckcTHUY0 X-Received: by 2002:a05:6e02:ecd:: with SMTP id i13mr20413286ilk.143.1632212147434; Tue, 21 Sep 2021 01:15:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632212147; cv=none; d=google.com; s=arc-20160816; b=FR/6c5BRMeDLvzqkOpEeIqfS0XaZFzMi0JpqU9NkRohg3Tw40jqFgxS47p2QOLF1yT Ypow9A1jILkMzIjg8Pgu6yfQ08jynJFryNyOpY9jhnIZ/K+E2LnQd1SuPfUHo+ZJ4+2w 4dtIM25FiJUA7gSU4qdQ6vBw+2H+ERQGwfEVcbmfCqJla7h29hkc7KWvZv3NQ6lrawbh 92I1nI4XgGYMHVHpydJtv7Cm7ngxTh9b+hs7u8Mwq4Ik+LX+pJ+0GAmgBBegde2juv1U YAAlTByiHtN0UQUgjsWiGfB6ePS/ySIDjZodE5Yky2eh6lri6xJBnvaVR2PxKNozag9z WN1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:dmarc-filter:sender:dkim-signature; bh=VYuQcjJgBCV5YB1/ZkmdBfsOPsqJ+sm51i8VCCVd5I8=; b=X3WMRgeJ1K78QlmW73bh/Q298tNUTU2Jpw00ejf1hRl6XloBV/WWtbKXnhK8KHOeW5 hnVlyyajI/ogni/2RnNVNr+XO3Xo8sph1sKfd1ubZnRO7nMFa/y++fcTJnV3XGIXGRyn HGywOhmXEo9IRCIMJtOK6qJ/aN6zsrtLHXAEcWl2pt2iF5PhW0WTJvO1TkO/Tz9EbLvu fx3ctlARz+370oQds12sS5nqQl0S7gkPwVh+o9Zx5OJiT9VlH/A5SqOwdFC6Fjvmx8dK 5zp+jsKl3RdvDhnagOm25VOE2pOwWZ0HWBX1RQaSJhOD7CIbv8DCOuPvnCcQFzRqjeCy D0AQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=P4IWpjDJ; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l17si2651262ilt.1.2021.09.21.01.15.32; Tue, 21 Sep 2021 01:15:47 -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; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=P4IWpjDJ; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231151AbhIUIQQ (ORCPT + 99 others); Tue, 21 Sep 2021 04:16:16 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:34681 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230488AbhIUIQP (ORCPT ); Tue, 21 Sep 2021 04:16:15 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1632212087; h=Content-Transfer-Encoding: Content-Type: In-Reply-To: MIME-Version: Date: Message-ID: From: References: Cc: To: Subject: Sender; bh=VYuQcjJgBCV5YB1/ZkmdBfsOPsqJ+sm51i8VCCVd5I8=; b=P4IWpjDJTjZkzvf4fiMN/1ZUCoFpRzv1LEWk60ER5WTh+30YoiH/MvhMwnYnhAZ1qI4AItDa OZ2XYcd3LTQG93o58Rsz5NrjYsfWI6fOhe+s+MxD94Idoqu33ayLSTTvArAirG4eTpxoiK4A S0L+18bAEqCtBHigIWaMxE9YEUA= X-Mailgun-Sending-Ip: 69.72.43.7 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n07.prod.us-west-2.postgun.com with SMTP id 61499465648642cc1c3609e9 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Tue, 21 Sep 2021 08:14:29 GMT Sender: srivasam=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 549EFC43618; Tue, 21 Sep 2021 08:14:29 +0000 (UTC) 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=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, NICE_REPLY_A,SPF_FAIL,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.204.90] (unknown [157.48.173.130]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: srivasam) by smtp.codeaurora.org (Postfix) with ESMTPSA id 540C4C4338F; Tue, 21 Sep 2021 08:14:21 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 smtp.codeaurora.org 540C4C4338F 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=fail smtp.mailfrom=codeaurora.org Subject: Re: [PATCH 4/7] ASoC: codecs: lpass-va-macro: Change bulk voting to individual clock voting To: Srinivas Kandagatla , agross@kernel.org, bjorn.andersson@linaro.org, lgirdwood@gmail.com, broonie@kernel.org, robh+dt@kernel.org, plai@codeaurora.org, bgoswami@codeaurora.org, perex@perex.cz, tiwai@suse.com, rohitkr@codeaurora.org, linux-arm-msm@vger.kernel.org, alsa-devel@alsa-project.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, swboyd@chromium.org, judyhsiao@chromium.org Cc: Venkata Prasad Potturu References: <1632123331-2425-1-git-send-email-srivasam@codeaurora.org> <1632123331-2425-5-git-send-email-srivasam@codeaurora.org> <5f915592-0ca6-2839-43fc-6d9aef1484b7@linaro.org> From: Srinivasa Rao Mandadapu Organization: Qualcomm India Private Limited. Message-ID: <2378b5b1-fe45-171d-f8f9-373f8cece37f@codeaurora.org> Date: Tue, 21 Sep 2021 13:44:19 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.14.0 MIME-Version: 1.0 In-Reply-To: <5f915592-0ca6-2839-43fc-6d9aef1484b7@linaro.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 9/20/2021 6:55 PM, Srinivas Kandagatla wrote: > > Thanks for Your time Srini!!! > On 20/09/2021 08:35, Srinivasa Rao Mandadapu wrote: >> Change bulk clock frequency voting to individual voting. >> > Can you please explain why do we need to move out using clk bulk apis? > > Am not seeing any thing obvious behavior changing as part of this > patch, more details please.. In ADSP bypass use case, few clocks like macro and decode, are optional. So is the main reason for move out. And sometimes we are seeing bulk voting failed in Kodiak setup. >> Fixes: 908e6b1df26e (ASoC: codecs: lpass-va-macro: Add support to VA >> Macro) > > Why this has Fixes tag? Are we fixing any bug with this patch? Okay. As such we are not fixing any bug. Will remove this fixes tag on your suggestion. > >> >> Signed-off-by: Venkata Prasad Potturu >> Signed-off-by: Srinivasa Rao Mandadapu >> --- >>   sound/soc/codecs/lpass-va-macro.c | 46 >> ++++++++++++++++++++++++--------------- >>   1 file changed, 28 insertions(+), 18 deletions(-) >> >> diff --git a/sound/soc/codecs/lpass-va-macro.c >> b/sound/soc/codecs/lpass-va-macro.c >> index d312a14..0ea39ae 100644 >> --- a/sound/soc/codecs/lpass-va-macro.c >> +++ b/sound/soc/codecs/lpass-va-macro.c >> @@ -193,7 +193,10 @@ struct va_macro { >>         int dec_mode[VA_MACRO_NUM_DECIMATORS]; >>       struct regmap *regmap; >> -    struct clk_bulk_data clks[VA_NUM_CLKS_MAX]; >> +    struct clk *mclk; >> +    struct clk *macro; >> +    struct clk *dcodec; >> + >>       struct clk_hw hw; >>         s32 dmic_0_1_clk_cnt; >> @@ -1321,7 +1324,7 @@ static const struct clk_ops fsgen_gate_ops = { >>     static int va_macro_register_fsgen_output(struct va_macro *va) >>   { >> -    struct clk *parent = va->clks[2].clk; >> +    struct clk *parent = va->mclk; >>       struct device *dev = va->dev; >>       struct device_node *np = dev->of_node; >>       const char *parent_clk_name; >> @@ -1404,15 +1407,18 @@ static int va_macro_probe(struct >> platform_device *pdev) >>           return -ENOMEM; >>         va->dev = dev; >> -    va->clks[0].id = "macro"; >> -    va->clks[1].id = "dcodec"; >> -    va->clks[2].id = "mclk"; >>   -    ret = devm_clk_bulk_get(dev, VA_NUM_CLKS_MAX, va->clks); >> -    if (ret) { >> -        dev_err(dev, "Error getting VA Clocks (%d)\n", ret); >> -        return ret; >> -    } >> +    va->macro = devm_clk_get_optional(dev, "macro"); >> +    if (IS_ERR(va->macro)) >> +        return PTR_ERR(va->macro); >> + >> +    va->dcodec = devm_clk_get_optional(dev, "dcodec"); >> +    if (IS_ERR(va->dcodec)) >> +        return PTR_ERR(va->dcodec); >> + >> +    va->mclk = devm_clk_get(dev, "mclk"); >> +    if (IS_ERR(va->mclk)) >> +        return PTR_ERR(va->mclk); >>         ret = of_property_read_u32(dev->of_node, >> "qcom,dmic-sample-rate", >>                      &sample_rate); >> @@ -1426,10 +1432,11 @@ static int va_macro_probe(struct >> platform_device *pdev) >>       } >>         /* mclk rate */ >> -    clk_set_rate(va->clks[1].clk, VA_MACRO_MCLK_FREQ); >> -    ret = clk_bulk_prepare_enable(VA_NUM_CLKS_MAX, va->clks); >> -    if (ret) >> -        return ret; >> +    clk_set_rate(va->mclk, VA_MACRO_MCLK_FREQ); >> + >> +    clk_prepare_enable(va->mclk); >> +    clk_prepare_enable(va->macro); >> +    clk_prepare_enable(va->dcodec); >>         base = devm_platform_ioremap_resource(pdev, 0); >>       if (IS_ERR(base)) { >> @@ -1457,8 +1464,9 @@ static int va_macro_probe(struct >> platform_device *pdev) >>       return ret; >>     err: >> -    clk_bulk_disable_unprepare(VA_NUM_CLKS_MAX, va->clks); >> - >> +    clk_disable_unprepare(va->mclk); >> +    clk_disable_unprepare(va->macro); >> +    clk_disable_unprepare(va->dcodec); >>       return ret; >>   } >>   @@ -1466,8 +1474,10 @@ static int va_macro_remove(struct >> platform_device *pdev) >>   { >>       struct va_macro *va = dev_get_drvdata(&pdev->dev); >>   -    clk_bulk_disable_unprepare(VA_NUM_CLKS_MAX, va->clks); >> - >> +    of_clk_del_provider(pdev->dev.of_node); > > fsgen clk is registered using devm_* variant of clk apis, so why do we > need this here? > Okay. Will remove it and post new patch. > > --srini >> +    clk_disable_unprepare(va->mclk); >> +    clk_disable_unprepare(va->macro); >> +    clk_disable_unprepare(va->dcodec); >>       return 0; >>   } >> -- Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center, Inc., is a member of Code Aurora Forum, a Linux Foundation Collaborative Project.