1 /*
2 * Copyright (c) 2021 Bosch Sensortec GmbH
3 * Copyright (c) 2022 Nordic Semiconductor ASA
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8 #define DT_DRV_COMPAT bosch_bmi270
9
10 #include <zephyr/drivers/sensor.h>
11 #include <zephyr/init.h>
12 #include <zephyr/kernel.h>
13 #include <zephyr/sys/__assert.h>
14 #include <zephyr/sys/byteorder.h>
15 #include <zephyr/logging/log.h>
16
17 #include "bmi270.h"
18 #include "bmi270_config_file.h"
19
20 LOG_MODULE_REGISTER(bmi270, CONFIG_SENSOR_LOG_LEVEL);
21
22 #define BMI270_WR_LEN 256
23 #define BMI270_CONFIG_FILE_RETRIES 15
24 #define BMI270_CONFIG_FILE_POLL_PERIOD_US 10000
25 #define BMI270_INTER_WRITE_DELAY_US 1000
26
bmi270_bus_check(const struct device * dev)27 static inline int bmi270_bus_check(const struct device *dev)
28 {
29 const struct bmi270_config *cfg = dev->config;
30
31 return cfg->bus_io->check(&cfg->bus);
32 }
33
bmi270_bus_init(const struct device * dev)34 static inline int bmi270_bus_init(const struct device *dev)
35 {
36 const struct bmi270_config *cfg = dev->config;
37
38 return cfg->bus_io->init(&cfg->bus);
39 }
40
bmi270_reg_read(const struct device * dev,uint8_t reg,uint8_t * data,uint16_t length)41 int bmi270_reg_read(const struct device *dev, uint8_t reg, uint8_t *data, uint16_t length)
42 {
43 const struct bmi270_config *cfg = dev->config;
44
45 return cfg->bus_io->read(&cfg->bus, reg, data, length);
46 }
47
bmi270_reg_write(const struct device * dev,uint8_t reg,const uint8_t * data,uint16_t length)48 int bmi270_reg_write(const struct device *dev, uint8_t reg,
49 const uint8_t *data, uint16_t length)
50 {
51 const struct bmi270_config *cfg = dev->config;
52
53 return cfg->bus_io->write(&cfg->bus, reg, data, length);
54 }
55
bmi270_reg_write_with_delay(const struct device * dev,uint8_t reg,const uint8_t * data,uint16_t length,uint32_t delay_us)56 int bmi270_reg_write_with_delay(const struct device *dev,
57 uint8_t reg,
58 const uint8_t *data,
59 uint16_t length,
60 uint32_t delay_us)
61 {
62 int ret = 0;
63
64 ret = bmi270_reg_write(dev, reg, data, length);
65 if (ret == 0) {
66 k_usleep(delay_us);
67 }
68 return ret;
69 }
70
channel_accel_convert(struct sensor_value * val,int64_t raw_val,uint8_t range)71 static void channel_accel_convert(struct sensor_value *val, int64_t raw_val,
72 uint8_t range)
73 {
74 /* 16 bit accelerometer. 2^15 bits represent the range in G */
75 /* Converting from G to m/s^2 */
76 raw_val = (raw_val * SENSOR_G * (int64_t) range) / INT16_MAX;
77
78 val->val1 = raw_val / 1000000LL;
79 val->val2 = raw_val % 1000000LL;
80 }
81
channel_gyro_convert(struct sensor_value * val,int64_t raw_val,uint16_t range)82 static void channel_gyro_convert(struct sensor_value *val, int64_t raw_val,
83 uint16_t range)
84 {
85 /* 16 bit gyroscope. 2^15 bits represent the range in degrees/s */
86 /* Converting from degrees/s to radians/s */
87
88 val->val1 = ((raw_val * (int64_t) range * SENSOR_PI)
89 / (180LL * INT16_MAX)) / 1000000LL;
90 val->val2 = ((raw_val * (int64_t) range * SENSOR_PI)
91 / (180LL * INT16_MAX)) % 1000000LL;
92 }
93
acc_odr_to_reg(const struct sensor_value * val)94 static uint8_t acc_odr_to_reg(const struct sensor_value *val)
95 {
96 double odr = sensor_value_to_double((struct sensor_value *) val);
97 uint8_t reg = 0;
98
99 if ((odr >= 0.78125) && (odr < 1.5625)) {
100 reg = BMI270_ACC_ODR_25D32_HZ;
101 } else if ((odr >= 1.5625) && (odr < 3.125)) {
102 reg = BMI270_ACC_ODR_25D16_HZ;
103 } else if ((odr >= 3.125) && (odr < 6.25)) {
104 reg = BMI270_ACC_ODR_25D8_HZ;
105 } else if ((odr >= 6.25) && (odr < 12.5)) {
106 reg = BMI270_ACC_ODR_25D4_HZ;
107 } else if ((odr >= 12.5) && (odr < 25.0)) {
108 reg = BMI270_ACC_ODR_25D2_HZ;
109 } else if ((odr >= 25.0) && (odr < 50.0)) {
110 reg = BMI270_ACC_ODR_25_HZ;
111 } else if ((odr >= 50.0) && (odr < 100.0)) {
112 reg = BMI270_ACC_ODR_50_HZ;
113 } else if ((odr >= 100.0) && (odr < 200.0)) {
114 reg = BMI270_ACC_ODR_100_HZ;
115 } else if ((odr >= 200.0) && (odr < 400.0)) {
116 reg = BMI270_ACC_ODR_200_HZ;
117 } else if ((odr >= 400.0) && (odr < 800.0)) {
118 reg = BMI270_ACC_ODR_400_HZ;
119 } else if ((odr >= 800.0) && (odr < 1600.0)) {
120 reg = BMI270_ACC_ODR_800_HZ;
121 } else if (odr >= 1600.0) {
122 reg = BMI270_ACC_ODR_1600_HZ;
123 }
124 return reg;
125 }
126
set_accel_odr_osr(const struct device * dev,const struct sensor_value * odr,const struct sensor_value * osr)127 static int set_accel_odr_osr(const struct device *dev, const struct sensor_value *odr,
128 const struct sensor_value *osr)
129 {
130 struct bmi270_data *data = dev->data;
131 uint8_t acc_conf, odr_bits, pwr_ctrl, osr_bits;
132 int ret = 0;
133
134 if (odr || osr) {
135 ret = bmi270_reg_read(dev, BMI270_REG_ACC_CONF, &acc_conf, 1);
136 if (ret != 0) {
137 return ret;
138 }
139
140 ret = bmi270_reg_read(dev, BMI270_REG_PWR_CTRL, &pwr_ctrl, 1);
141 if (ret != 0) {
142 return ret;
143 }
144 }
145
146 if (odr) {
147 odr_bits = acc_odr_to_reg(odr);
148 acc_conf = BMI270_SET_BITS_POS_0(acc_conf, BMI270_ACC_ODR,
149 odr_bits);
150
151 /* If odr_bits is 0, implies that the sampling frequency is 0Hz
152 * or invalid too.
153 */
154 if (odr_bits) {
155 pwr_ctrl |= BMI270_PWR_CTRL_ACC_EN;
156 } else {
157 pwr_ctrl &= ~BMI270_PWR_CTRL_ACC_EN;
158 }
159
160 /* If the Sampling frequency (odr) >= 100Hz, enter performance
161 * mode else, power optimized. This also has a consequence
162 * for the OSR
163 */
164 if (odr_bits >= BMI270_ACC_ODR_100_HZ) {
165 acc_conf = BMI270_SET_BITS(acc_conf, BMI270_ACC_FILT,
166 BMI270_ACC_FILT_PERF_OPT);
167 } else {
168 acc_conf = BMI270_SET_BITS(acc_conf, BMI270_ACC_FILT,
169 BMI270_ACC_FILT_PWR_OPT);
170 }
171
172 data->acc_odr = odr_bits;
173 }
174
175 if (osr) {
176 if (data->acc_odr >= BMI270_ACC_ODR_100_HZ) {
177 /* Performance mode */
178 /* osr->val2 should be unused */
179 switch (osr->val1) {
180 case 4:
181 osr_bits = BMI270_ACC_BWP_OSR4_AVG1;
182 break;
183 case 2:
184 osr_bits = BMI270_ACC_BWP_OSR2_AVG2;
185 break;
186 case 1:
187 osr_bits = BMI270_ACC_BWP_NORM_AVG4;
188 break;
189 default:
190 osr_bits = BMI270_ACC_BWP_CIC_AVG8;
191 break;
192 }
193 } else {
194 /* Power optimized mode */
195 /* osr->val2 should be unused */
196 switch (osr->val1) {
197 case 1:
198 osr_bits = BMI270_ACC_BWP_OSR4_AVG1;
199 break;
200 case 2:
201 osr_bits = BMI270_ACC_BWP_OSR2_AVG2;
202 break;
203 case 4:
204 osr_bits = BMI270_ACC_BWP_NORM_AVG4;
205 break;
206 case 8:
207 osr_bits = BMI270_ACC_BWP_CIC_AVG8;
208 break;
209 case 16:
210 osr_bits = BMI270_ACC_BWP_RES_AVG16;
211 break;
212 case 32:
213 osr_bits = BMI270_ACC_BWP_RES_AVG32;
214 break;
215 case 64:
216 osr_bits = BMI270_ACC_BWP_RES_AVG64;
217 break;
218 case 128:
219 osr_bits = BMI270_ACC_BWP_RES_AVG128;
220 break;
221 default:
222 return -ENOTSUP;
223 }
224 }
225
226 acc_conf = BMI270_SET_BITS(acc_conf, BMI270_ACC_BWP,
227 osr_bits);
228 }
229
230 if (odr || osr) {
231 ret = bmi270_reg_write(dev, BMI270_REG_ACC_CONF, &acc_conf, 1);
232 if (ret != 0) {
233 return ret;
234 }
235
236 /* Assuming we have advance power save enabled */
237 k_usleep(BMI270_TRANSC_DELAY_SUSPEND);
238
239 pwr_ctrl &= BMI270_PWR_CTRL_MSK;
240 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_PWR_CTRL,
241 &pwr_ctrl, 1,
242 BMI270_INTER_WRITE_DELAY_US);
243 }
244
245 return ret;
246 }
247
set_accel_range(const struct device * dev,const struct sensor_value * range)248 static int set_accel_range(const struct device *dev, const struct sensor_value *range)
249 {
250 struct bmi270_data *data = dev->data;
251 int ret = 0;
252 uint8_t acc_range, reg;
253
254 ret = bmi270_reg_read(dev, BMI270_REG_ACC_RANGE, &acc_range, 1);
255 if (ret != 0) {
256 return ret;
257 }
258
259 /* range->val2 is unused */
260 switch (range->val1) {
261 case 2:
262 reg = BMI270_ACC_RANGE_2G;
263 data->acc_range = 2;
264 break;
265 case 4:
266 reg = BMI270_ACC_RANGE_4G;
267 data->acc_range = 4;
268 break;
269 case 8:
270 reg = BMI270_ACC_RANGE_8G;
271 data->acc_range = 8;
272 break;
273 case 16:
274 reg = BMI270_ACC_RANGE_16G;
275 data->acc_range = 16;
276 break;
277 default:
278 return -ENOTSUP;
279 }
280
281 acc_range = BMI270_SET_BITS_POS_0(acc_range, BMI270_ACC_RANGE,
282 reg);
283 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_ACC_RANGE, &acc_range,
284 1, BMI270_INTER_WRITE_DELAY_US);
285
286 return ret;
287 }
288
gyr_odr_to_reg(const struct sensor_value * val)289 static uint8_t gyr_odr_to_reg(const struct sensor_value *val)
290 {
291 double odr = sensor_value_to_double((struct sensor_value *) val);
292 uint8_t reg = 0;
293
294 if ((odr >= 25.0) && (odr < 50.0)) {
295 reg = BMI270_GYR_ODR_25_HZ;
296 } else if ((odr >= 50.0) && (odr < 100.0)) {
297 reg = BMI270_GYR_ODR_50_HZ;
298 } else if ((odr >= 100.0) && (odr < 200.0)) {
299 reg = BMI270_GYR_ODR_100_HZ;
300 } else if ((odr >= 200.0) && (odr < 400.0)) {
301 reg = BMI270_GYR_ODR_200_HZ;
302 } else if ((odr >= 400.0) && (odr < 800.0)) {
303 reg = BMI270_GYR_ODR_400_HZ;
304 } else if ((odr >= 800.0) && (odr < 1600.0)) {
305 reg = BMI270_GYR_ODR_800_HZ;
306 } else if ((odr >= 1600.0) && (odr < 3200.0)) {
307 reg = BMI270_GYR_ODR_1600_HZ;
308 } else if (odr >= 3200.0) {
309 reg = BMI270_GYR_ODR_3200_HZ;
310 }
311
312 return reg;
313 }
314
set_gyro_odr_osr(const struct device * dev,const struct sensor_value * odr,const struct sensor_value * osr)315 static int set_gyro_odr_osr(const struct device *dev, const struct sensor_value *odr,
316 const struct sensor_value *osr)
317 {
318 struct bmi270_data *data = dev->data;
319 uint8_t gyr_conf, odr_bits, pwr_ctrl, osr_bits;
320 int ret = 0;
321
322 if (odr || osr) {
323 ret = bmi270_reg_read(dev, BMI270_REG_GYR_CONF, &gyr_conf, 1);
324 if (ret != 0) {
325 return ret;
326 }
327
328 ret = bmi270_reg_read(dev, BMI270_REG_PWR_CTRL, &pwr_ctrl, 1);
329 if (ret != 0) {
330 return ret;
331 }
332 }
333
334 if (odr) {
335 odr_bits = gyr_odr_to_reg(odr);
336 gyr_conf = BMI270_SET_BITS_POS_0(gyr_conf, BMI270_GYR_ODR,
337 odr_bits);
338
339 /* If odr_bits is 0, implies that the sampling frequency is
340 * 0Hz or invalid too.
341 */
342 if (odr_bits) {
343 pwr_ctrl |= BMI270_PWR_CTRL_GYR_EN;
344 } else {
345 pwr_ctrl &= ~BMI270_PWR_CTRL_GYR_EN;
346 }
347
348 /* If the Sampling frequency (odr) >= 100Hz, enter performance
349 * mode else, power optimized. This also has a consequence for
350 * the OSR
351 */
352 if (odr_bits >= BMI270_GYR_ODR_100_HZ) {
353 gyr_conf = BMI270_SET_BITS(gyr_conf,
354 BMI270_GYR_FILT,
355 BMI270_GYR_FILT_PERF_OPT);
356 gyr_conf = BMI270_SET_BITS(gyr_conf,
357 BMI270_GYR_FILT_NOISE,
358 BMI270_GYR_FILT_NOISE_PERF);
359 } else {
360 gyr_conf = BMI270_SET_BITS(gyr_conf,
361 BMI270_GYR_FILT,
362 BMI270_GYR_FILT_PWR_OPT);
363 gyr_conf = BMI270_SET_BITS(gyr_conf,
364 BMI270_GYR_FILT_NOISE,
365 BMI270_GYR_FILT_NOISE_PWR);
366 }
367
368 data->gyr_odr = odr_bits;
369 }
370
371 if (osr) {
372 /* osr->val2 should be unused */
373 switch (osr->val1) {
374 case 4:
375 osr_bits = BMI270_GYR_BWP_OSR4;
376 break;
377 case 2:
378 osr_bits = BMI270_GYR_BWP_OSR2;
379 break;
380 default:
381 osr_bits = BMI270_GYR_BWP_NORM;
382 break;
383 }
384
385 gyr_conf = BMI270_SET_BITS(gyr_conf, BMI270_GYR_BWP,
386 osr_bits);
387 }
388
389 if (odr || osr) {
390 ret = bmi270_reg_write(dev, BMI270_REG_GYR_CONF, &gyr_conf, 1);
391 if (ret != 0) {
392 return ret;
393 }
394
395 /* Assuming we have advance power save enabled */
396 k_usleep(BMI270_TRANSC_DELAY_SUSPEND);
397
398 pwr_ctrl &= BMI270_PWR_CTRL_MSK;
399 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_PWR_CTRL,
400 &pwr_ctrl, 1,
401 BMI270_INTER_WRITE_DELAY_US);
402 }
403
404 return ret;
405 }
406
set_gyro_range(const struct device * dev,const struct sensor_value * range)407 static int set_gyro_range(const struct device *dev, const struct sensor_value *range)
408 {
409 struct bmi270_data *data = dev->data;
410 int ret = 0;
411 uint8_t gyr_range, reg;
412
413 ret = bmi270_reg_read(dev, BMI270_REG_GYR_RANGE, &gyr_range, 1);
414 if (ret != 0) {
415 return ret;
416 }
417
418 /* range->val2 is unused */
419 switch (range->val1) {
420 case 125:
421 reg = BMI270_GYR_RANGE_125DPS;
422 data->gyr_range = 125;
423 break;
424 case 250:
425 reg = BMI270_GYR_RANGE_250DPS;
426 data->gyr_range = 250;
427 break;
428 case 500:
429 reg = BMI270_GYR_RANGE_500DPS;
430 data->gyr_range = 500;
431 break;
432 case 1000:
433 reg = BMI270_GYR_RANGE_1000DPS;
434 data->gyr_range = 1000;
435 break;
436 case 2000:
437 reg = BMI270_GYR_RANGE_2000DPS;
438 data->gyr_range = 2000;
439 break;
440 default:
441 return -ENOTSUP;
442 }
443
444 gyr_range = BMI270_SET_BITS_POS_0(gyr_range, BMI270_GYR_RANGE, reg);
445 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_GYR_RANGE, &gyr_range,
446 1, BMI270_INTER_WRITE_DELAY_US);
447
448 return ret;
449 }
450
write_config_file(const struct device * dev)451 static int8_t write_config_file(const struct device *dev)
452 {
453 const struct bmi270_config *cfg = dev->config;
454 int8_t ret = 0;
455 uint16_t index = 0;
456 uint8_t addr_array[2] = { 0 };
457
458 LOG_DBG("writing config file %s", cfg->feature->name);
459
460 /* Disable loading of the configuration */
461 for (index = 0; index < cfg->feature->config_file_len;
462 index += BMI270_WR_LEN) {
463 /* Store 0 to 3 bits of address in first byte */
464 addr_array[0] = (uint8_t)((index / 2) & 0x0F);
465
466 /* Store 4 to 11 bits of address in the second byte */
467 addr_array[1] = (uint8_t)((index / 2) >> 4);
468
469 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_INIT_ADDR_0,
470 addr_array, 2,
471 BMI270_INTER_WRITE_DELAY_US);
472
473 if (ret == 0) {
474 ret = bmi270_reg_write_with_delay(dev,
475 BMI270_REG_INIT_DATA,
476 &cfg->feature->config_file[index],
477 BMI270_WR_LEN,
478 BMI270_INTER_WRITE_DELAY_US);
479 }
480 }
481
482 return ret;
483 }
484
bmi270_sample_fetch(const struct device * dev,enum sensor_channel chan)485 static int bmi270_sample_fetch(const struct device *dev, enum sensor_channel chan)
486 {
487 struct bmi270_data *data = dev->data;
488 uint8_t buf[12];
489 int ret;
490
491 if (chan != SENSOR_CHAN_ALL) {
492 return -ENOTSUP;
493 }
494
495 ret = bmi270_reg_read(dev, BMI270_REG_ACC_X_LSB, buf, 12);
496 if (ret == 0) {
497 data->ax = (int16_t)sys_get_le16(&buf[0]);
498 data->ay = (int16_t)sys_get_le16(&buf[2]);
499 data->az = (int16_t)sys_get_le16(&buf[4]);
500 data->gx = (int16_t)sys_get_le16(&buf[6]);
501 data->gy = (int16_t)sys_get_le16(&buf[8]);
502 data->gz = (int16_t)sys_get_le16(&buf[10]);
503 } else {
504 data->ax = 0;
505 data->ay = 0;
506 data->az = 0;
507 data->gx = 0;
508 data->gy = 0;
509 data->gz = 0;
510 }
511
512 return ret;
513 }
514
bmi270_channel_get(const struct device * dev,enum sensor_channel chan,struct sensor_value * val)515 static int bmi270_channel_get(const struct device *dev, enum sensor_channel chan,
516 struct sensor_value *val)
517 {
518 struct bmi270_data *data = dev->data;
519
520 if (chan == SENSOR_CHAN_ACCEL_X) {
521 channel_accel_convert(val, data->ax, data->acc_range);
522 } else if (chan == SENSOR_CHAN_ACCEL_Y) {
523 channel_accel_convert(val, data->ay, data->acc_range);
524 } else if (chan == SENSOR_CHAN_ACCEL_Z) {
525 channel_accel_convert(val, data->az, data->acc_range);
526 } else if (chan == SENSOR_CHAN_ACCEL_XYZ) {
527 channel_accel_convert(&val[0], data->ax,
528 data->acc_range);
529 channel_accel_convert(&val[1], data->ay,
530 data->acc_range);
531 channel_accel_convert(&val[2], data->az,
532 data->acc_range);
533 } else if (chan == SENSOR_CHAN_GYRO_X) {
534 channel_gyro_convert(val, data->gx, data->gyr_range);
535 } else if (chan == SENSOR_CHAN_GYRO_Y) {
536 channel_gyro_convert(val, data->gy, data->gyr_range);
537 } else if (chan == SENSOR_CHAN_GYRO_Z) {
538 channel_gyro_convert(val, data->gz, data->gyr_range);
539 } else if (chan == SENSOR_CHAN_GYRO_XYZ) {
540 channel_gyro_convert(&val[0], data->gx,
541 data->gyr_range);
542 channel_gyro_convert(&val[1], data->gy,
543 data->gyr_range);
544 channel_gyro_convert(&val[2], data->gz,
545 data->gyr_range);
546 } else {
547 return -ENOTSUP;
548 }
549
550 return 0;
551 }
552
553 #if defined(CONFIG_BMI270_TRIGGER)
554
555 /* ANYMO_1.duration conversion is 20 ms / LSB */
556 #define ANYMO_1_DURATION_MSEC_TO_LSB(_ms) \
557 BMI270_ANYMO_1_DURATION(_ms / 20)
558
bmi270_write_anymo_threshold(const struct device * dev,struct sensor_value val)559 static int bmi270_write_anymo_threshold(const struct device *dev,
560 struct sensor_value val)
561 {
562 struct bmi270_data *data = dev->data;
563
564 /* this takes configuration in g. */
565 if (val.val1 > 0) {
566 LOG_DBG("anymo_threshold set to max");
567 val.val2 = 1e6;
568 }
569
570 /* max = BIT_MASK(10) = 1g => 0.49 mg/LSB */
571 uint16_t lsbs = (val.val2 * BMI270_ANYMO_2_THRESHOLD_MASK) / 1e6;
572
573 if (!lsbs) {
574 LOG_ERR("Threshold too low!");
575 return -EINVAL;
576 }
577
578 uint16_t anymo_2 = BMI270_ANYMO_2_THRESHOLD(lsbs)
579 | BMI270_ANYMO_2_OUT_CONF_BIT_6;
580
581 data->anymo_2 = anymo_2;
582 return 0;
583 }
584
bmi270_write_anymo_duration(const struct device * dev,uint32_t ms)585 static int bmi270_write_anymo_duration(const struct device *dev, uint32_t ms)
586 {
587 struct bmi270_data *data = dev->data;
588 uint16_t val = ANYMO_1_DURATION_MSEC_TO_LSB(ms)
589 | BMI270_ANYMO_1_SELECT_XYZ;
590
591 data->anymo_1 = val;
592 return 0;
593 }
594 #endif /* CONFIG_BMI270_TRIGGER */
595
bmi270_attr_set(const struct device * dev,enum sensor_channel chan,enum sensor_attribute attr,const struct sensor_value * val)596 static int bmi270_attr_set(const struct device *dev, enum sensor_channel chan,
597 enum sensor_attribute attr, const struct sensor_value *val)
598 {
599 int ret = -ENOTSUP;
600
601 if ((chan == SENSOR_CHAN_ACCEL_X) || (chan == SENSOR_CHAN_ACCEL_Y)
602 || (chan == SENSOR_CHAN_ACCEL_Z)
603 || (chan == SENSOR_CHAN_ACCEL_XYZ)) {
604 switch (attr) {
605 case SENSOR_ATTR_SAMPLING_FREQUENCY:
606 ret = set_accel_odr_osr(dev, val, NULL);
607 break;
608 case SENSOR_ATTR_OVERSAMPLING:
609 ret = set_accel_odr_osr(dev, NULL, val);
610 break;
611 case SENSOR_ATTR_FULL_SCALE:
612 ret = set_accel_range(dev, val);
613 break;
614 #if defined(CONFIG_BMI270_TRIGGER)
615 case SENSOR_ATTR_SLOPE_DUR:
616 return bmi270_write_anymo_duration(dev, val->val1);
617 case SENSOR_ATTR_SLOPE_TH:
618 return bmi270_write_anymo_threshold(dev, *val);
619 #endif
620 default:
621 ret = -ENOTSUP;
622 }
623 } else if ((chan == SENSOR_CHAN_GYRO_X) || (chan == SENSOR_CHAN_GYRO_Y)
624 || (chan == SENSOR_CHAN_GYRO_Z)
625 || (chan == SENSOR_CHAN_GYRO_XYZ)) {
626 switch (attr) {
627 case SENSOR_ATTR_SAMPLING_FREQUENCY:
628 ret = set_gyro_odr_osr(dev, val, NULL);
629 break;
630 case SENSOR_ATTR_OVERSAMPLING:
631 ret = set_gyro_odr_osr(dev, NULL, val);
632 break;
633 case SENSOR_ATTR_FULL_SCALE:
634 ret = set_gyro_range(dev, val);
635 break;
636 default:
637 ret = -ENOTSUP;
638 }
639 }
640
641 return ret;
642 }
643
bmi270_init(const struct device * dev)644 static int bmi270_init(const struct device *dev)
645 {
646 int ret;
647 struct bmi270_data *data = dev->data;
648 uint8_t chip_id;
649 uint8_t soft_reset_cmd;
650 uint8_t init_ctrl;
651 uint8_t msg;
652 uint8_t tries;
653 uint8_t adv_pwr_save;
654
655 ret = bmi270_bus_check(dev);
656 if (ret < 0) {
657 LOG_ERR("Could not initialize bus");
658 return ret;
659 }
660
661 #if CONFIG_BMI270_TRIGGER
662 data->dev = dev;
663 k_mutex_init(&data->trigger_mutex);
664 #endif
665
666 data->acc_odr = BMI270_ACC_ODR_100_HZ;
667 data->acc_range = 8;
668 data->gyr_odr = BMI270_GYR_ODR_200_HZ;
669 data->gyr_range = 2000;
670
671 k_usleep(BMI270_POWER_ON_TIME);
672
673 ret = bmi270_bus_init(dev);
674 if (ret != 0) {
675 LOG_ERR("Could not initiate bus communication");
676 return ret;
677 }
678
679 ret = bmi270_reg_read(dev, BMI270_REG_CHIP_ID, &chip_id, 1);
680 if (ret != 0) {
681 return ret;
682 }
683
684 if (chip_id != BMI270_CHIP_ID) {
685 LOG_ERR("Unexpected chip id (%x). Expected (%x)",
686 chip_id, BMI270_CHIP_ID);
687 return -EIO;
688 }
689
690 soft_reset_cmd = BMI270_CMD_SOFT_RESET;
691 ret = bmi270_reg_write(dev, BMI270_REG_CMD, &soft_reset_cmd, 1);
692 if (ret != 0) {
693 return ret;
694 }
695
696 k_usleep(BMI270_SOFT_RESET_TIME);
697
698 ret = bmi270_reg_read(dev, BMI270_REG_PWR_CONF, &adv_pwr_save, 1);
699 if (ret != 0) {
700 return ret;
701 }
702
703 adv_pwr_save = BMI270_SET_BITS_POS_0(adv_pwr_save,
704 BMI270_PWR_CONF_ADV_PWR_SAVE,
705 BMI270_PWR_CONF_ADV_PWR_SAVE_DIS);
706 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_PWR_CONF,
707 &adv_pwr_save, 1,
708 BMI270_INTER_WRITE_DELAY_US);
709 if (ret != 0) {
710 return ret;
711 }
712
713 init_ctrl = BMI270_PREPARE_CONFIG_LOAD;
714 ret = bmi270_reg_write(dev, BMI270_REG_INIT_CTRL, &init_ctrl, 1);
715 if (ret != 0) {
716 return ret;
717 }
718
719 ret = write_config_file(dev);
720
721 if (ret != 0) {
722 return ret;
723 }
724
725 init_ctrl = BMI270_COMPLETE_CONFIG_LOAD;
726 ret = bmi270_reg_write(dev, BMI270_REG_INIT_CTRL, &init_ctrl, 1);
727 if (ret != 0) {
728 return ret;
729 }
730
731 /* Timeout after BMI270_CONFIG_FILE_RETRIES x
732 * BMI270_CONFIG_FILE_POLL_PERIOD_US microseconds.
733 * If tries is BMI270_CONFIG_FILE_RETRIES by the end of the loop,
734 * report an error
735 */
736 for (tries = 0; tries <= BMI270_CONFIG_FILE_RETRIES; tries++) {
737 ret = bmi270_reg_read(dev, BMI270_REG_INTERNAL_STATUS, &msg, 1);
738 if (ret != 0) {
739 return ret;
740 }
741
742 msg &= BMI270_INST_MESSAGE_MSK;
743 if (msg == BMI270_INST_MESSAGE_INIT_OK) {
744 break;
745 }
746
747 k_usleep(BMI270_CONFIG_FILE_POLL_PERIOD_US);
748 }
749
750 if (tries == BMI270_CONFIG_FILE_RETRIES) {
751 return -EIO;
752 }
753
754 #if CONFIG_BMI270_TRIGGER
755 ret = bmi270_init_interrupts(dev);
756 if (ret) {
757 LOG_ERR("bmi270_init_interrupts returned %d", ret);
758 return ret;
759 }
760 #endif
761
762 adv_pwr_save = BMI270_SET_BITS_POS_0(adv_pwr_save,
763 BMI270_PWR_CONF_ADV_PWR_SAVE,
764 BMI270_PWR_CONF_ADV_PWR_SAVE_EN);
765 ret = bmi270_reg_write_with_delay(dev, BMI270_REG_PWR_CONF,
766 &adv_pwr_save, 1,
767 BMI270_INTER_WRITE_DELAY_US);
768
769 return ret;
770 }
771
772 static DEVICE_API(sensor, bmi270_driver_api) = {
773 .sample_fetch = bmi270_sample_fetch,
774 .channel_get = bmi270_channel_get,
775 .attr_set = bmi270_attr_set,
776 #if defined(CONFIG_BMI270_TRIGGER)
777 .trigger_set = bmi270_trigger_set,
778 #endif
779 };
780
781 static const struct bmi270_feature_config bmi270_feature_max_fifo = {
782 .name = "max_fifo",
783 .config_file = bmi270_config_file_max_fifo,
784 .config_file_len = sizeof(bmi270_config_file_max_fifo),
785 };
786
787 static const struct bmi270_feature_config bmi270_feature_base = {
788 .name = "base",
789 .config_file = bmi270_config_file_base,
790 .config_file_len = sizeof(bmi270_config_file_base),
791 .anymo_1 = &(struct bmi270_feature_reg){ .page = 1, .addr = 0x3C },
792 .anymo_2 = &(struct bmi270_feature_reg){ .page = 1, .addr = 0x3E },
793 };
794
795 #define BMI270_FEATURE(inst) ( \
796 DT_INST_NODE_HAS_COMPAT(inst, bosch_bmi270_base) ? \
797 &bmi270_feature_base : \
798 &bmi270_feature_max_fifo)
799
800 #if CONFIG_BMI270_TRIGGER
801 #define BMI270_CONFIG_INT(inst) \
802 .int1 = GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, irq_gpios, 0, {}),\
803 .int2 = GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, irq_gpios, 1, {}),
804 #else
805 #define BMI270_CONFIG_INT(inst)
806 #endif
807
808 /* Initializes a struct bmi270_config for an instance on a SPI bus. */
809 #define BMI270_CONFIG_SPI(inst) \
810 .bus.spi = SPI_DT_SPEC_INST_GET( \
811 inst, BMI270_SPI_OPERATION, 0), \
812 .bus_io = &bmi270_bus_io_spi,
813
814 /* Initializes a struct bmi270_config for an instance on an I2C bus. */
815 #define BMI270_CONFIG_I2C(inst) \
816 .bus.i2c = I2C_DT_SPEC_INST_GET(inst), \
817 .bus_io = &bmi270_bus_io_i2c,
818
819 #define BMI270_CREATE_INST(inst) \
820 \
821 static struct bmi270_data bmi270_drv_##inst; \
822 \
823 static const struct bmi270_config bmi270_config_##inst = { \
824 COND_CODE_1(DT_INST_ON_BUS(inst, spi), \
825 (BMI270_CONFIG_SPI(inst)), \
826 (BMI270_CONFIG_I2C(inst))) \
827 .feature = BMI270_FEATURE(inst), \
828 BMI270_CONFIG_INT(inst) \
829 }; \
830 \
831 SENSOR_DEVICE_DT_INST_DEFINE(inst, \
832 bmi270_init, \
833 NULL, \
834 &bmi270_drv_##inst, \
835 &bmi270_config_##inst, \
836 POST_KERNEL, \
837 CONFIG_SENSOR_INIT_PRIORITY, \
838 &bmi270_driver_api);
839
840 DT_INST_FOREACH_STATUS_OKAY(BMI270_CREATE_INST);
841