From: Jonathan Cameron <jic23@kernel.org>
To: "Nuno Sá" <noname.nuno@gmail.com>
Cc: Ramona Gradinariu <ramona.gradinariu@analog.com>,
nuno.sa@analog.com, linux-iio@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 1/1] drivers: imu: adis16475.c: Remove scan index from delta channels
Date: Sat, 14 Oct 2023 17:04:21 +0100 [thread overview]
Message-ID: <20231014170421.77eb0bbe@jic23-huawei> (raw)
In-Reply-To: <1bbca62efe038e37a6a87f873d71d131d5ebdd2f.camel@gmail.com>
On Thu, 12 Oct 2023 17:35:02 +0200
Nuno Sá <noname.nuno@gmail.com> wrote:
> On Thu, 2023-10-12 at 17:09 +0200, Nuno Sá wrote:
> > Hi Ramona,
> >
> > There are some odd stuff...
> >
> > On Thu, 2023-10-12 at 15:24 +0300, Ramona Gradinariu wrote:
> > > Some devices do not support delta angle and delta velocity
> > > burst readings, which means there should be no buffer support
> > > for these types of channels.
> > > A new list of channels is created which contains the delta
> > > channels structures with the scan index equal to -1 to allow
> > > for raw register readings, without buffer support.
> > > This list of channels is assigned to the devices which
> > > do not support delta angle and delta velocity burst
> > > readings.
> > >
> > > Fixes: 8f6bc87d67c0 ("iio: imu: adis16475.c: Add delta angle and delta velocity
> > > channels")
> > > Signed-off-by: Ramona Gradinariu <ramona.gradinariu@analog.com>
> > > ---
> > > drivers/iio/imu/adis16475.c | 67 +++++++++++++++++++++++++------------
> > > 1 file changed, 46 insertions(+), 21 deletions(-)
> > >
> > > diff --git a/drivers/iio/imu/adis16475.c b/drivers/iio/imu/adis16475.c
> > > index 9af07fec0d89..b7cbe1565aee 100644
> > > --- a/drivers/iio/imu/adis16475.c
> > > +++ b/drivers/iio/imu/adis16475.c
> > > @@ -604,7 +604,15 @@ static int adis16475_write_raw(struct iio_dev *indio_dev,
> > > ADIS16475_MOD_CHAN_DELTA(IIO_DELTA_VELOCITY, IIO_MOD_ ## _mod, \
> > > ADIS16475_REG_ ## _mod ## _DELTVEL_L,
> > > ADIS16475_SCAN_DELTVEL_ ## _mod, 32, 32)
> > >
> > > -static const struct iio_chan_spec adis16475_channels[] = {
> > > +#define ADIS16475_DELTANG_CHAN_NO_SCAN(_mod) \
> > > + ADIS16475_MOD_CHAN_DELTA(IIO_DELTA_ANGL, IIO_MOD_ ## _mod, \
> > > + ADIS16475_REG_ ## _mod ## _DELTANG_L, -1, 32, 32)
> > > +
> > > +#define ADIS16475_DELTVEL_CHAN_NO_SCAN(_mod) \
> > > + ADIS16475_MOD_CHAN_DELTA(IIO_DELTA_VELOCITY, IIO_MOD_ ## _mod, \
> > > + ADIS16475_REG_ ## _mod ## _DELTVEL_L, -1, 32, 32)
> > > +
> > > +static const struct iio_chan_spec adis16477_channels[] = {
> > > ADIS16475_GYRO_CHANNEL(X),
> > > ADIS16475_GYRO_CHANNEL(Y),
> > > ADIS16475_GYRO_CHANNEL(Z),
> > > @@ -621,6 +629,23 @@ static const struct iio_chan_spec adis16475_channels[] = {
> > > IIO_CHAN_SOFT_TIMESTAMP(13)
> > > };
> > >
> > > +static const struct iio_chan_spec adis16475_channels[] = {
> >
> > I guess you mean adis16477_channels?
> >
> > > + ADIS16475_GYRO_CHANNEL(X),
> > > + ADIS16475_GYRO_CHANNEL(Y),
> > > + ADIS16475_GYRO_CHANNEL(Z),
> > > + ADIS16475_ACCEL_CHANNEL(X),
> > > + ADIS16475_ACCEL_CHANNEL(Y),
> > > + ADIS16475_ACCEL_CHANNEL(Z),
> > > + ADIS16475_TEMP_CHANNEL(),
> > > + ADIS16475_DELTANG_CHAN_NO_SCAN(X),
> > > + ADIS16475_DELTANG_CHAN_NO_SCAN(Y),
> > > + ADIS16475_DELTANG_CHAN_NO_SCAN(Z),
> > > + ADIS16475_DELTVEL_CHAN_NO_SCAN(X),
> > > + ADIS16475_DELTVEL_CHAN_NO_SCAN(Y),
> > > + ADIS16475_DELTVEL_CHAN_NO_SCAN(Z),
> > > + IIO_CHAN_SOFT_TIMESTAMP(7)
> > > +};
> > > +
> > > enum adis16475_variant {
> > > ADIS16470,
> > > ADIS16475_1,
> > > @@ -782,8 +807,8 @@ static const struct adis16475_chip_info adis16475_chip_info[]
> > > =
> > > {
> > > },
> > > [ADIS16477_1] = {
> > > .name = "adis16477-1",
> > > - .num_channels = ARRAY_SIZE(adis16475_channels),
> > > - .channels = adis16475_channels,
> > > + .num_channels = ARRAY_SIZE(adis16477_channels),
> > > + .channels = adis16477_channels,
> > > .gyro_max_val = 1,
> > > .gyro_max_scale = IIO_RAD_TO_DEGREE(160 << 16),
> > > .accel_max_val = 1,
> > > @@ -800,8 +825,8 @@ static const struct adis16475_chip_info adis16475_chip_info[]
> > > =
> > > {
> > > },
> > > [ADIS16477_2] = {
> > > .name = "adis16477-2",
> > > - .num_channels = ARRAY_SIZE(adis16475_channels),
> > > - .channels = adis16475_channels,
> > > + .num_channels = ARRAY_SIZE(adis16477_channels),
> > > + .channels = adis16477_channels,
> > > .gyro_max_val = 1,
> > > .gyro_max_scale = IIO_RAD_TO_DEGREE(40 << 16),
> > > .accel_max_val = 1,
> > > @@ -818,8 +843,8 @@ static const struct adis16475_chip_info adis16475_chip_info[]
> > > =
> > > {
> > > },
> > > [ADIS16477_3] = {
> > > .name = "adis16477-3",
> > > - .num_channels = ARRAY_SIZE(adis16475_channels),
> > > - .channels = adis16475_channels,
> > > + .num_channels = ARRAY_SIZE(adis16477_channels),
> > > + .channels = adis16477_channels,
> > > .gyro_max_val = 1,
> > > .gyro_max_scale = IIO_RAD_TO_DEGREE(10 << 16),
> > > .accel_max_val = 1,
> > > @@ -938,8 +963,8 @@ static const struct adis16475_chip_info adis16475_chip_info[]
> > > =
> > > {
> > > },
> > > [ADIS16500] = {
> > > .name = "adis16500",
> > > - .num_channels = ARRAY_SIZE(adis16475_channels),
> > > - .channels = adis16475_channels,
> > > + .num_channels = ARRAY_SIZE(adis16477_channels),
> > > + .channels = adis16477_channels,
> > > .gyro_max_val = 1,
> > > .gyro_max_scale = IIO_RAD_TO_DEGREE(10 << 16),
> > > .accel_max_val = 392,
> > > @@ -957,8 +982,8 @@ static const struct adis16475_chip_info adis16475_chip_info[]
> > > =
> > > {
> > > },
> > > [ADIS16505_1] = {
> > > .name = "adis16505-1",
> > > - .num_channels = ARRAY_SIZE(adis16475_channels),
> > > - .channels = adis16475_channels,
> > > + .num_channels = ARRAY_SIZE(adis16477_channels),
> > > + .channels = adis16477_channels,
> >
> > AFAICS, this supports delta channels in burst mode... right? Please make sure to go
> > again through the datasheets so we make this right...
> >
>
> Alright, I just saw I missed the diff renaming adis16475_channels >
> adis16477_channels. MAybe you could state why you did it in the commit message.
> Anyhow:
>
> Reviewed-by: Nuno Sa <nuno.sa@analog.com>
>
Applied.
prev parent reply other threads:[~2023-10-14 16:04 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-10-12 12:24 [PATCH 0/1] adis16475.c: Remove scan index from delta channels Ramona Gradinariu
2023-10-12 12:24 ` [PATCH 1/1] drivers: imu: " Ramona Gradinariu
2023-10-12 15:09 ` Nuno Sá
2023-10-12 15:35 ` Nuno Sá
2023-10-14 16:04 ` Jonathan Cameron [this message]
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=20231014170421.77eb0bbe@jic23-huawei \
--to=jic23@kernel.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=noname.nuno@gmail.com \
--cc=nuno.sa@analog.com \
--cc=ramona.gradinariu@analog.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox