3 Jun
2023
3 Jun
'23
4:04 p.m.
Tue, May 23, 2023 at 05:12:19PM +0200, Herve Codina kirjoitti:
A helper, iio_read_max_channel_raw() exists to read the available maximum raw value of a channel but nothing similar exists to read the available minimum raw value.
This new helper, iio_read_min_channel_raw(), fills the hole and can be used for reading the available minimum raw value of a channel. It is fully based on the existing iio_read_max_channel_raw().
...
+static int iio_channel_read_min(struct iio_channel *chan,
int *val, int *val2, int *type,enum iio_chan_info_enum info)+{
- int unused;
- const int *vals;
- int length;
- int ret;
- if (!val2)
val2 = &unused;
It's a single place, where this is used, can you move it there?
- ret = iio_channel_read_avail(chan, &vals, type, &length, info);
- if (ret < 0)
return ret;- switch (ret) {
- case IIO_AVAIL_RANGE:
switch (*type) {case IIO_VAL_INT:*val = vals[0];break;default:*val = vals[0];*val2 = vals[1];}return 0;- case IIO_AVAIL_LIST:
if (length <= 0)return -EINVAL;switch (*type) {case IIO_VAL_INT:*val = vals[--length];
while (length) {
while (length--) {
will do the job and at the same time...
if (vals[--length] < *val)*val = vals[length];
...this construction becomes less confusing (easier to parse).
}break;default:/* FIXME: learn about min for other iio values */
I believe in a final version this comment won't be here.
return -EINVAL;}return 0;- default:
return -EINVAL;- }
+}
--
With Best Regards,
Andy Shevchenko