Received: by 2002:a05:6358:c692:b0:131:369:b2a3 with SMTP id fe18csp4058077rwb; Sun, 30 Jul 2023 23:58:04 -0700 (PDT) X-Google-Smtp-Source: APBJJlFawQgjVWlwndlYygtV6gQ12W0FvRiNjbdKb7a03trVCDvUx02FTcSi3zM1giMhgKnl+nRm X-Received: by 2002:a50:fa8d:0:b0:522:38cb:d8cb with SMTP id w13-20020a50fa8d000000b0052238cbd8cbmr6593206edr.20.1690786683936; Sun, 30 Jul 2023 23:58:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690786683; cv=none; d=google.com; s=arc-20160816; b=O8jaVIz+fgGVyr0G2pDElAcfTAsAowki+q8TbDAhUOABb9xPsEDkS6zIKfbQ1OwW7S UwzXxV3EKEPiJdhIubo8Pm5EtU8/SEXvnfKu7eFx3uGhqhSwp7rW+uf7jwiKEzXGUlMB UAhA/JHzFAh8AeOK2CJwDNY+krPy7EHbMo0kOVBgZ/HR6VfnrxqgB1aXuSabtxhCixVA Jfm5oVudt0HcgQoyDiUhmfoTxNIBIdrK7gPNvSIw6GLvyTP+DaAt/a5DHJ+SWGv74gKf odrNPso5lSb0vKQwlTCxLgJPiVx5O1lv4KMvlEYnweC6g3w0dTYoBGCFXtZ8NVAoFZtj zGXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=r8Z1KCRbh8BOiBoP5c49vjmNSPAG1hDNsgNbkK+qmrM=; fh=pXwDPJYR16PHmT/Pg8MoKq4wWtpmbWINpREGWWdfn9k=; b=tQZ7LbuizwAwkbwiV4+f16kwcpvJRYWh26lOfd9S61+fkha2w0ldomWMdWSuKf3ti1 w3HH7cb9wUESxRpmBEv8bMsR5b/cgSiZqX4tqPOSBKrvulV0f7p2On1B95Kb1s46IgTa D/jBZn5s+EaJ9U/KKt7zkjg/Y5b/vO2+39awCzB78ue56qcg3qZ4FNw5SjNVfGz32VRQ N1cQssv1srhrtnxYp9RlaOfu3Se68IBCvI3SnM695o2n/Eh4YyTz6ScN/U6DRRd3f9u0 NngNtUMze2dgHVFsTRVJ362OSE6nx/tVI69X0u8X8I1lFUGXbjLRRUEo1R90ceih3qBk Z+Gg== 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 g12-20020aa7c58c000000b00522b962a41bsi2745728edq.4.2023.07.30.23.57.39; Sun, 30 Jul 2023 23:58:03 -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 S229937AbjGaGjW (ORCPT + 99 others); Mon, 31 Jul 2023 02:39:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57616 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229735AbjGaGjV (ORCPT ); Mon, 31 Jul 2023 02:39:21 -0400 Received: from out28-195.mail.aliyun.com (out28-195.mail.aliyun.com [115.124.28.195]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7851B1A5; Sun, 30 Jul 2023 23:39:19 -0700 (PDT) X-Alimail-AntiSpam: AC=CONTINUE;BC=0.07436259|-1;CH=green;DM=|CONTINUE|false|;DS=CONTINUE|ham_system_inform|0.00400371-0.000150313-0.995846;FP=0|0|0|0|0|-1|-1|-1;HT=ay29a033018047205;MF=wangweidong.a@awinic.com;NM=1;PH=DS;RN=26;RT=26;SR=0;TI=SMTPD_---.U4bHBGG_1690785547; Received: from ubuntu-VirtualBox..(mailfrom:wangweidong.a@awinic.com fp:SMTPD_---.U4bHBGG_1690785547) by smtp.aliyun-inc.com; Mon, 31 Jul 2023 14:39:10 +0800 From: wangweidong.a@awinic.com To: krzysztof.kozlowski@linaro.org Cc: 13916275206@139.com, alsa-devel@alsa-project.org, broonie@kernel.org, ckeepax@opensource.cirrus.com, colin.i.king@gmail.com, conor+dt@kernel.org, devicetree@vger.kernel.org, doug@schmorgal.com, fido_max@inbox.ru, herve.codina@bootlin.com, krzysztof.kozlowski+dt@linaro.org, lgirdwood@gmail.com, linux-kernel@vger.kernel.org, liweilei@awinic.com, perex@perex.cz, povik+lin@cutebit.org, rf@opensource.cirrus.com, robh+dt@kernel.org, ryans.lee@analog.com, shumingf@realtek.com, tiwai@suse.com, trix@redhat.com, wangweidong.a@awinic.com, yijiangtao@awinic.com, zhangjianming@awinic.com Subject: Re: [PATCH V3 3/5] ASoC: codecs: Add aw88261 amplifier driver Date: Mon, 31 Jul 2023 14:39:07 +0800 Message-ID: <20230731063907.4097-1-wangweidong.a@awinic.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <4d822ff6-b7e6-20e2-6087-78941488a3cf@linaro.org> References: <4d822ff6-b7e6-20e2-6087-78941488a3cf@linaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY 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 Thank you very much for your review, but I have a few questions I'd like to discuss with you On 29/07/2023 19:22, krzysztof.kozlowski@linaro.org wrote: > On 29/07/2023 11:12, wangweidong.a@awinic.com wrote: >> From: Weidong Wang >> >> Add i2c and amplifier registration for >> aw88261 and their associated operation functions. >> >> Signed-off-by: Weidong Wang >> --- >> sound/soc/codecs/aw88261/aw88261.c | 517 +++++++++++++++++++++++++++++ >> sound/soc/codecs/aw88261/aw88261.h | 52 +++ >> 2 files changed, 569 insertions(+) >> create mode 100644 sound/soc/codecs/aw88261/aw88261.c >> create mode 100644 sound/soc/codecs/aw88261/aw88261.h >> >> + >> +static int aw88261_request_firmware_file(struct aw88261 *aw88261) >> +{ >> + const struct firmware *cont = NULL; >> + int ret; >> + >> + aw88261->aw_pa->aw88261_base->fw_status = AW88261_DEV_FW_FAILED; >> + >> + ret = request_firmware(&cont, AW88261_ACF_FILE, aw88261->aw_pa->dev); >> + if (ret < 0) { >> + dev_err_probe(aw88261->aw_pa->dev, ret, "load [%s] failed!", AW88261_ACF_FILE); >> + return ret; > That's not how you use dev_err_probe. Instead: return dev_err_probe Thank you very much. I will changed it to "return dev_err_probe(aw88261->aw_pa->dev, ret, "load [%s] failed!", AW88261_ACF_FILE)". >> + } >> + >> + dev_info(aw88261->aw_pa->dev, "loaded %s - size: %zu\n", >> + AW88261_ACF_FILE, cont ? cont->size : 0); >> + >> + aw88261->aw_cfg = devm_kzalloc(aw88261->aw_pa->dev, cont->size + sizeof(int), GFP_KERNEL); >> + if (!aw88261->aw_cfg) { >> + release_firmware(cont); >> + return -ENOMEM; >> + } >> + aw88261->aw_cfg->len = (int)cont->size; >> + memcpy(aw88261->aw_cfg->data, cont->data, cont->size); >> + release_firmware(cont); >> + >> + ret = aw88395_dev_load_acf_check(aw88261->aw_pa->aw88261_base, aw88261->aw_cfg); >> + if (ret < 0) { >> + dev_err_probe(aw88261->aw_pa->dev, ret, "load [%s] failed !", AW88261_ACF_FILE); >> + return ret; > return dev_err_probe I want to use "dev_err" here, Because the aw88395_dev_load_acf_check function only checks the bin file, it does not involve the application of resources >> + } >> + >> + mutex_lock(&aw88261->lock); >> + /* aw device init */ >> + ret = aw88261_dev_init(aw88261->aw_pa, aw88261->aw_cfg); >> + if (ret < 0) >> + dev_err(aw88261->aw_pa->dev, "dev init failed"); >> + mutex_unlock(&aw88261->lock); >> + >> + return ret; >> +} >> + >> +static int aw88261_codec_probe(struct snd_soc_component *component) >> +{ >> + struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); >> + struct aw88261 *aw88261 = snd_soc_component_get_drvdata(component); >> + int ret; >> + >> + INIT_DELAYED_WORK(&aw88261->start_work, aw88261_startup_work); >> + >> + ret = aw88261_request_firmware_file(aw88261); >> + if (ret < 0) { >> + dev_err_probe(aw88261->aw_pa->dev, ret, "aw88261_request_firmware_file failed\n"); >> + return ret; > return dev_err_probe Thank you very much. I'll change it to "return dev_err_probe" >> + } >> + >> + /* add widgets */ >> + ret = snd_soc_dapm_new_controls(dapm, aw88261_dapm_widgets, >> + ARRAY_SIZE(aw88261_dapm_widgets)); >> + if (ret < 0) >> + return ret; >> + >> + /* add route */ >> + ret = snd_soc_dapm_add_routes(dapm, aw88261_audio_map, >> + ARRAY_SIZE(aw88261_audio_map)); >> + if (ret < 0) >> + return ret; >> + >> + ret = snd_soc_add_component_controls(component, aw88261_controls, >> + ARRAY_SIZE(aw88261_controls)); >> + >> + return ret; >> +} >> + >> +static void aw88261_codec_remove(struct snd_soc_component *aw_codec) >> +{ >> + struct aw88261 *aw88261 = snd_soc_component_get_drvdata(aw_codec); >> + >> + cancel_delayed_work_sync(&aw88261->start_work); >> +} >> + >> +static const struct snd_soc_component_driver soc_codec_dev_aw88261 = { >> + .probe = aw88261_codec_probe, >> + .remove = aw88261_codec_remove, >> +}; >> + >> +static void aw88261_hw_reset(struct aw88261 *aw88261) >> +{ >> + gpiod_set_value_cansleep(aw88261->reset_gpio, 0); >> + usleep_range(AW88261_1000_US, AW88261_1000_US + 10); >> + gpiod_set_value_cansleep(aw88261->reset_gpio, 1); >> + usleep_range(AW88261_1000_US, AW88261_1000_US + 10); >> +} >> + >> +static int aw88261_i2c_probe(struct i2c_client *i2c) >> +{ >> + struct aw88261 *aw88261; >> + int ret; >> + >> + ret = i2c_check_functionality(i2c->adapter, I2C_FUNC_I2C); >> + if (!ret) { >> + dev_err_probe(&i2c->dev, ret, "check_functionality failed"); >> + return -ENXIO; > return dev_err_probe Thank you very much. I'll change it to "return dev_err_probe" >> + } >> + >> + aw88261 = devm_kzalloc(&i2c->dev, sizeof(struct aw88261), GFP_KERNEL); > sizeof(*) Thank you very much. I will change it to "devm_kzalloc(&i2c->dev, sizeof(*aw88261), GFP_KERNEL)". >> + if (!aw88261) >> + return -ENOMEM; >> + >> + mutex_init(&aw88261->lock); >> + >> + i2c_set_clientdata(i2c, aw88261); >> + >> + aw88261->reset_gpio = devm_gpiod_get_optional(&i2c->dev, "reset", GPIOD_OUT_LOW); >> + if (IS_ERR(aw88261->reset_gpio)) >> + dev_info(&i2c->dev, "reset gpio not defined\n"); >> + else >> + aw88261_hw_reset(aw88261); >> + >> + aw88261->regmap = devm_regmap_init_i2c(i2c, &aw88261_remap_config); >> + if (IS_ERR(aw88261->regmap)) { >> + ret = PTR_ERR(aw88261->regmap); >> + dev_err_probe(&i2c->dev, ret, "failed to init regmap: %d\n", ret); >> + return ret; > return dev_err_probe > I asked you about this in your first version. I explicitly wrote "return > dev_err_probe", not some other syntax. Thank you very much. I'll change it to "return dev_err_probe" Best regards, Weidong Wang