Received: by 2002:a05:6358:700f:b0:131:369:b2a3 with SMTP id 15csp1979645rwo; Thu, 3 Aug 2023 02:59:13 -0700 (PDT) X-Google-Smtp-Source: APBJJlGAq+9lJZ8yn7TUjijahVf6cZou3V+IsWTfYHgUD7Gw07IC8chVAsN7MRZRSAbl2ye/l771 X-Received: by 2002:a05:6a21:33aa:b0:137:f985:f384 with SMTP id yy42-20020a056a2133aa00b00137f985f384mr19718571pzb.0.1691056752961; Thu, 03 Aug 2023 02:59:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691056752; cv=none; d=google.com; s=arc-20160816; b=B9B4iLZi4976GZQ4whhBF/2s9Bi6Kkc4pipmUh+lkS5tbqoe1+7WkDOKWsIG4LA2gX hmADNavPhjy087IiHuaIFo/brKQAbop388Cl1B8GcaPjHfneqjTe44JPy6hfoS1Yxg3t wTCfardpr69QUQbd2Tse1sly9vZX/vVSgt5M7pj0UeOInKRtQo829B48xTA9e3bJl3Wr NL+QYMs7BoctfM4AcBVEWYzjHfMC3Fv+Mg8YySZG1obGXfynoaNqzd1/rVmL5h/Q/CtO T/2t8gXmkiNXZnhKlr9w+p6ofrDd4lYpqNhSmTZc9rZC72pcKEcCHO8gT8S+cdWtIZH0 X6ZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=tP0Se9e5OenhDQmCRLMo3D3ZF2M+nSBl11NrzbNnyjI=; fh=RMpaJOXVVKRMI29ZGP8UjT1K7wjWmBhEjEE6YhkoKlA=; b=ROcsqUCBJFeheE4OpE0AHZOSO4nYNvs52hLjSjMh1b7jp3Z4sOG2tm9KSMP/pathWZ UhYq5tc1wvGTH7767QybFQTSvVFIgHWVesucwXICwjV6ms9o6ORrGSHVlbpEAIfmPl4o lJzuUTPUjzyQAcbgrdMbhbJJbeQlV+qB3wgAeFNZy0Xxkqa8wd5d7SFoFRL67fU0Hg61 6kSlafSfHPYHh8bgKrw2nvhesoO4ZITagqAk270EpLL65jkcdvPLfSsLnZw+ev8GCjMu KO7WWjGUdI0vxXnRFtz3+Fx2i8670Yv18zd6sFly7bmQ+96Lh6TUxhvc3Jl0k5vVk8SX oyZw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id cp20-20020a056a00349400b00666ad95e625si7832437pfb.337.2023.08.03.02.59.00; Thu, 03 Aug 2023 02:59:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231492AbjHCIjw (ORCPT + 99 others); Thu, 3 Aug 2023 04:39:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58990 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234700AbjHCIj2 (ORCPT ); Thu, 3 Aug 2023 04:39:28 -0400 Received: from fd01.gateway.ufhost.com (fd01.gateway.ufhost.com [61.152.239.71]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9B52F4221; Thu, 3 Aug 2023 01:38:00 -0700 (PDT) Received: from EXMBX166.cuchost.com (unknown [175.102.18.54]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "EXMBX166", Issuer "EXMBX166" (not verified)) by fd01.gateway.ufhost.com (Postfix) with ESMTP id AC5BE8067; Thu, 3 Aug 2023 16:37:52 +0800 (CST) Received: from EXMBX172.cuchost.com (172.16.6.92) by EXMBX166.cuchost.com (172.16.6.76) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Thu, 3 Aug 2023 16:37:52 +0800 Received: from [192.168.125.84] (183.27.98.54) by EXMBX172.cuchost.com (172.16.6.92) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Thu, 3 Aug 2023 16:37:51 +0800 Message-ID: <34c8c9d5-fad0-52ce-d1e6-798546005bfd@starfivetech.com> Date: Thu, 3 Aug 2023 16:37:50 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.3.2 Subject: Re: [PATCH v2 2/3] ASoC: starfive: Add JH7110 PWM-DAC driver Content-Language: en-US To: Mark Brown CC: Liam Girdwood , Jaroslav Kysela , Takashi Iwai , Claudiu Beznea , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Walker Chen , Xingyu Wu , Emil Renner Berthing , , , , References: <20230731032829.127864-1-hal.feng@starfivetech.com> <20230731032829.127864-3-hal.feng@starfivetech.com> <9b03c7ed-845c-494b-8c40-10d1fe923b15@sirena.org.uk> From: Hal Feng In-Reply-To: <9b03c7ed-845c-494b-8c40-10d1fe923b15@sirena.org.uk> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [183.27.98.54] X-ClientProxiedBy: EXCAS066.cuchost.com (172.16.6.26) To EXMBX172.cuchost.com (172.16.6.92) X-YovoleRuleAgent: yovoleflag X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 31 Jul 2023 20:14:38 +0100, Mark Brown wrote: > On Mon, Jul 31, 2023 at 11:28:28AM +0800, Hal Feng wrote: > >> +static const struct jh7110_ct_pwmdac pwmdac_ct_data_shift[] = { >> + { .name = "left 0 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_0 }, >> + { .name = "left 1 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_1 }, >> + { .name = "left 2 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_2 }, >> + { .name = "left 3 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_3 }, >> + { .name = "left 4 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_4 }, >> + { .name = "left 5 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_5 }, >> + { .name = "left 6 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_6 }, >> + { .name = "left 7 bit", .vals = PWMDAC_DATA_LEFT_SHIFT_BIT_7 } >> +}; > > It's not clear to me why this is user selectable - what does the control > do? It's convenient to change the register values in user space with the control. But actually using fixed register configuration is enough. I will drop all these control in the next version. > >> +static int jh7110_pwmdac_put(struct snd_kcontrol *kcontrol, >> + struct snd_ctl_elem_value *ucontrol, >> + int pwmdac_ct) >> +{ >> + struct snd_soc_component *component = snd_kcontrol_chip(kcontrol); >> + struct jh7110_pwmdac_dev *dev = snd_soc_component_get_drvdata(component); >> + int sel = ucontrol->value.enumerated.item[0]; >> + unsigned int items; > >> + if (pwmdac_ct == PWMDAC_CT_SHIFT) >> + dev->shift = pwmdac_ct_shift[sel].vals; >> + else if (pwmdac_ct == PWMDAC_CT_DUTY_CYCLE) >> + dev->duty_cycle = pwmdac_ct_duty_cycle[sel].vals; >> + else if (pwmdac_ct == PWMDAC_CT_DATA_CHANGE) >> + dev->data_change = pwmdac_ct_data_change[sel].vals; >> + else if (pwmdac_ct == PWMDAC_CT_DATA_MODE) >> + dev->data_mode = pwmdac_ct_data_mode[sel].vals; >> + else if (pwmdac_ct == PWMDAC_CT_DATA_SHIFT) >> + dev->data_shift = pwmdac_ct_data_shift[sel].vals; >> + >> + return 0; >> +} > > _put() operations should return 1 if the control value changes so event > generation works - please test a card using this driver with the > mixer-test selftest, it'll identify this and a bunch of other potential > issues. Thanks for the correct, but it doesn't matter as I will drop these control later. > >> +static int jh7110_pwmdac_component_probe(struct snd_soc_component *component) >> +{ >> + snd_soc_add_component_controls(component, jh7110_pwmdac_snd_controls, >> + ARRAY_SIZE(jh7110_pwmdac_snd_controls)); >> + return 0; >> +} > > The driver can just point to the controls from the _driver struct and > skip having a probe() function. Thanks for your advice, but I would like to drop these control later. Thanks again for your review. Best regards, Hal