|
Zephyr Project API 4.0.0
A Scalable Open Source RTOS
|
Decodes a single raw data buffer. More...
#include <sensor.h>
Data Fields | |
| int(* | get_frame_count )(const uint8_t *buffer, struct sensor_chan_spec channel, uint16_t *frame_count) |
| Get the number of frames in the current buffer. | |
| int(* | get_size_info )(struct sensor_chan_spec channel, size_t *base_size, size_t *frame_size) |
| Get the size required to decode a given channel. | |
| int(* | decode )(const uint8_t *buffer, struct sensor_chan_spec channel, uint32_t *fit, uint16_t max_count, void *data_out) |
Decode up to max_count samples from the buffer. | |
| bool(* | has_trigger )(const uint8_t *buffer, enum sensor_trigger_type trigger) |
| Check if the given trigger type is present. | |
Decodes a single raw data buffer.
Data buffers are provided on the RTIO context that's supplied to sensor_read.
| int(* sensor_decoder_api::decode) (const uint8_t *buffer, struct sensor_chan_spec channel, uint32_t *fit, uint16_t max_count, void *data_out) |
Decode up to max_count samples from the buffer.
Decode samples of channel sensor_channel across multiple frames. If there exist multiple instances of the same channel, channel_index is used to differentiate them. As an example, assume a sensor provides 2 distance measurements:
| [in] | buffer | The buffer provided on the RTIO context |
| [in] | channel | The channel to decode |
| [in,out] | fit | The current frame iterator |
| [in] | max_count | The maximum number of channels to decode. |
| [out] | data_out | The decoded data |
| int(* sensor_decoder_api::get_frame_count) (const uint8_t *buffer, struct sensor_chan_spec channel, uint16_t *frame_count) |
Get the number of frames in the current buffer.
| [in] | buffer | The buffer provided on the RTIO context. |
| [in] | channel | The channel to get the count for |
| [out] | frame_count | The number of frames on the buffer (at least 1) |
| int(* sensor_decoder_api::get_size_info) (struct sensor_chan_spec channel, size_t *base_size, size_t *frame_size) |
Get the size required to decode a given channel.
When decoding a single frame, use base_size. For every additional frame, add another frame_size. As an example, to decode 3 frames use: 'base_size + 2 * frame_size'.
| [in] | channel | The channel to query |
| [out] | base_size | The size of decoding the first frame |
| [out] | frame_size | The additional size of every additional frame |
| bool(* sensor_decoder_api::has_trigger) (const uint8_t *buffer, enum sensor_trigger_type trigger) |
Check if the given trigger type is present.
| [in] | buffer | The buffer provided on the RTIO context |
| [in] | trigger | The trigger type in question |