From: Herve Codina <herve.codina@bootlin.com>
To: andy.shevchenko@gmail.com
Cc: Liam Girdwood <lgirdwood@gmail.com>,
Mark Brown <broonie@kernel.org>, Rob Herring <robh+dt@kernel.org>,
Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>,
Conor Dooley <conor+dt@kernel.org>,
Jonathan Cameron <jic23@kernel.org>,
Lars-Peter Clausen <lars@metafoo.de>,
Jaroslav Kysela <perex@perex.cz>, Takashi Iwai <tiwai@suse.com>,
Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>,
alsa-devel@alsa-project.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org,
Christophe Leroy <christophe.leroy@csgroup.eu>,
Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Subject: Re: [PATCH v2 7/9] ASoC: codecs: Add support for the generic IIO auxiliary devices
Date: Tue, 6 Jun 2023 15:54:04 +0200 [thread overview]
Message-ID: <20230606155404.28ada064@bootlin.com> (raw)
In-Reply-To: <ZHuFywIrTnEFpX6e@surfacebook>
Hi Andy,
On Sat, 3 Jun 2023 21:26:19 +0300
andy.shevchenko@gmail.com wrote:
> Tue, May 23, 2023 at 05:12:21PM +0200, Herve Codina kirjoitti:
> > Industrial I/O devices can be present in the audio path.
> > These devices needs to be used as audio components in order to be fully
> > integrated in the audio path.
> >
> > This support allows to consider these Industrial I/O devices as auxliary
> > audio devices and allows to control them using mixer controls.
>
> ...
>
> > +// audio-iio-aux.c -- ALSA SoC glue to use IIO devices as audio components
>
> Putting file name into file is not a good idea in case the file will be renamed
> in the future.
Indeed, the file name will be removed in the nest iteration.
>
> ...
>
> > +struct audio_iio_aux_chan {
> > + struct iio_channel *iio_chan;
> > + const char *name;
> > + bool is_invert_range;
>
> If you put bool after int:s it may save a few bytes in some cases.
I will mode is_invert_range after the int members.
>
> > + int max;
> > + int min;
>
> Wondering if there is already a data type for the ranges (like linear_range.h,
> but not sure it's applicable here).
Seems not applicable here.
- IIO does not use linear_range or something similar. It just uses simple int.
- ASoC does not use linear_range or something similar. It just uses simple long.
So, I keep the simple int min and max.
>
> > +};
>
> ...
>
> > + if (val < 0)
> > + return -EINVAL;
> > + if (val > max - min)
>
> Btw, who will validate that max > min?
By construction,
min = 0
max = iio_read_max_channel_raw() - iio_read_min_channel_raw()
and iio_read_max_channel_raw() returns a value greater or equal to
iio_read_min_channel_raw().
But to be sure, I will check the last asumption at probe() and swap
the minimum and maximum values if needed.
>
> > + return -EINVAL;
>
> ...
>
> > + return 1; /* The value changed */
>
> Perhaps this 1 needs a definition?
Yes but to be coherent, in ASoC code, many places need to be changed too
in order to use the newly defined value.
I don't think these modifications should be part of this series.
>
> ...
>
> > +static struct snd_soc_dapm_widget widgets[3] = {0};
> > +static struct snd_soc_dapm_route routes[2] = {0};
>
> 0:s are not needed. Moreover, the entire assingments are redundant
> as this is guaranteed by the C standard.
Indeed, the 0 assignment will be removed in the next iteration.
>
> ...
>
> > + char *input_name = NULL;
> > + char *output_name = NULL;
> > + char *pga_name = NULL;
>
> Redundant assignments if you properly label the freeing.
I will rework the error paths (gotos) to avoid these assignement.
>
> ...
>
> > + BUILD_BUG_ON(ARRAY_SIZE(widgets) < 3);
>
> Use static_assert() at the place where the array is defined.
Will be done in next iteration.
>
> ...
>
> > + BUILD_BUG_ON(ARRAY_SIZE(routes) < 2);
>
> Ditto.
Will be done in next iteration.
>
> ...
>
> > +end:
>
> out_free:
>
> > + /* Allocated names are no more needed (duplicated in ASoC internals) */
> > + kfree(pga_name);
> > + kfree(output_name);
> > + kfree(input_name);
> > +
> > + return ret;
>
> ...
>
> > + for (i = 0; i < iio_aux->num_chans; i++) {
> > + chan = iio_aux->chans + i;
> > +
> > + ret = iio_read_max_channel_raw(chan->iio_chan, &chan->max);
> > + if (ret) {
> > + dev_err(component->dev, "chan[%d] %s: Cannot get max raw value (%d)\n",
> > + i, chan->name, ret);
> > + return ret;
>
> It sounds like a part of ->probe() flow, correct?
> Can dev_err_probe() be used here?
Will be changed in the next iteration.
>
> > + }
> > +
> > + ret = iio_read_min_channel_raw(chan->iio_chan, &chan->min);
> > + if (ret) {
> > + dev_err(component->dev, "chan[%d] %s: Cannot get min raw value (%d)\n",
> > + i, chan->name, ret);
> > + return ret;
>
> Ditto.
Will be changed in the next iteration.
>
> > + }
> > +
> > + /* Set initial value */
> > + ret = iio_write_channel_raw(chan->iio_chan,
> > + chan->is_invert_range ? chan->max : chan->min);
> > + if (ret) {
> > + dev_err(component->dev, "chan[%d] %s: Cannot set initial value (%d)\n",
> > + i, chan->name, ret);
> > + return ret;
>
> Ditto.
Will be changed in the next iteration.
>
> > + }
>
> ...
>
> > + dev_dbg(component->dev, "chan[%d]: Added %s (min=%d, max=%d, invert=%s)\n",
> > + i, chan->name, chan->min, chan->max,
> > + chan->is_invert_range ? "on" : "off");
>
> str_on_off()
Indeed, I didn't know str_on_off().
Thanks for pointing.
Will be use in next iteration.
>
> > + }
>
> ...
>
> > + count = of_property_count_strings(np, "io-channel-names");
> > + if (count < 0) {
>
> > + dev_err(iio_aux->dev, "%pOF: failed to read io-channel-names\n", np);
> > + return count;
>
> return dev_err_probe();
Will be changed in next iteration.
>
> > + }
>
> ...
>
> > + for (i = 0; i < iio_aux->num_chans; i++) {
> > + iio_aux_chan = iio_aux->chans + i;
> > +
> > + ret = of_property_read_string_index(np, "io-channel-names", i,
> > + &iio_aux_chan->name);
> > + if (ret < 0) {
> > + dev_err(iio_aux->dev, "%pOF: failed to read io-channel-names[%d]\n", np, i);
> > + return ret;
>
> Ditto.
Will be changed in next iteration.
>
> > + }
>
> > + tmp = 0;
> > + of_property_read_u32_index(np, "snd-control-invert-range", i, &tmp);
>
> > + iio_aux_chan->is_invert_range = tmp;
>
> You can use this variable directly.
Not sure, is_invert_range is a bool and tmp is a u32.
In previous iteration, I wrote
iio_aux_chan->is_invert_range = !!tmp;
>
> > + }
>
> Btw, can you avoid using OF APIs? It's better to have device property/fwnode
> API to be used from day 1.
Hum, this comment was raised in the previous iteration
https://lore.kernel.org/linux-kernel/20230501162456.3448c494@jic23-huawei/
I didn't find any equivalent to of_property_read_u32_index() in the
device_property_read_*() function family.
I mean I did find anything available to get a value from an array using an index.
In the previous iteration it was concluded that keeping OF APIs in this series
seemed "reasonable".
>
> ...
>
> > + platform_set_drvdata(pdev, iio_aux);
>
> Which callback is using this driver data?
None -> I will remove platform_set_drvdata().
>
> ...
>
> > +static const struct of_device_id audio_iio_aux_ids[] = {
> > + { .compatible = "audio-iio-aux", },
>
> Inner comma is not needed.
Will be fixed.
>
> > + { }
> > +};
>
> ...
>
> > +static struct platform_driver audio_iio_aux_driver = {
> > + .driver = {
> > + .name = "audio-iio-aux",
> > + .of_match_table = audio_iio_aux_ids,
> > + },
> > + .probe = audio_iio_aux_probe,
> > +};
>
> > +
>
> Redundant blank line
Will be fixed.
>
> > +module_platform_driver(audio_iio_aux_driver);
>
--
Hervé Codina, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com
next prev parent reply other threads:[~2023-06-06 13:55 UTC|newest]
Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-05-23 15:12 [PATCH v2 0/9] Add support for IIO devices in ASoC Herve Codina
2023-05-23 15:12 ` [PATCH v2 1/9] ASoC: dt-bindings: Add audio-iio-aux Herve Codina
2023-05-23 15:12 ` [PATCH v2 2/9] ASoC: dt-bindings: simple-card: Add additional-devs subnode Herve Codina
2023-05-23 15:12 ` [PATCH v2 3/9] iio: inkern: Check error explicitly in iio_channel_read_max() Herve Codina
2023-05-28 17:32 ` Jonathan Cameron
2023-05-23 15:12 ` [PATCH v2 4/9] iio: consumer.h: Fix raw values documentation notes Herve Codina
2023-05-28 17:29 ` Jonathan Cameron
2023-05-23 15:12 ` [PATCH v2 5/9] iio: inkern: Add a helper to query an available minimum raw value Herve Codina
2023-05-28 17:33 ` Jonathan Cameron
2023-06-03 14:04 ` andy.shevchenko
2023-06-05 7:46 ` Herve Codina
2023-06-05 9:45 ` Andy Shevchenko
2023-06-05 14:11 ` Herve Codina
2023-06-05 17:05 ` Jonathan Cameron
2023-06-05 17:36 ` Herve Codina
2023-05-23 15:12 ` [PATCH v2 6/9] ASoC: soc-dapm.h: Add a helper to build a DAPM widget dynamically Herve Codina
2023-06-03 14:07 ` andy.shevchenko
2023-06-05 8:54 ` Herve Codina
2023-06-05 12:35 ` Herve Codina
2023-05-23 15:12 ` [PATCH v2 7/9] ASoC: codecs: Add support for the generic IIO auxiliary devices Herve Codina
2023-05-28 17:38 ` Jonathan Cameron
2023-06-05 17:22 ` Herve Codina
2023-06-03 18:26 ` andy.shevchenko
2023-06-06 13:54 ` Herve Codina [this message]
2023-06-06 14:34 ` Andy Shevchenko
2023-06-07 14:56 ` Herve Codina
2023-06-07 13:23 ` Herve Codina
2023-05-23 15:12 ` [PATCH v2 8/9] ASoC: simple-card: Add missing of_node_put() in case of error Herve Codina
2023-05-23 23:24 ` Kuninori Morimoto
2023-05-23 15:12 ` [PATCH v2 9/9] ASoC: simple-card: Handle additional devices Herve Codina
2023-05-24 0:08 ` Kuninori Morimoto
2023-05-24 0:36 ` Kuninori Morimoto
2023-05-24 12:14 ` Herve Codina
2023-05-25 0:01 ` Kuninori Morimoto
2023-05-26 13:07 ` Herve Codina
2023-05-29 0:18 ` Kuninori Morimoto
2023-06-03 18:27 ` andy.shevchenko
2023-05-26 16:31 ` (subset) [PATCH v2 0/9] Add support for IIO devices in ASoC Mark Brown
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230606155404.28ada064@bootlin.com \
--to=herve.codina@bootlin.com \
--cc=alsa-devel@alsa-project.org \
--cc=andy.shevchenko@gmail.com \
--cc=broonie@kernel.org \
--cc=christophe.leroy@csgroup.eu \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=jic23@kernel.org \
--cc=krzysztof.kozlowski+dt@linaro.org \
--cc=kuninori.morimoto.gx@renesas.com \
--cc=lars@metafoo.de \
--cc=lgirdwood@gmail.com \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=perex@perex.cz \
--cc=robh+dt@kernel.org \
--cc=thomas.petazzoni@bootlin.com \
--cc=tiwai@suse.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.