1 /* Bosch BMI160 inertial measurement unit driver
2 *
3 * Copyright (c) 2016 Intel Corporation
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 *
7 * Datasheet:
8 * http://ae-bst.resource.bosch.com/media/_tech/media/datasheets/BST-BMI160-DS000-07.pdf
9 */
10
11 #include <zephyr/init.h>
12 #include <zephyr/drivers/i2c.h>
13 #include <zephyr/drivers/sensor.h>
14 #include <zephyr/sys/byteorder.h>
15 #include <zephyr/kernel.h>
16 #include <zephyr/sys/__assert.h>
17 #include <zephyr/pm/pm.h>
18 #include <zephyr/pm/device.h>
19 #include <zephyr/pm/device_runtime.h>
20 #include <zephyr/logging/log.h>
21
22 #include "bmi160.h"
23
24 LOG_MODULE_REGISTER(BMI160, CONFIG_SENSOR_LOG_LEVEL);
25
26 #if DT_NUM_INST_STATUS_OKAY(DT_DRV_COMPAT) == 0
27 #warning "BMI160 driver enabled without any devices"
28 #endif
29
30 #if BMI160_BUS_SPI
bmi160_transceive(const struct device * dev,uint8_t reg,bool write,void * buf,size_t length)31 static int bmi160_transceive(const struct device *dev, uint8_t reg,
32 bool write, void *buf, size_t length)
33 {
34 const struct bmi160_cfg *cfg = dev->config;
35 const struct spi_buf tx_buf[2] = {
36 {
37 .buf = ®,
38 .len = 1
39 },
40 {
41 .buf = buf,
42 .len = length
43 }
44 };
45 const struct spi_buf_set tx = {
46 .buffers = tx_buf,
47 .count = buf ? 2 : 1
48 };
49
50 if (!write) {
51 const struct spi_buf_set rx = {
52 .buffers = tx_buf,
53 .count = 2
54 };
55
56 return spi_transceive_dt(&cfg->bus.spi, &tx, &rx);
57 }
58
59 return spi_write_dt(&cfg->bus.spi, &tx);
60 }
61
bmi160_bus_ready_spi(const struct device * dev)62 bool bmi160_bus_ready_spi(const struct device *dev)
63 {
64 const struct bmi160_cfg *cfg = dev->config;
65
66 return spi_is_ready_dt(&cfg->bus.spi);
67 }
68
bmi160_read_spi(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)69 int bmi160_read_spi(const struct device *dev,
70 uint8_t reg_addr, void *buf, uint8_t len)
71 {
72 return bmi160_transceive(dev, reg_addr | BMI160_REG_READ, false,
73 buf, len);
74 }
75
bmi160_write_spi(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)76 int bmi160_write_spi(const struct device *dev,
77 uint8_t reg_addr, void *buf, uint8_t len)
78 {
79 return bmi160_transceive(dev, reg_addr & BMI160_REG_MASK, true,
80 buf, len);
81 }
82
83 static const struct bmi160_bus_io bmi160_bus_io_spi = {
84 .ready = bmi160_bus_ready_spi,
85 .read = bmi160_read_spi,
86 .write = bmi160_write_spi,
87 };
88 #endif /* BMI160_BUS_SPI */
89
90 #if BMI160_BUS_I2C
91
bmi160_bus_ready_i2c(const struct device * dev)92 bool bmi160_bus_ready_i2c(const struct device *dev)
93 {
94 const struct bmi160_cfg *cfg = dev->config;
95
96 return device_is_ready(cfg->bus.i2c.bus);
97 }
98
bmi160_read_i2c(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)99 int bmi160_read_i2c(const struct device *dev,
100 uint8_t reg_addr, void *buf, uint8_t len)
101 {
102 const struct bmi160_cfg *cfg = dev->config;
103
104 return i2c_burst_read_dt(&cfg->bus.i2c, reg_addr, buf, len);
105 }
106
bmi160_write_i2c(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)107 int bmi160_write_i2c(const struct device *dev,
108 uint8_t reg_addr, void *buf, uint8_t len)
109 {
110 const struct bmi160_cfg *cfg = dev->config;
111
112 return i2c_burst_write_dt(&cfg->bus.i2c, reg_addr, buf, len);
113 }
114
115 static const struct bmi160_bus_io bmi160_bus_io_i2c = {
116 .ready = bmi160_bus_ready_i2c,
117 .read = bmi160_read_i2c,
118 .write = bmi160_write_i2c,
119 };
120 #endif
121
bmi160_read(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)122 int bmi160_read(const struct device *dev, uint8_t reg_addr, void *buf,
123 uint8_t len)
124 {
125 const struct bmi160_cfg *cfg = dev->config;
126
127 return cfg->bus_io->read(dev, reg_addr, buf, len);
128 }
129
bmi160_byte_read(const struct device * dev,uint8_t reg_addr,uint8_t * byte)130 int bmi160_byte_read(const struct device *dev, uint8_t reg_addr, uint8_t *byte)
131 {
132 return bmi160_read(dev, reg_addr, byte, 1);
133 }
134
bmi160_word_read(const struct device * dev,uint8_t reg_addr,uint16_t * word)135 static int bmi160_word_read(const struct device *dev, uint8_t reg_addr,
136 uint16_t *word)
137 {
138 int rc;
139
140 rc = bmi160_read(dev, reg_addr, word, 2);
141 if (rc != 0) {
142 return rc;
143 }
144
145 *word = sys_le16_to_cpu(*word);
146
147 return 0;
148 }
149
bmi160_write(const struct device * dev,uint8_t reg_addr,void * buf,uint8_t len)150 int bmi160_write(const struct device *dev, uint8_t reg_addr, void *buf,
151 uint8_t len)
152 {
153 const struct bmi160_cfg *cfg = dev->config;
154
155 return cfg->bus_io->write(dev, reg_addr, buf, len);
156 }
157
bmi160_byte_write(const struct device * dev,uint8_t reg_addr,uint8_t byte)158 int bmi160_byte_write(const struct device *dev, uint8_t reg_addr,
159 uint8_t byte)
160 {
161 return bmi160_write(dev, reg_addr & BMI160_REG_MASK, &byte, 1);
162 }
163
bmi160_word_write(const struct device * dev,uint8_t reg_addr,uint16_t word)164 int bmi160_word_write(const struct device *dev, uint8_t reg_addr,
165 uint16_t word)
166 {
167 uint8_t tx_word[2] = {
168 (uint8_t)(word & 0xff),
169 (uint8_t)(word >> 8)
170 };
171
172 return bmi160_write(dev, reg_addr & BMI160_REG_MASK, tx_word, 2);
173 }
174
bmi160_reg_field_update(const struct device * dev,uint8_t reg_addr,uint8_t pos,uint8_t mask,uint8_t val)175 int bmi160_reg_field_update(const struct device *dev, uint8_t reg_addr,
176 uint8_t pos, uint8_t mask, uint8_t val)
177 {
178 uint8_t old_val;
179
180 if (bmi160_byte_read(dev, reg_addr, &old_val) < 0) {
181 return -EIO;
182 }
183
184 return bmi160_byte_write(dev, reg_addr,
185 (old_val & ~mask) | ((val << pos) & mask));
186 }
187
bmi160_pmu_set(const struct device * dev,union bmi160_pmu_status * pmu_sts)188 static int bmi160_pmu_set(const struct device *dev,
189 union bmi160_pmu_status *pmu_sts)
190 {
191 struct {
192 uint8_t cmd;
193 uint16_t delay_us; /* values taken from page 82 */
194 } cmds[] = {
195 {BMI160_CMD_PMU_MAG | pmu_sts->mag, 350},
196 {BMI160_CMD_PMU_ACC | pmu_sts->acc, 3200},
197 {BMI160_CMD_PMU_GYR | pmu_sts->gyr, 55000}
198 };
199 size_t i;
200
201 for (i = 0; i < ARRAY_SIZE(cmds); i++) {
202 union bmi160_pmu_status sts;
203 bool pmu_set = false;
204
205 if (bmi160_byte_write(dev, BMI160_REG_CMD, cmds[i].cmd) < 0) {
206 return -EIO;
207 }
208
209 /*
210 * Cannot use a timer here since this is called from the
211 * init function and the timeouts were not initialized yet.
212 */
213 k_busy_wait(cmds[i].delay_us);
214
215 /* make sure the PMU_STATUS was set, though */
216 do {
217 if (bmi160_byte_read(dev, BMI160_REG_PMU_STATUS,
218 &sts.raw) < 0) {
219 return -EIO;
220 }
221
222 if (i == 0) {
223 pmu_set = (pmu_sts->mag == sts.mag);
224 } else if (i == 1) {
225 pmu_set = (pmu_sts->acc == sts.acc);
226 } else {
227 pmu_set = (pmu_sts->gyr == sts.gyr);
228 }
229
230 } while (!pmu_set);
231 }
232
233 /* set the undersampling flag for accelerometer */
234 return bmi160_reg_field_update(dev, BMI160_REG_ACC_CONF,
235 BMI160_ACC_CONF_US_POS, BMI160_ACC_CONF_US_MASK,
236 pmu_sts->acc != BMI160_PMU_NORMAL);
237 }
238
239 #if defined(CONFIG_BMI160_GYRO_ODR_RUNTIME) ||\
240 defined(CONFIG_BMI160_ACCEL_ODR_RUNTIME)
241 /*
242 * Output data rate map with allowed frequencies:
243 * freq = freq_int + freq_milli / 1000
244 *
245 * Since we don't need a finer frequency resolution than milliHz, use uint16_t
246 * to save some flash.
247 */
248 struct {
249 uint16_t freq_int;
250 uint16_t freq_milli; /* User should convert to uHz before setting the
251 * SENSOR_ATTR_SAMPLING_FREQUENCY attribute.
252 */
253 } bmi160_odr_map[] = {
254 {0, 0 }, {0, 781}, {1, 562}, {3, 125}, {6, 250},
255 {12, 500}, {25, 0 }, {50, 0 }, {100, 0 }, {200, 0 },
256 {400, 0 }, {800, 0 }, {1600, 0 }, {3200, 0 },
257 };
258
bmi160_freq_to_odr_val(uint16_t freq_int,uint16_t freq_milli)259 static int bmi160_freq_to_odr_val(uint16_t freq_int, uint16_t freq_milli)
260 {
261 size_t i;
262
263 /* An ODR of 0 Hz is not allowed */
264 if (freq_int == 0U && freq_milli == 0U) {
265 return -EINVAL;
266 }
267
268 for (i = 0; i < ARRAY_SIZE(bmi160_odr_map); i++) {
269 if (freq_int < bmi160_odr_map[i].freq_int ||
270 (freq_int == bmi160_odr_map[i].freq_int &&
271 freq_milli <= bmi160_odr_map[i].freq_milli)) {
272 return i;
273 }
274 }
275
276 return -EINVAL;
277 }
278 #endif
279
280 #if defined(CONFIG_BMI160_ACCEL_ODR_RUNTIME)
bmi160_acc_odr_set(const struct device * dev,uint16_t freq_int,uint16_t freq_milli)281 static int bmi160_acc_odr_set(const struct device *dev, uint16_t freq_int,
282 uint16_t freq_milli)
283 {
284 int odr = bmi160_freq_to_odr_val(freq_int, freq_milli);
285
286 if (odr < 0) {
287 return odr;
288 }
289
290 return bmi160_reg_field_update(dev, BMI160_REG_ACC_CONF,
291 BMI160_ACC_CONF_ODR_POS,
292 BMI160_ACC_CONF_ODR_MASK,
293 (uint8_t) odr);
294 }
295 #endif
296
297 static const struct bmi160_range bmi160_acc_range_map[] = {
298 {2, BMI160_ACC_RANGE_2G},
299 {4, BMI160_ACC_RANGE_4G},
300 {8, BMI160_ACC_RANGE_8G},
301 {16, BMI160_ACC_RANGE_16G},
302 };
303 #define BMI160_ACC_RANGE_MAP_SIZE ARRAY_SIZE(bmi160_acc_range_map)
304
305 static const struct bmi160_range bmi160_gyr_range_map[] = {
306 {125, BMI160_GYR_RANGE_125DPS},
307 {250, BMI160_GYR_RANGE_250DPS},
308 {500, BMI160_GYR_RANGE_500DPS},
309 {1000, BMI160_GYR_RANGE_1000DPS},
310 {2000, BMI160_GYR_RANGE_2000DPS},
311 };
312 #define BMI160_GYR_RANGE_MAP_SIZE ARRAY_SIZE(bmi160_gyr_range_map)
313
314 #if defined(CONFIG_BMI160_ACCEL_RANGE_RUNTIME) ||\
315 defined(CONFIG_BMI160_GYRO_RANGE_RUNTIME)
bmi160_range_to_reg_val(uint16_t range,const struct bmi160_range * range_map,uint16_t range_map_size)316 static int32_t bmi160_range_to_reg_val(uint16_t range,
317 const struct bmi160_range *range_map,
318 uint16_t range_map_size)
319 {
320 int i;
321
322 for (i = 0; i < range_map_size; i++) {
323 if (range <= range_map[i].range) {
324 return range_map[i].reg_val;
325 }
326 }
327
328 return -EINVAL;
329 }
330 #endif
331
bmi160_reg_val_to_range(uint8_t reg_val,const struct bmi160_range * range_map,uint16_t range_map_size)332 static int32_t bmi160_reg_val_to_range(uint8_t reg_val,
333 const struct bmi160_range *range_map,
334 uint16_t range_map_size)
335 {
336 int i;
337
338 for (i = 0; i < range_map_size; i++) {
339 if (reg_val == range_map[i].reg_val) {
340 return range_map[i].range;
341 }
342 }
343
344 return -EINVAL;
345 }
346
bmi160_acc_reg_val_to_range(uint8_t reg_val)347 int32_t bmi160_acc_reg_val_to_range(uint8_t reg_val)
348 {
349 return bmi160_reg_val_to_range(reg_val, bmi160_acc_range_map,
350 BMI160_ACC_RANGE_MAP_SIZE);
351 }
352
bmi160_gyr_reg_val_to_range(uint8_t reg_val)353 int32_t bmi160_gyr_reg_val_to_range(uint8_t reg_val)
354 {
355 return bmi160_reg_val_to_range(reg_val, bmi160_gyr_range_map,
356 BMI160_GYR_RANGE_MAP_SIZE);
357 }
358
bmi160_do_calibration(const struct device * dev,uint8_t foc_conf)359 static int bmi160_do_calibration(const struct device *dev, uint8_t foc_conf)
360 {
361 if (bmi160_byte_write(dev, BMI160_REG_FOC_CONF, foc_conf) < 0) {
362 return -EIO;
363 }
364
365 if (bmi160_byte_write(dev, BMI160_REG_CMD, BMI160_CMD_START_FOC) < 0) {
366 return -EIO;
367 }
368
369 k_busy_wait(250000); /* calibration takes a maximum of 250ms */
370
371 return 0;
372 }
373
374 #if defined(CONFIG_BMI160_ACCEL_RANGE_RUNTIME)
bmi160_acc_range_set(const struct device * dev,const struct sensor_value * val)375 static int bmi160_acc_range_set(const struct device *dev, const struct sensor_value *val)
376 {
377 int32_t range_g = sensor_ms2_to_g(val);
378 struct bmi160_data *data = dev->data;
379 int32_t reg_val = bmi160_range_to_reg_val(range_g,
380 bmi160_acc_range_map,
381 BMI160_ACC_RANGE_MAP_SIZE);
382
383 if (reg_val < 0) {
384 return reg_val;
385 }
386
387 switch (reg_val & 0xff) {
388 case BMI160_ACC_RANGE_2G:
389 range_g = 2;
390 break;
391 case BMI160_ACC_RANGE_4G:
392 range_g = 4;
393 break;
394 case BMI160_ACC_RANGE_8G:
395 range_g = 8;
396 break;
397 case BMI160_ACC_RANGE_16G:
398 range_g = 16;
399 break;
400 }
401
402 if (bmi160_byte_write(dev, BMI160_REG_ACC_RANGE, reg_val & 0xff) < 0) {
403 return -EIO;
404 }
405
406 data->scale.acc_numerator = BMI160_ACC_SCALE_NUMERATOR(range_g);
407 return 0;
408 }
409 #endif
410
411 #if !defined(CONFIG_BMI160_ACCEL_PMU_SUSPEND)
412 /*
413 * Accelerometer offset scale, taken from pg. 79, converted to micro m/s^2:
414 * 3.9 * 9.80665 * 1000
415 */
416 #define BMI160_ACC_OFS_LSB 38246
bmi160_acc_ofs_set(const struct device * dev,enum sensor_channel chan,const struct sensor_value * ofs)417 static int bmi160_acc_ofs_set(const struct device *dev,
418 enum sensor_channel chan,
419 const struct sensor_value *ofs)
420 {
421 uint8_t reg_addr[] = {
422 BMI160_REG_OFFSET_ACC_X,
423 BMI160_REG_OFFSET_ACC_Y,
424 BMI160_REG_OFFSET_ACC_Z
425 };
426 int i;
427 int32_t reg_val;
428
429 /* we need the offsets for all axis */
430 if (chan != SENSOR_CHAN_ACCEL_XYZ) {
431 return -ENOTSUP;
432 }
433
434 for (i = 0; i < BMI160_AXES; i++, ofs++) {
435 /* convert offset to micro m/s^2 */
436 reg_val =
437 CLAMP(sensor_value_to_micro(ofs) / BMI160_ACC_OFS_LSB, INT8_MIN, INT8_MAX);
438
439 if (bmi160_byte_write(dev, reg_addr[i], reg_val) < 0) {
440 return -EIO;
441 }
442 }
443
444 /* activate accel HW compensation */
445 return bmi160_reg_field_update(dev, BMI160_REG_OFFSET_EN,
446 BMI160_ACC_OFS_EN_POS,
447 BIT(BMI160_ACC_OFS_EN_POS), 1);
448 }
449
bmi160_acc_calibrate(const struct device * dev,enum sensor_channel chan,const struct sensor_value * xyz_calib_value)450 static int bmi160_acc_calibrate(const struct device *dev,
451 enum sensor_channel chan,
452 const struct sensor_value *xyz_calib_value)
453 {
454 struct bmi160_data *data = dev->data;
455 uint8_t foc_pos[] = {
456 BMI160_FOC_ACC_X_POS,
457 BMI160_FOC_ACC_Y_POS,
458 BMI160_FOC_ACC_Z_POS,
459 };
460 int i;
461 uint8_t reg_val = 0U;
462
463 /* Calibration has to be done in normal mode. */
464 if (data->pmu_sts.acc != BMI160_PMU_NORMAL) {
465 return -ENOTSUP;
466 }
467
468 /*
469 * Hardware calibration is done knowing the expected values on all axis.
470 */
471 if (chan != SENSOR_CHAN_ACCEL_XYZ) {
472 return -ENOTSUP;
473 }
474
475 for (i = 0; i < BMI160_AXES; i++, xyz_calib_value++) {
476 int32_t accel_g;
477 uint8_t accel_val;
478
479 accel_g = sensor_ms2_to_g(xyz_calib_value);
480 if (accel_g == 0) {
481 accel_val = 3U;
482 } else if (accel_g == 1) {
483 accel_val = 1U;
484 } else if (accel_g == -1) {
485 accel_val = 2U;
486 } else {
487 accel_val = 0U;
488 }
489 reg_val |= (accel_val << foc_pos[i]);
490 }
491
492 if (bmi160_do_calibration(dev, reg_val) < 0) {
493 return -EIO;
494 }
495
496 /* activate accel HW compensation */
497 return bmi160_reg_field_update(dev, BMI160_REG_OFFSET_EN,
498 BMI160_ACC_OFS_EN_POS,
499 BIT(BMI160_ACC_OFS_EN_POS), 1);
500 }
501
bmi160_acc_config(const struct device * dev,enum sensor_channel chan,enum sensor_attribute attr,const struct sensor_value * val)502 static int bmi160_acc_config(const struct device *dev,
503 enum sensor_channel chan,
504 enum sensor_attribute attr,
505 const struct sensor_value *val)
506 {
507 switch (attr) {
508 #if defined(CONFIG_BMI160_ACCEL_RANGE_RUNTIME)
509 case SENSOR_ATTR_FULL_SCALE:
510 return bmi160_acc_range_set(dev, val);
511 #endif
512 #if defined(CONFIG_BMI160_ACCEL_ODR_RUNTIME)
513 case SENSOR_ATTR_SAMPLING_FREQUENCY:
514 return bmi160_acc_odr_set(dev, val->val1, val->val2 / 1000);
515 #endif
516 case SENSOR_ATTR_OFFSET:
517 return bmi160_acc_ofs_set(dev, chan, val);
518 case SENSOR_ATTR_CALIB_TARGET:
519 return bmi160_acc_calibrate(dev, chan, val);
520 #if defined(CONFIG_BMI160_TRIGGER)
521 case SENSOR_ATTR_SLOPE_TH:
522 case SENSOR_ATTR_SLOPE_DUR:
523 return bmi160_acc_slope_config(dev, attr, val);
524 #endif
525 default:
526 LOG_DBG("Accel attribute not supported.");
527 return -ENOTSUP;
528 }
529
530 return 0;
531 }
532 #endif /* !defined(CONFIG_BMI160_ACCEL_PMU_SUSPEND) */
533
534 #if defined(CONFIG_BMI160_GYRO_ODR_RUNTIME)
bmi160_gyr_odr_set(const struct device * dev,uint16_t freq_int,uint16_t freq_milli)535 static int bmi160_gyr_odr_set(const struct device *dev, uint16_t freq_int,
536 uint16_t freq_milli)
537 {
538 int odr = bmi160_freq_to_odr_val(freq_int, freq_milli);
539
540 if (odr < 0) {
541 return odr;
542 }
543
544 if (odr < BMI160_ODR_25 || odr > BMI160_ODR_3200) {
545 return -ENOTSUP;
546 }
547
548 return bmi160_reg_field_update(dev, BMI160_REG_GYR_CONF,
549 BMI160_GYR_CONF_ODR_POS,
550 BMI160_GYR_CONF_ODR_MASK,
551 (uint8_t) odr);
552 }
553 #endif
554
555 #if defined(CONFIG_BMI160_GYRO_RANGE_RUNTIME)
bmi160_gyr_range_set(const struct device * dev,const struct sensor_value * val)556 static int bmi160_gyr_range_set(const struct device *dev, const struct sensor_value *val)
557 {
558 uint16_t range = sensor_rad_to_degrees(val);
559 struct bmi160_data *data = dev->data;
560 int32_t reg_val = bmi160_range_to_reg_val(range,
561 bmi160_gyr_range_map,
562 BMI160_GYR_RANGE_MAP_SIZE);
563
564 if (reg_val < 0) {
565 return reg_val;
566 }
567 switch (reg_val) {
568 case BMI160_GYR_RANGE_125DPS:
569 range = 125;
570 break;
571 case BMI160_GYR_RANGE_250DPS:
572 range = 250;
573 break;
574 case BMI160_GYR_RANGE_500DPS:
575 range = 500;
576 break;
577 case BMI160_GYR_RANGE_1000DPS:
578 range = 1000;
579 break;
580 case BMI160_GYR_RANGE_2000DPS:
581 range = 2000;
582 break;
583 }
584
585 if (bmi160_byte_write(dev, BMI160_REG_GYR_RANGE, reg_val) < 0) {
586 return -EIO;
587 }
588
589 data->scale.gyr_numerator = BMI160_GYR_SCALE_NUMERATOR(range);
590
591 return 0;
592 }
593 #endif
594
595 #if !defined(CONFIG_BMI160_GYRO_PMU_SUSPEND)
596 /*
597 * Gyro offset scale, taken from pg. 79, converted to micro rad/s:
598 * 0.061 * (pi / 180) * 1000000, where pi = 3.141592
599 */
600 #define BMI160_GYR_OFS_LSB 1065
bmi160_gyr_ofs_set(const struct device * dev,enum sensor_channel chan,const struct sensor_value * ofs)601 static int bmi160_gyr_ofs_set(const struct device *dev,
602 enum sensor_channel chan,
603 const struct sensor_value *ofs)
604 {
605 struct {
606 uint8_t lsb_addr;
607 uint8_t msb_pos;
608 } ofs_desc[] = {
609 {BMI160_REG_OFFSET_GYR_X, BMI160_GYR_MSB_OFS_X_POS},
610 {BMI160_REG_OFFSET_GYR_Y, BMI160_GYR_MSB_OFS_Y_POS},
611 {BMI160_REG_OFFSET_GYR_Z, BMI160_GYR_MSB_OFS_Z_POS},
612 };
613 int i;
614 int32_t ofs_u;
615 int16_t val;
616
617 /* we need the offsets for all axis */
618 if (chan != SENSOR_CHAN_GYRO_XYZ) {
619 return -ENOTSUP;
620 }
621
622 for (i = 0; i < BMI160_AXES; i++, ofs++) {
623 /* convert offset to micro rad/s */
624 ofs_u = ofs->val1 * 1000000ULL + ofs->val2;
625
626 val = CLAMP(ofs_u / BMI160_GYR_OFS_LSB, -512, 511);
627
628 /* write the LSB */
629 if (bmi160_byte_write(dev, ofs_desc[i].lsb_addr,
630 val & 0xff) < 0) {
631 return -EIO;
632 }
633
634 /* write the MSB */
635 if (bmi160_reg_field_update(dev, BMI160_REG_OFFSET_EN,
636 ofs_desc[i].msb_pos,
637 0x3 << ofs_desc[i].msb_pos,
638 (val >> 8) & 0x3) < 0) {
639 return -EIO;
640 }
641 }
642
643 /* activate gyro HW compensation */
644 return bmi160_reg_field_update(dev, BMI160_REG_OFFSET_EN,
645 BMI160_GYR_OFS_EN_POS,
646 BIT(BMI160_GYR_OFS_EN_POS), 1);
647 }
648
bmi160_gyr_calibrate(const struct device * dev,enum sensor_channel chan)649 static int bmi160_gyr_calibrate(const struct device *dev,
650 enum sensor_channel chan)
651 {
652 struct bmi160_data *data = dev->data;
653
654 ARG_UNUSED(chan);
655
656 /* Calibration has to be done in normal mode. */
657 if (data->pmu_sts.gyr != BMI160_PMU_NORMAL) {
658 return -ENOTSUP;
659 }
660
661 if (bmi160_do_calibration(dev, BIT(BMI160_FOC_GYR_EN_POS)) < 0) {
662 return -EIO;
663 }
664
665 /* activate gyro HW compensation */
666 return bmi160_reg_field_update(dev, BMI160_REG_OFFSET_EN,
667 BMI160_GYR_OFS_EN_POS,
668 BIT(BMI160_GYR_OFS_EN_POS), 1);
669 }
670
bmi160_gyr_config(const struct device * dev,enum sensor_channel chan,enum sensor_attribute attr,const struct sensor_value * val)671 static int bmi160_gyr_config(const struct device *dev,
672 enum sensor_channel chan,
673 enum sensor_attribute attr,
674 const struct sensor_value *val)
675 {
676 switch (attr) {
677 #if defined(CONFIG_BMI160_GYRO_RANGE_RUNTIME)
678 case SENSOR_ATTR_FULL_SCALE:
679 return bmi160_gyr_range_set(dev, val);
680 #endif
681 #if defined(CONFIG_BMI160_GYRO_ODR_RUNTIME)
682 case SENSOR_ATTR_SAMPLING_FREQUENCY:
683 return bmi160_gyr_odr_set(dev, val->val1, val->val2 / 1000);
684 #endif
685 case SENSOR_ATTR_OFFSET:
686 return bmi160_gyr_ofs_set(dev, chan, val);
687
688 case SENSOR_ATTR_CALIB_TARGET:
689 return bmi160_gyr_calibrate(dev, chan);
690
691 default:
692 LOG_DBG("Gyro attribute not supported.");
693 return -ENOTSUP;
694 }
695
696 return 0;
697 }
698 #endif /* !defined(CONFIG_BMI160_GYRO_PMU_SUSPEND) */
699
bmi160_attr_set(const struct device * dev,enum sensor_channel chan,enum sensor_attribute attr,const struct sensor_value * val)700 static int bmi160_attr_set(const struct device *dev, enum sensor_channel chan,
701 enum sensor_attribute attr,
702 const struct sensor_value *val)
703 {
704 switch (chan) {
705 #if !defined(CONFIG_BMI160_GYRO_PMU_SUSPEND)
706 case SENSOR_CHAN_GYRO_X:
707 case SENSOR_CHAN_GYRO_Y:
708 case SENSOR_CHAN_GYRO_Z:
709 case SENSOR_CHAN_GYRO_XYZ:
710 return bmi160_gyr_config(dev, chan, attr, val);
711 #endif
712 #if !defined(CONFIG_BMI160_ACCEL_PMU_SUSPEND)
713 case SENSOR_CHAN_ACCEL_X:
714 case SENSOR_CHAN_ACCEL_Y:
715 case SENSOR_CHAN_ACCEL_Z:
716 case SENSOR_CHAN_ACCEL_XYZ:
717 return bmi160_acc_config(dev, chan, attr, val);
718 #endif
719 default:
720 LOG_DBG("attr_set() not supported on this channel.");
721 return -ENOTSUP;
722 }
723
724 return 0;
725 }
726
bmi160_attr_get(const struct device * dev,enum sensor_channel chan,enum sensor_attribute attr,struct sensor_value * val)727 static int bmi160_attr_get(const struct device *dev, enum sensor_channel chan,
728 enum sensor_attribute attr, struct sensor_value *val)
729 {
730 int rc;
731
732 if (attr == SENSOR_ATTR_OFFSET) {
733 if (chan != SENSOR_CHAN_ACCEL_XYZ && chan != SENSOR_CHAN_GYRO_XYZ) {
734 return -EINVAL;
735 }
736
737 int8_t data[7];
738
739 rc = bmi160_read(dev, BMI160_REG_OFFSET_ACC_X, data, 7);
740 if (rc != 0) {
741 return rc;
742 }
743
744 if ((chan == SENSOR_CHAN_ACCEL_XYZ &&
745 FIELD_GET(BIT(BMI160_ACC_OFS_EN_POS), data[6]) == 0) ||
746 (chan == SENSOR_CHAN_GYRO_XYZ &&
747 FIELD_GET(BIT(BMI160_GYR_OFS_EN_POS), data[6]) == 0)) {
748 for (int i = 0; i < 3; ++i) {
749 val[i].val1 = 0;
750 val[i].val2 = 0;
751 }
752 } else {
753 for (int i = 0; i < 3; ++i) {
754 if (chan == SENSOR_CHAN_ACCEL_XYZ) {
755 int32_t ug = data[i] * INT32_C(3900);
756
757 sensor_ug_to_ms2(ug, &val[i]);
758 } else {
759 int32_t udeg =
760 (FIELD_GET(GENMASK((2 * i) + 1, 2 * i), data[6])
761 << 8) |
762 data[3 + i];
763
764 udeg |= 0 - (udeg & 0x200);
765 udeg *= 61000;
766 sensor_10udegrees_to_rad(udeg / 10, &val[i]);
767 }
768 }
769 }
770 return 0;
771 }
772 if (attr == SENSOR_ATTR_SAMPLING_FREQUENCY) {
773 if (chan == SENSOR_CHAN_ACCEL_XYZ) {
774 int64_t rate_uhz;
775 uint8_t acc_odr;
776
777 if (IS_ENABLED(CONFIG_BMI160_ACCEL_ODR_RUNTIME)) {
778 /* Read the register */
779 rc = bmi160_byte_read(dev, BMI160_REG_ACC_CONF, &acc_odr);
780 if (rc != 0) {
781 return rc;
782 }
783 acc_odr = FIELD_GET(BMI160_ACC_CONF_ODR_MASK, acc_odr);
784 } else {
785 acc_odr = BMI160_DEFAULT_ODR_ACC;
786 }
787
788 rate_uhz = INT64_C(100000000) * BIT(acc_odr) / 256;
789 val->val1 = rate_uhz / 1000000;
790 val->val2 = rate_uhz - val->val1 * 1000000;
791 return 0;
792 } else if (chan == SENSOR_CHAN_GYRO_XYZ) {
793 int64_t rate_uhz;
794 uint8_t gyr_ord;
795
796 if (IS_ENABLED(CONFIG_BMI160_GYRO_ODR_RUNTIME)) {
797 /* Read the register */
798 rc = bmi160_byte_read(dev, BMI160_REG_GYR_CONF, &gyr_ord);
799 if (rc != 0) {
800 return rc;
801 }
802 gyr_ord = FIELD_GET(BMI160_GYR_CONF_ODR_MASK, gyr_ord);
803 } else {
804 gyr_ord = BMI160_DEFAULT_ODR_GYR;
805 }
806
807 rate_uhz = INT64_C(100000000) * BIT(gyr_ord) / 256;
808 val->val1 = rate_uhz / 1000000;
809 val->val2 = rate_uhz - val->val1 * 1000000;
810 return 0;
811
812 }
813 return -EINVAL;
814
815 }
816 if (attr == SENSOR_ATTR_FULL_SCALE) {
817 if (chan == SENSOR_CHAN_ACCEL_XYZ) {
818 uint8_t acc_range;
819
820 if (IS_ENABLED(CONFIG_BMI160_ACCEL_RANGE_RUNTIME)) {
821 rc = bmi160_byte_read(dev, BMI160_REG_ACC_RANGE, &acc_range);
822 if (rc != 0) {
823 return rc;
824 }
825 } else {
826 acc_range = BMI160_DEFAULT_RANGE_ACC;
827 }
828 sensor_g_to_ms2(bmi160_acc_reg_val_to_range(acc_range), val);
829 return 0;
830 } else if (chan == SENSOR_CHAN_GYRO_XYZ) {
831 uint8_t gyr_range;
832
833 if (IS_ENABLED(CONFIG_BMI160_GYRO_RANGE_RUNTIME)) {
834 rc = bmi160_byte_read(dev, BMI160_REG_GYR_RANGE, &gyr_range);
835 if (rc != 0) {
836 return rc;
837 }
838 } else {
839 gyr_range = BMI160_DEFAULT_RANGE_GYR;
840 }
841 sensor_degrees_to_rad(bmi160_gyr_reg_val_to_range(gyr_range), val);
842 return 0;
843 }
844 return -EINVAL;
845 }
846 return -EINVAL;
847 }
848
bmi160_sample_fetch(const struct device * dev,enum sensor_channel chan)849 static int bmi160_sample_fetch(const struct device *dev,
850 enum sensor_channel chan)
851 {
852 struct bmi160_data *data = dev->data;
853 uint8_t status;
854 size_t i;
855 int ret = 0;
856 enum pm_device_state pm_state;
857
858 (void)pm_device_state_get(dev, &pm_state);
859 if (pm_state != PM_DEVICE_STATE_ACTIVE) {
860 LOG_DBG("Device is suspended, fetch is unavailable");
861 ret = -EIO;
862 goto out;
863 }
864
865 if (chan == SENSOR_CHAN_DIE_TEMP) {
866 /* Die temperature is only valid when at least one measurement is active */
867 if (data->pmu_sts.raw == 0U) {
868 return -EINVAL;
869 }
870 return bmi160_word_read(dev, BMI160_REG_TEMPERATURE0, &data->sample.temperature);
871 }
872
873 __ASSERT_NO_MSG(chan == SENSOR_CHAN_ALL);
874
875 status = 0;
876 while ((status & BMI160_DATA_READY_BIT_MASK) == 0) {
877
878 if (bmi160_byte_read(dev, BMI160_REG_STATUS, &status) < 0) {
879 ret = -EIO;
880 goto out;
881 }
882 }
883
884 if (bmi160_read(dev, BMI160_SAMPLE_BURST_READ_ADDR, data->sample.raw,
885 BMI160_BUF_SIZE) < 0) {
886 ret = -EIO;
887 goto out;
888 }
889
890 /* convert samples to cpu endianness */
891 for (i = 0; i < BMI160_SAMPLE_SIZE; i += 2) {
892 uint16_t *sample =
893 (uint16_t *) &data->sample.raw[i];
894
895 *sample = sys_le16_to_cpu(*sample);
896 }
897
898 out:
899 return ret;
900 }
901
bmi160_to_fixed_point(int16_t raw_val,int64_t scale_numerator,uint32_t scale_denominator,struct sensor_value * val)902 static void bmi160_to_fixed_point(int16_t raw_val, int64_t scale_numerator,
903 uint32_t scale_denominator, struct sensor_value *val)
904 {
905 int64_t converted_val = (int64_t)raw_val * scale_numerator / scale_denominator;
906
907 val->val1 = converted_val / 1000000;
908 val->val2 = converted_val % 1000000;
909 }
910
bmi160_channel_convert(enum sensor_channel chan,int64_t scale_numerator,uint32_t scale_denominator,uint16_t * raw_xyz,struct sensor_value * val)911 static void bmi160_channel_convert(enum sensor_channel chan,
912 int64_t scale_numerator,
913 uint32_t scale_denominator,
914 uint16_t *raw_xyz,
915 struct sensor_value *val)
916 {
917 int i;
918 uint8_t ofs_start, ofs_stop;
919
920 switch (chan) {
921 case SENSOR_CHAN_ACCEL_X:
922 case SENSOR_CHAN_GYRO_X:
923 ofs_start = ofs_stop = 0U;
924 break;
925 case SENSOR_CHAN_ACCEL_Y:
926 case SENSOR_CHAN_GYRO_Y:
927 ofs_start = ofs_stop = 1U;
928 break;
929 case SENSOR_CHAN_ACCEL_Z:
930 case SENSOR_CHAN_GYRO_Z:
931 ofs_start = ofs_stop = 2U;
932 break;
933 default:
934 ofs_start = 0U; ofs_stop = 2U;
935 break;
936 }
937
938 for (i = ofs_start; i <= ofs_stop ; i++, val++) {
939 bmi160_to_fixed_point(raw_xyz[i], scale_numerator, scale_denominator, val);
940 }
941 }
942
943 #if !defined(CONFIG_BMI160_GYRO_PMU_SUSPEND)
bmi160_gyr_channel_get(const struct device * dev,enum sensor_channel chan,struct sensor_value * val)944 static inline void bmi160_gyr_channel_get(const struct device *dev,
945 enum sensor_channel chan,
946 struct sensor_value *val)
947 {
948 struct bmi160_data *data = dev->data;
949
950 bmi160_channel_convert(chan, data->scale.gyr_numerator, BMI160_GYR_SCALE_DENOMINATOR,
951 data->sample.gyr, val);
952 }
953 #endif
954
955 #if !defined(CONFIG_BMI160_ACCEL_PMU_SUSPEND)
bmi160_acc_channel_get(const struct device * dev,enum sensor_channel chan,struct sensor_value * val)956 static inline void bmi160_acc_channel_get(const struct device *dev,
957 enum sensor_channel chan,
958 struct sensor_value *val)
959 {
960 struct bmi160_data *data = dev->data;
961
962 bmi160_channel_convert(chan, data->scale.acc_numerator, BMI160_ACC_SCALE_DENOMINATOR,
963 data->sample.acc, val);
964 }
965 #endif
966
bmi160_temp_channel_get(const struct device * dev,struct sensor_value * val)967 static int bmi160_temp_channel_get(const struct device *dev,
968 struct sensor_value *val)
969 {
970 struct bmi160_data *data = dev->data;
971
972 /* the scale is 1/2^9/LSB = 1953 micro degrees */
973 int32_t temp_micro = BMI160_TEMP_OFFSET * 1000000ULL + data->sample.temperature * 1953ULL;
974
975 val->val1 = temp_micro / 1000000ULL;
976 val->val2 = temp_micro % 1000000ULL;
977
978 return 0;
979 }
980
bmi160_channel_get(const struct device * dev,enum sensor_channel chan,struct sensor_value * val)981 static int bmi160_channel_get(const struct device *dev,
982 enum sensor_channel chan,
983 struct sensor_value *val)
984 {
985 switch (chan) {
986 #if !defined(CONFIG_BMI160_GYRO_PMU_SUSPEND)
987 case SENSOR_CHAN_GYRO_X:
988 case SENSOR_CHAN_GYRO_Y:
989 case SENSOR_CHAN_GYRO_Z:
990 case SENSOR_CHAN_GYRO_XYZ:
991 bmi160_gyr_channel_get(dev, chan, val);
992 return 0;
993 #endif
994 #if !defined(CONFIG_BMI160_ACCEL_PMU_SUSPEND)
995 case SENSOR_CHAN_ACCEL_X:
996 case SENSOR_CHAN_ACCEL_Y:
997 case SENSOR_CHAN_ACCEL_Z:
998 case SENSOR_CHAN_ACCEL_XYZ:
999 bmi160_acc_channel_get(dev, chan, val);
1000 return 0;
1001 #endif
1002 case SENSOR_CHAN_DIE_TEMP:
1003 return bmi160_temp_channel_get(dev, val);
1004 default:
1005 LOG_DBG("Channel not supported.");
1006 return -ENOTSUP;
1007 }
1008
1009 return 0;
1010 }
1011
1012 static DEVICE_API(sensor, bmi160_api) = {
1013 .attr_set = bmi160_attr_set,
1014 .attr_get = bmi160_attr_get,
1015 #ifdef CONFIG_BMI160_TRIGGER
1016 .trigger_set = bmi160_trigger_set,
1017 #endif
1018 .sample_fetch = bmi160_sample_fetch,
1019 .channel_get = bmi160_channel_get,
1020 };
1021
1022
bmi160_resume(const struct device * dev)1023 static inline int bmi160_resume(const struct device *dev)
1024 {
1025 struct bmi160_data *data = dev->data;
1026
1027 return bmi160_pmu_set(dev, &data->pmu_sts);
1028 }
1029
bmi160_suspend(const struct device * dev)1030 static inline int bmi160_suspend(const struct device *dev)
1031 {
1032 struct bmi160_data *data = dev->data;
1033
1034 /* Suspend everything */
1035 union bmi160_pmu_status st = {
1036 .acc = BMI160_PMU_SUSPEND,
1037 .gyr = BMI160_PMU_SUSPEND,
1038 .mag = BMI160_PMU_SUSPEND,
1039 };
1040
1041 int ret = bmi160_pmu_set(dev, &st);
1042
1043 if (ret == 0) {
1044 memset(data->sample.raw, 0, sizeof(data->sample.raw));
1045 }
1046 return ret;
1047 }
1048
bmi160_init(const struct device * dev)1049 int bmi160_init(const struct device *dev)
1050 {
1051 const struct bmi160_cfg *cfg = dev->config;
1052 struct bmi160_data *data = dev->data;
1053 uint8_t val = 0U;
1054 int32_t acc_range, gyr_range;
1055
1056 if (!cfg->bus_io->ready(dev)) {
1057 LOG_ERR("Bus not ready");
1058 return -EINVAL;
1059 }
1060
1061 /* reboot the chip */
1062 if (bmi160_byte_write(dev, BMI160_REG_CMD, BMI160_CMD_SOFT_RESET) < 0) {
1063 LOG_DBG("Cannot reboot chip.");
1064 return -EIO;
1065 }
1066
1067 k_busy_wait(1000);
1068
1069 /* do a dummy read from 0x7F to activate SPI */
1070 if (bmi160_byte_read(dev, BMI160_SPI_START, &val) < 0) {
1071 LOG_DBG("Cannot read from 0x7F..");
1072 return -EIO;
1073 }
1074
1075 k_busy_wait(150);
1076
1077 if (bmi160_byte_read(dev, BMI160_REG_CHIPID, &val) < 0) {
1078 LOG_DBG("Failed to read chip id.");
1079 return -EIO;
1080 }
1081
1082 if (val != BMI160_CHIP_ID) {
1083 LOG_DBG("Unsupported chip detected (0x%x)!", val);
1084 return -ENODEV;
1085 }
1086
1087 /* set default PMU for gyro, accelerometer */
1088 data->pmu_sts.gyr = BMI160_DEFAULT_PMU_GYR;
1089 data->pmu_sts.acc = BMI160_DEFAULT_PMU_ACC;
1090
1091 /* compass not supported, yet */
1092 data->pmu_sts.mag = BMI160_PMU_SUSPEND;
1093
1094 /* Start in a suspended state (never turning on the mems sensors) if
1095 * PM_DEVICE_RUNTIME is enabled.
1096 */
1097 #ifdef CONFIG_PM_DEVICE_RUNTIME
1098 pm_device_init_suspended(dev);
1099
1100 int ret = pm_device_runtime_enable(dev);
1101
1102 if (ret < 0 && ret != -ENOSYS) {
1103 LOG_ERR("Failed to enabled runtime power management");
1104 return -EIO;
1105 }
1106 #else
1107
1108 /*
1109 * The next command will take around 100ms (contains some necessary busy
1110 * waits), but we cannot do it in a separate thread since we need to
1111 * guarantee the BMI is up and running, before the app's main() is
1112 * called.
1113 */
1114 if (bmi160_pmu_set(dev, &data->pmu_sts) < 0) {
1115 LOG_DBG("Failed to set power mode.");
1116 return -EIO;
1117 }
1118 #endif
1119
1120 /* set accelerometer default range */
1121 if (bmi160_byte_write(dev, BMI160_REG_ACC_RANGE,
1122 BMI160_DEFAULT_RANGE_ACC) < 0) {
1123 LOG_DBG("Cannot set default range for accelerometer.");
1124 return -EIO;
1125 }
1126
1127 acc_range = bmi160_acc_reg_val_to_range(BMI160_DEFAULT_RANGE_ACC);
1128
1129 data->scale.acc_numerator = BMI160_ACC_SCALE_NUMERATOR(acc_range);
1130
1131 /* set gyro default range */
1132 if (bmi160_byte_write(dev, BMI160_REG_GYR_RANGE,
1133 BMI160_DEFAULT_RANGE_GYR) < 0) {
1134 LOG_DBG("Cannot set default range for gyroscope.");
1135 return -EIO;
1136 }
1137
1138 gyr_range = bmi160_gyr_reg_val_to_range(BMI160_DEFAULT_RANGE_GYR);
1139
1140 data->scale.gyr_numerator = BMI160_GYR_SCALE_NUMERATOR(gyr_range);
1141
1142 if (bmi160_reg_field_update(dev, BMI160_REG_ACC_CONF,
1143 BMI160_ACC_CONF_ODR_POS,
1144 BMI160_ACC_CONF_ODR_MASK,
1145 BMI160_DEFAULT_ODR_ACC) < 0) {
1146 LOG_DBG("Failed to set accel's default ODR.");
1147 return -EIO;
1148 }
1149
1150 if (bmi160_reg_field_update(dev, BMI160_REG_GYR_CONF,
1151 BMI160_GYR_CONF_ODR_POS,
1152 BMI160_GYR_CONF_ODR_MASK,
1153 BMI160_DEFAULT_ODR_GYR) < 0) {
1154 LOG_DBG("Failed to set gyro's default ODR.");
1155 return -EIO;
1156 }
1157
1158 #ifdef CONFIG_BMI160_TRIGGER
1159 if (bmi160_trigger_mode_init(dev) < 0) {
1160 LOG_DBG("Cannot set up trigger mode.");
1161 return -EINVAL;
1162 }
1163 #endif
1164
1165 return 0;
1166 }
1167
bmi160_pm(const struct device * dev,enum pm_device_action action)1168 int bmi160_pm(const struct device *dev, enum pm_device_action action)
1169 {
1170 int ret = 0;
1171
1172 switch (action) {
1173 case PM_DEVICE_ACTION_RESUME:
1174 bmi160_resume(dev);
1175 break;
1176 case PM_DEVICE_ACTION_SUSPEND:
1177 bmi160_suspend(dev);
1178 break;
1179 default:
1180 ret = -ENOTSUP;
1181 }
1182
1183 return ret;
1184 }
1185
1186 #if defined(CONFIG_BMI160_TRIGGER)
1187 #define BMI160_TRIGGER_CFG(inst) \
1188 .interrupt = GPIO_DT_SPEC_INST_GET(inst, int_gpios),
1189 #else
1190 #define BMI160_TRIGGER_CFG(inst)
1191 #endif
1192
1193 #define BMI160_DEVICE_INIT(inst) \
1194 IF_ENABLED(CONFIG_PM_DEVICE_RUNTIME, (PM_DEVICE_DT_INST_DEFINE(inst, bmi160_pm))); \
1195 SENSOR_DEVICE_DT_INST_DEFINE(inst, bmi160_init, \
1196 COND_CODE_1(CONFIG_PM_DEVICE_RUNTIME, (PM_DEVICE_DT_INST_GET(inst)), (NULL)), \
1197 &bmi160_data_##inst, &bmi160_cfg_##inst, \
1198 POST_KERNEL, CONFIG_SENSOR_INIT_PRIORITY, \
1199 &bmi160_api);
1200
1201 /* Instantiation macros used when a device is on a SPI bus */
1202 #define BMI160_DEFINE_SPI(inst) \
1203 static struct bmi160_data bmi160_data_##inst; \
1204 static const struct bmi160_cfg bmi160_cfg_##inst = { \
1205 .bus.spi = SPI_DT_SPEC_INST_GET(inst, SPI_WORD_SET(8), 0), \
1206 .bus_io = &bmi160_bus_io_spi, \
1207 BMI160_TRIGGER_CFG(inst) \
1208 }; \
1209 BMI160_DEVICE_INIT(inst)
1210
1211 /* Instantiation macros used when a device is on an I2C bus */
1212 #define BMI160_CONFIG_I2C(inst) \
1213 { \
1214 .bus.i2c = I2C_DT_SPEC_INST_GET(inst), \
1215 .bus_io = &bmi160_bus_io_i2c, \
1216 BMI160_TRIGGER_CFG(inst) \
1217 }
1218
1219 #define BMI160_DEFINE_I2C(inst) \
1220 static struct bmi160_data bmi160_data_##inst; \
1221 static const struct bmi160_cfg bmi160_cfg_##inst = BMI160_CONFIG_I2C(inst); \
1222 BMI160_DEVICE_INIT(inst)
1223
1224 /*
1225 * Main instantiation macro. Use of COND_CODE_1() selects the right
1226 * bus-specific macro at preprocessor time.
1227 */
1228 #define BMI160_DEFINE(inst) \
1229 COND_CODE_1(DT_INST_ON_BUS(inst, spi), \
1230 (BMI160_DEFINE_SPI(inst)), \
1231 (BMI160_DEFINE_I2C(inst)))
1232
1233 DT_INST_FOREACH_STATUS_OKAY(BMI160_DEFINE)
1234