Infuse-IoT SDK API 0.0.1
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
imu.h
Go to the documentation of this file.
1
12
13#ifndef INFUSE_SDK_INCLUDE_INFUSE_DRIVERS_IMU_H_
14#define INFUSE_SDK_INCLUDE_INFUSE_DRIVERS_IMU_H_
15
16#include <zephyr/kernel.h>
17#include <zephyr/device.h>
18
20
21#ifdef __cplusplus
22extern "C" {
23#endif
24
30
32struct imu_config {
33 struct {
41 struct {
43 uint16_t sample_rate_hz;
47 bool low_power;
49 struct {
50 uint16_t sample_rate_hz;
54};
55
67
69 int (*configure)(const struct device *dev, const struct imu_config *config,
70 struct imu_config_output *output);
71 int (*data_wait)(const struct device *dev, k_timeout_t timeout);
72 int (*data_read)(const struct device *dev, struct imu_sample_array *samples,
73 uint16_t max_samples);
74#if defined(CONFIG_INFUSE_IMU_SELF_TEST) || defined(__DOXYGEN__)
75 int (*self_test)(const struct device *dev);
76#endif /* defined(CONFIG_INFUSE_IMU_SELF_TEST) || defined(__DOXYGEN__) */
77};
78
90static inline int imu_configure(const struct device *dev, const struct imu_config *config,
91 struct imu_config_output *output)
92{
93 const struct infuse_imu_api *api = dev->api;
94
95 return api->configure(dev, config, output);
96}
97
107static inline int imu_data_wait(const struct device *dev, k_timeout_t timeout)
108{
109 const struct infuse_imu_api *api = dev->api;
110
111 return api->data_wait(dev, timeout);
112}
113
126static inline int imu_data_read(const struct device *dev, struct imu_sample_array *samples,
127 uint16_t max_samples)
128{
129 const struct infuse_imu_api *api = dev->api;
130
131 return api->data_read(dev, samples, max_samples);
132}
133
134#if defined(CONFIG_INFUSE_IMU_SELF_TEST) || defined(__DOXYGEN__)
143static inline int imu_self_test(const struct device *dev)
144{
145 const struct infuse_imu_api *api = dev->api;
146
147 if (api->self_test == NULL) {
148 return -ENOTSUP;
149 }
150 return api->self_test(dev);
151}
152#endif /* defined(CONFIG_INFUSE_IMU_SELF_TEST) || defined(__DOXYGEN__) */
153
161static inline int16_t imu_accelerometer_1g(uint8_t full_scale)
162{
163 switch (full_scale) {
164 case 2:
165 return 16384;
166 case 4:
167 return 8192;
168 case 8:
169 return 4096;
170 case 16:
171 return 2048;
172 default:
173 return -1;
174 }
175}
176
184static inline uint32_t imu_sample_period(const struct imu_sensor_meta *meta)
185{
186 if (meta->num < 2) {
187 return 0;
188 }
189 return meta->buffer_period_ticks / (meta->num - 1);
190}
191
199static inline uint16_t imu_sample_rate(const struct imu_sensor_meta *meta)
200{
201 uint32_t period_us = k_ticks_to_us_near32(imu_sample_period(meta));
202
203 if (period_us == 0) {
204 return 0;
205 }
206 return 1000000 / period_us;
207}
208
217static inline k_ticks_t imu_sample_timestamp(const struct imu_sensor_meta *meta, uint8_t sample)
218{
219 if (meta->num < 2) {
220 return meta->timestamp_ticks;
221 }
222 return meta->timestamp_ticks + (sample * meta->buffer_period_ticks / (meta->num - 1));
223}
224
248
265 const struct imu_sample *input, uint16_t num_input);
266
270
271#ifdef __cplusplus
272}
273#endif
274
275#endif /* INFUSE_SDK_INCLUDE_INFUSE_DRIVERS_IMU_H_ */
IMU Output data types.
int imu_linear_downsample_scaled(struct imu_linear_downsample_scaled_state *state, const struct imu_sample *input, uint16_t num_input)
Downsample IMU samples to a new frequency using linear interpolation.
static uint16_t imu_sample_rate(const struct imu_sensor_meta *meta)
Get the approximate sample rate of a buffer.
Definition imu.h:199
static int imu_self_test(const struct device *dev)
Run self-test functionality on the IMU.
Definition imu.h:143
static k_ticks_t imu_sample_timestamp(const struct imu_sensor_meta *meta, uint8_t sample)
Get the local tick counter of a given sample in a buffer.
Definition imu.h:217
static int16_t imu_accelerometer_1g(uint8_t full_scale)
Convert a full scale range to an expected value for 1G.
Definition imu.h:161
static uint32_t imu_sample_period(const struct imu_sensor_meta *meta)
Get the local ticks between samples in a buffer.
Definition imu.h:184
static int imu_configure(const struct device *dev, const struct imu_config *config, struct imu_config_output *output)
Configure IMU for operation.
Definition imu.h:90
static int imu_data_wait(const struct device *dev, k_timeout_t timeout)
Wait for FIFO interrupt from IMU.
Definition imu.h:107
static int imu_data_read(const struct device *dev, struct imu_sample_array *samples, uint16_t max_samples)
Read samples from IMU.
Definition imu.h:126
Configured IMU value.
Definition imu.h:57
uint32_t accelerometer_period_us
Expected period between accelerometer samples.
Definition imu.h:59
uint32_t gyroscope_period_us
Expected period between gyroscope samples.
Definition imu.h:61
uint32_t expected_interrupt_period_us
Expected period FIFO interrupts.
Definition imu.h:65
uint32_t magnetometer_period_us
Expected period between magnetometer samples.
Definition imu.h:63
IMU configuration struct.
Definition imu.h:32
struct imu_config::@002066230011174142061264175250353301144202043330 accelerometer
uint16_t sample_rate_hz
Sample rate in Hertz.
Definition imu.h:35
struct imu_config::@012327065131013340056006222315027114333325114165 magnetometer
uint8_t full_scale_range
Full scale range in G.
Definition imu.h:37
uint16_t fifo_sample_buffer
Requested number of samples to buffer in FIFO before raising interrupt.
Definition imu.h:53
struct imu_config::@337212207024143026276102347134057053356067255150 gyroscope
bool low_power
True for low power mode, false for performance.
Definition imu.h:39
State for imu_linear_downsample_scaled.
Definition imu.h:226
uint8_t freq_mult
Multiplier applied to input frequency.
Definition imu.h:242
int16_t scale
Output is scaled as (integer_val/scale)
Definition imu.h:240
uint8_t freq_div
Divider applied to (input_frequency * freq_mult)
Definition imu.h:244
uint16_t output_offset
Current number of samples written to output.
Definition imu.h:238
uint16_t output_size
Size of the axis output arrays.
Definition imu.h:236
uint8_t subsample_idx
Private.
Definition imu.h:246
float * output_z
Buffer storage for Z axis output.
Definition imu.h:234
struct imu_sample last_sample
Private.
Definition imu.h:228
float * output_x
Buffer storage for X axis output.
Definition imu.h:230
float * output_y
Buffer storage for Y axis output.
Definition imu.h:232
FIFO read structure.
Definition data_types.h:52
IMU sample struct.
Definition data_types.h:28
Metadata for each sub-sensor in a FIFO buffer.
Definition data_types.h:38
uint32_t buffer_period_ticks
Real period between first and last samples in buffer.
Definition data_types.h:42
uint16_t num
Number of readings for this sensor.
Definition data_types.h:48
int64_t timestamp_ticks
Local tick counter of first sample.
Definition data_types.h:40
Definition imu.h:68
int(* self_test)(const struct device *dev)
Definition imu.h:75
int(* data_read)(const struct device *dev, struct imu_sample_array *samples, uint16_t max_samples)
Definition imu.h:72
int(* configure)(const struct device *dev, const struct imu_config *config, struct imu_config_output *output)
Definition imu.h:69
int(* data_wait)(const struct device *dev, k_timeout_t timeout)
Definition imu.h:71