From: Crestez Dan Leonard <leonard.crestez@intel.com>
To: Lars-Peter Clausen <lars@metafoo.de>,
Gregor Boirie <gregor.boirie@parrot.com>,
"linux-iio@vger.kernel.org" <linux-iio@vger.kernel.org>
Subject: Re: generic_buffer and 24 bits samples
Date: Fri, 15 Apr 2016 16:06:14 +0300 [thread overview]
Message-ID: <5710E746.1080102@intel.com> (raw)
In-Reply-To: <5710C2E6.2080303@metafoo.de>
On 04/15/2016 01:31 PM, Lars-Peter Clausen wrote:
> On 04/15/2016 11:56 AM, Crestez Dan Leonard wrote:
>> On 04/14/2016 07:00 PM, Lars-Peter Clausen wrote:
>>> On 04/14/2016 05:28 PM, Gregor Boirie wrote:
>>>> Greetings,
>>>>
>>>> I'm trying to use an st_pressure based sensor to sample pressure
>>>> data using generic_buffer tool. However it seems that it does not
>>>> support data packed onto 24 bits samples.
>>>> st_pressure driver defines scan_type for my device as:
>>>> <code>
>>>> /* ... */
>>>> .scan_type = {
>>>> .sign = 'u',
>>>> .realbits = 24,
>>>> .storagebits = 24,
>>>> .endianness = IIO_LE,
>>>> },
>>>> </code>
>>>>
>>>> What is the proper way to make this work ? Using 32 bits storagebits
>>>> field ? Enhance generic_buffer to support 24 bits samples ? Anything
>>>> else ??
>>>>
>>>> It seems iio_compute_scan_bytes consider sample data as a simple byte
>>>> stream. So I'm wondering what are the alignment constraints for sample
>>>> start address ? Should they be aligned onto their natural "word"
>>>> boundaries, i.e. 16 bits for u16, 32 bits for u32, etc... ? And for
>>>> 24 bits samples ?
>>>
>>> IIO really only supports powers of two >= 8 for the storagebits size.
>>> Everything else is undefined.
>>>
>>> Samples are aligned to their storage size.
>>
>> How does 24-bit alignment work?
>
> It does not work ;)
>
>>
>> Maybe the IIO core should check that storagebits is one of 8/16/32/64 and
>> otherwise fail at register time? A quick grep finds only 2 drivers using
>> storagebits = 24 and they could easily be modified to 32.
>
> Yes, sounds reasonable. Do you want to send a patch?
Not really, I don't want to break stuff.
The only drivers that seem to use an unusual storagebits value are
st_pressure (the one that this thread is about) and AD5791 which doesn't
seem to actually expose buffer support.
There is also the curious case of AD7303 which specifies realbits and
storage bits as the char value '8', again without exposing buffer support.
Perhaps storagebits=24 in st_pressure should be considered a bug. Maybe
try to modify this to 32 and check the readings?
I don't have any of these devices.
Regards,
Leonard
next prev parent reply other threads:[~2016-04-15 13:06 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-04-14 15:28 generic_buffer and 24 bits samples Gregor Boirie
2016-04-14 16:00 ` Lars-Peter Clausen
2016-04-15 9:56 ` Crestez Dan Leonard
2016-04-15 10:31 ` Lars-Peter Clausen
2016-04-15 13:06 ` Crestez Dan Leonard [this message]
2016-04-15 14:35 ` Gregor Boirie
2016-04-15 14:44 ` Lars-Peter Clausen
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=5710E746.1080102@intel.com \
--to=leonard.crestez@intel.com \
--cc=gregor.boirie@parrot.com \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
/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;
as well as URLs for NNTP newsgroup(s).