Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp6850857rwr; Tue, 9 May 2023 23:38:29 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7+BW7NP5vQYMva8jnS4qX0twGxK303P/LwBacY0ROXEDrYgzX5VnCfnUA6NaVTXGC7RP7E X-Received: by 2002:a17:90a:e38f:b0:23a:5f51:6ee5 with SMTP id b15-20020a17090ae38f00b0023a5f516ee5mr17737752pjz.12.1683700709746; Tue, 09 May 2023 23:38:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683700709; cv=none; d=google.com; s=arc-20160816; b=HbKY7Nfto0l+f2Couc/cg9OeEw6Vy+0BmS4pBuUa9YBkfmsIoCBLWBd55J+vkcokBi JH1J47IIm8gubwMRW2UamAdsrm/NzDsHU6yGgNNabZl8TC+mjN0JwxFJx4UXCC71/KqC bpewvRnCGd/0YH3wvf1BOxE25WjqkHxonaXVIm/hd0wo+JoGBfuXyrKpmpzdIQBzFXHb 5ikNI9jDkEAMoYkp4kYAe71uTM7zjyW7JzzviqU1EdKqj40JhRTamkfWYB53p3rzwzQz zRDAs1znOHsoWUWSq4DXvfW2ed7mK2zZKTtRoZBwF35hOhhb6KWKfybUJJ+ao6EvXpQa jjTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version:dkim-signature; bh=qTralI+BjXkUYeKdpt1EKOYLurUZJUqEWnuIzQBEp7g=; b=AdiOlxC92TgZj+Elx04F2bMFeyADx7+ezE120uSybs2voI0RUL5N0pZdpFBq2nT8gk pCMjUYINSF8LacQ9GskIwo0sBtA2VUdPNnIUf8B0FmtcniatO0MaSOkSIYpUOBz2b0oS E3dthTsbb6r9y0LfvtVmZlqz8UYLmyNgfc1to+a7MuSQm/4VRePoC+2sj5YTk0uzHRLd JOjysZ6achwxVs/zxAvbGVam+G1sOr6LxxuPqXgAoN4Mb3Vy9tBDW9DESsaS+WMUdqc8 xmi2ie5VIgu9r9pYGem6+yM3325liOygHZw3ePhgEO7ZKxEPmIpgfAAWoLHZSzRtnBKo ecwQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cutebit.org header.s=mail header.b=PmPugz2x; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cutebit.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 130-20020a630288000000b0050c0a00c1edsi3502066pgc.703.2023.05.09.23.38.16; Tue, 09 May 2023 23:38:29 -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; dkim=pass header.i=@cutebit.org header.s=mail header.b=PmPugz2x; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cutebit.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235962AbjEJGYu (ORCPT + 99 others); Wed, 10 May 2023 02:24:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35412 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235734AbjEJGYq (ORCPT ); Wed, 10 May 2023 02:24:46 -0400 Received: from hutie.ust.cz (hutie.ust.cz [185.8.165.127]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CAA2059F3; Tue, 9 May 2023 23:24:00 -0700 (PDT) Content-Type: text/plain; charset=utf-8 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cutebit.org; s=mail; t=1683699815; bh=qTralI+BjXkUYeKdpt1EKOYLurUZJUqEWnuIzQBEp7g=; h=Subject:From:In-Reply-To:Date:Cc:References:To; b=PmPugz2x90kQffxeCbG0qp9sZuQ50W491xv2ssNip1mGx5wefSNn7yw7IpH//9OjO YL6cgtQNHGKBncWB8bmKNeg+LGFJiXkZ9RgObhHFtyBEQiWdCBRggzCbS8EE1RmHkS /SoJHaiCoNMrqu+0713ZUsg4pWuun9aPZEIOy/sA= Mime-Version: 1.0 (Mac OS X Mail 16.0 \(3696.120.41.1.1\)) Subject: Re: [PATCH 2/2] ASoC: ssm3515: Add new amp driver From: =?utf-8?Q?Martin_Povi=C5=A1er?= In-Reply-To: Date: Wed, 10 May 2023 08:23:34 +0200 Cc: Liam Girdwood , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Jaroslav Kysela , Takashi Iwai , Lars-Peter Clausen , =?utf-8?Q?Nuno_S=C3=A1?= , asahi@lists.linux.dev, alsa-devel@alsa-project.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Content-Transfer-Encoding: quoted-printable Message-Id: References: <20230509163828.86003-1-povik+lin@cutebit.org> <20230509163828.86003-2-povik+lin@cutebit.org> To: Mark Brown X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 10. 5. 2023, at 4:16, Mark Brown wrote: >=20 > On Tue, May 09, 2023 at 06:38:28PM +0200, Martin Povi=C5=A1er wrote: >=20 >> +static int ssm3515_setup(struct snd_soc_component *component) >> +{ >> + struct ssm3515_data *data =3D >> + snd_soc_component_get_drvdata(component); >> + int ret; >> + >> + ret =3D snd_soc_component_update_bits(component, SSM3515_GEC, >> + SSM3515_GEC_ANA_GAIN, >> + FIELD_PREP(SSM3515_GEC_ANA_GAIN, = data->ana_gain)); >> + if (ret < 0) >> + return ret; >> + >> + /* Start out muted */ >> + ret =3D snd_soc_component_update_bits(component, SSM3515_DAC, >> + SSM3515_DAC_MUTE, SSM3515_DAC_MUTE); >> + if (ret < 0) >> + return ret; >=20 > Why are we not using the chip defaults here? We use those for most > things as what's appropraite for one user might not be appropriate for > another and it's easier to agree to follow what the chip does than to > select things. There's some exceptions like for zero cross options = but > not typically for gains and mutes. This bit is controlled by the mute DAI op, where it is expected the component starts out muted. The datasheet promises pop-free experience if this bit is sequenced with the disablement of clocks, so it seems like a good fit for said op. >> +static int ssm3515_probe(struct snd_soc_component *component) >> +{ >> + struct ssm3515_data *data =3D >> + snd_soc_component_get_drvdata(component); >> + int ret; >> + >> + ret =3D ssm3515_reset(component); >> + if (ret < 0) >> + return ret; >> + regmap_reinit_cache(data->regmap, &ssm3515_i2c_regmap); >> + >> + return ssm3515_setup(component); >> +} >=20 > We don't normally reset things on component probe, only on bus level > probe... I don=E2=80=99t think I have a strong reason to do this.