49 #if (LSM6DS0_USE_I2C) || defined(__DOXYGEN__)
64 uint8_t* rxbuf,
size_t n) {
66 return i2cMasterTransmitTimeout(i2cp, sad, ®, 1, rxbuf, n,
83 #define lsm6ds0I2CWriteRegister(i2cp, sad, txbuf, n) \
84 i2cMasterTransmitTimeout(i2cp, sad, txbuf, n + 1, NULL, 0, \
123 osalDbgCheck((ip != NULL) && (axes != NULL));
129 "acc_read_raw(), invalid state");
131 osalDbgAssert((devp->config->i2cp->state == I2C_READY),
132 "acc_read_raw(), channel not ready");
134 #if LSM6DS0_SHARED_I2C
135 i2cAcquireBus(devp->config->i2cp);
136 i2cStart(devp->config->i2cp,
137 devp->config->i2ccfg);
141 LSM6DS0_AD_OUT_X_L_XL, buff,
144 #if LSM6DS0_SHARED_I2C
145 i2cReleaseBus(devp->config->i2cp);
150 tmp = buff[2 * i] + (buff[2 * i + 1] << 8);
151 axes[i] = (int32_t)tmp;
179 osalDbgCheck((ip != NULL) && (axes != NULL));
185 "acc_read_cooked(), invalid state");
189 axes[i] = (raw[i] * devp->accsensitivity[i]) - devp->accbias[i];
211 osalDbgCheck((ip != NULL) && (bp != NULL));
217 "acc_set_bias(), invalid state");
220 devp->accbias[i] = bp[i];
240 osalDbgCheck(ip != NULL);
246 "acc_reset_bias(), invalid state");
249 devp->accbias[i] = LSM6DS0_ACC_BIAS;
273 osalDbgCheck((ip != NULL) && (sp != NULL));
276 "acc_set_sensivity(), invalid state");
279 devp->accsensitivity[i] = sp[i];
299 osalDbgCheck(ip != NULL);
305 "acc_reset_sensivity(), invalid state");
309 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_2G;
312 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_4G;
315 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_8G;
318 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_16G;
320 osalDbgAssert(FALSE,
"reset_sensivity(), accelerometer full scale issue");
344 osalDbgCheck(devp != NULL);
347 "acc_set_full_scale(), invalid state");
348 osalDbgAssert((devp->config->i2cp->state == I2C_READY),
349 "acc_set_full_scale(), channel not ready");
353 newfs = LSM6DS0_ACC_2G;
356 newfs = LSM6DS0_ACC_4G;
359 newfs = LSM6DS0_ACC_8G;
362 newfs = LSM6DS0_ACC_16G;
369 if(newfs != devp->accfullscale) {
371 scale = newfs / devp->accfullscale;
372 devp->accfullscale = newfs;
374 #if LSM6DS0_SHARED_I2C
375 i2cAcquireBus(devp->config->i2cp);
376 i2cStart(devp->config->i2cp,
377 devp->config->i2ccfg);
382 devp->config->slaveaddress,
383 LSM6DS0_AD_CTRL_REG6_XL, &buff[1], 1);
385 #if LSM6DS0_SHARED_I2C
386 i2cReleaseBus(devp->config->i2cp);
392 buff[1] &= ~(LSM6DS0_CTRL_REG6_XL_FS_MASK);
394 buff[0] = LSM6DS0_AD_CTRL_REG6_XL;
396 #if LSM6DS0_SHARED_I2C
397 i2cAcquireBus(devp->config->i2cp);
398 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
402 devp->config->slaveaddress, buff, 1);
404 #if LSM6DS0_SHARED_I2C
405 i2cReleaseBus(devp->config->i2cp);
413 devp->accsensitivity[i] *= scale;
414 devp->accbias[i] *= scale;
455 osalDbgCheck((ip != NULL) && (axes != NULL));
461 "gyro_read_raw(), invalid state");
463 osalDbgAssert((devp->config->i2cp->state == I2C_READY),
464 "gyro_read_raw(), channel not ready");
466 #if LSM6DS0_SHARED_I2C
467 i2cAcquireBus(devp->config->i2cp);
468 i2cStart(devp->config->i2cp,
469 devp->config->i2ccfg);
473 LSM6DS0_AD_OUT_X_L_G, buff,
476 #if LSM6DS0_SHARED_I2C
477 i2cReleaseBus(devp->config->i2cp);
482 tmp = buff[2 * i] + (buff[2 * i + 1] << 8);
483 axes[i] = (int32_t)tmp;
511 osalDbgCheck((ip != NULL) && (axes != NULL));
517 "gyro_read_cooked(), invalid state");
521 axes[i] = (raw[i] * devp->gyrosensitivity[i]) - devp->gyrobias[i];
545 osalDbgCheck(ip != NULL);
551 "gyro_sample_bias(), invalid state");
553 osalDbgAssert((devp->config->i2cp->state == I2C_READY),
554 "gyro_sample_bias(), channel not ready");
569 devp->gyrobias[i] *= devp->gyrosensitivity[i];
591 osalDbgCheck((ip != NULL) && (bp != NULL));
597 "gyro_set_bias(), invalid state");
600 devp->gyrobias[i] = bp[i];
620 osalDbgCheck(ip != NULL);
626 "gyro_reset_bias(), invalid state");
629 devp->gyrobias[i] = LSM6DS0_GYRO_BIAS;
650 osalDbgCheck((ip != NULL) && (sp !=NULL));
656 "gyro_set_sensivity(), invalid state");
659 devp->gyrosensitivity[i] = sp[i];
679 osalDbgCheck(ip != NULL);
685 "gyro_reset_sensivity(), invalid state");
689 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_245DPS;
692 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_500DPS;
695 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_2000DPS;
697 osalDbgAssert(FALSE,
"gyro_reset_sensivity(), full scale issue");
721 osalDbgCheck(devp != NULL);
724 "gyro_set_full_scale(), invalid state");
726 osalDbgAssert((devp->config->i2cp->state == I2C_READY),
727 "gyro_set_full_scale(), channel not ready");
731 newfs = LSM6DS0_GYRO_245DPS;
734 newfs = LSM6DS0_GYRO_500DPS;
737 newfs = LSM6DS0_GYRO_2000DPS;
743 if(newfs != devp->gyrofullscale) {
744 scale = newfs / devp->gyrofullscale;
745 devp->gyrofullscale = newfs;
748 #if LSM6DS0_SHARED_I2C
749 i2cAcquireBus(devp->config->i2cp);
750 i2cStart(devp->config->i2cp,
751 devp->config->i2ccfg);
756 devp->config->slaveaddress,
757 LSM6DS0_AD_CTRL_REG1_G, &buff[1], 1);
759 #if LSM6DS0_SHARED_I2C
760 i2cReleaseBus(devp->config->i2cp);
764 buff[1] &= ~(LSM6DS0_CTRL_REG1_G_FS_MASK);
766 buff[0] = LSM6DS0_AD_CTRL_REG1_G;
769 #if LSM6DS0_SHARED_I2C
770 i2cAcquireBus(devp->config->i2cp);
771 i2cStart(devp->config->i2cp,
772 devp->config->i2ccfg);
778 #if LSM6DS0_SHARED_I2C
779 i2cReleaseBus(devp->config->i2cp);
785 devp->gyrosensitivity[i] *= scale;
786 devp->gyrobias[i] *= scale;
822 devp->
vmt = &vmt_device;
845 osalDbgCheck((devp != NULL) && (config != NULL));
849 "lsm6ds0Start(), invalid state");
851 devp->config = config;
857 cr[0] = LSM6DS0_AD_CTRL_REG8;
858 cr[1] = LSM6DS0_CTRL_REG8_IF_ADD_INC;
859 #if LSM6DS0_USE_ADVANCED || defined(__DOXYGEN__)
860 cr[1] |= devp->config->endianness | devp->config->blockdataupdate;
864 #if LSM6DS0_SHARED_I2C
865 i2cAcquireBus(devp->config->i2cp);
868 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
872 #if LSM6DS0_SHARED_I2C
873 i2cReleaseBus(devp->config->i2cp);
879 cr[0] = LSM6DS0_AD_CTRL_REG5_XL;
882 cr[1] = LSM6DS0_CTRL_REG5_XL_XEN_XL | LSM6DS0_CTRL_REG5_XL_YEN_XL |
883 LSM6DS0_CTRL_REG5_XL_ZEN_XL;
884 #if LSM6DS0_USE_ADVANCED || defined(__DOXYGEN__)
885 cr[1] |= devp->config->accdecmode;
891 cr[2] = devp->config->accoutdatarate |
892 devp->config->accfullscale;
896 #if LSM6DS0_SHARED_I2C
897 i2cAcquireBus(devp->config->i2cp);
898 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
904 #if LSM6DS0_SHARED_I2C
905 i2cReleaseBus(devp->config->i2cp);
912 if(devp->config->accsensitivity == NULL)
913 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_2G;
915 devp->accsensitivity[i] = devp->config->accsensitivity[i];
917 devp->accfullscale = LSM6DS0_ACC_2G;
921 if(devp->config->accsensitivity == NULL)
922 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_4G;
924 devp->accsensitivity[i] = devp->config->accsensitivity[i];
926 devp->accfullscale = LSM6DS0_ACC_4G;
930 if(devp->config->accsensitivity == NULL)
931 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_8G;
933 devp->accsensitivity[i] = devp->config->accsensitivity[i];
935 devp->accfullscale = LSM6DS0_ACC_8G;
939 if(devp->config->accsensitivity == NULL)
940 devp->accsensitivity[i] = LSM6DS0_ACC_SENS_16G;
942 devp->accsensitivity[i] = devp->config->accsensitivity[i];
944 devp->accfullscale = LSM6DS0_ACC_16G;
947 osalDbgAssert(FALSE,
"lsm6ds0Start(), accelerometer full scale issue");
950 if(devp->config->accbias != NULL)
952 devp->accbias[i] = devp->config->accbias[i];
955 devp->accbias[i] = LSM6DS0_ACC_BIAS;
959 cr[0] = LSM6DS0_AD_CTRL_REG1_G;
963 cr[1] = devp->config->gyrofullscale |
964 devp->config->gyrooutdatarate;
970 #if LSM6DS0_USE_ADVANCED || defined(__DOXYGEN__)
971 cr[2] |= devp->config->gyrooutsel;
978 #if LSM6DS0_USE_ADVANCED || defined(__DOXYGEN__)
979 cr[3] |= devp->config->gyrohpfenable |
980 devp->config->gyrolowmodecfg |
981 devp->config->gyrohpcfg;
987 cr[4] = LSM6DS0_CTRL_REG4_XEN_G | LSM6DS0_CTRL_REG4_YEN_G |
988 LSM6DS0_CTRL_REG4_ZEN_G;
991 #if LSM6DS0_SHARED_I2C
992 i2cAcquireBus(devp->config->i2cp);
993 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
999 #if LSM6DS0_SHARED_I2C
1000 i2cReleaseBus(devp->config->i2cp);
1004 cr[0] = LSM6DS0_AD_CTRL_REG9;
1010 #if LSM6DS0_SHARED_I2C
1011 i2cAcquireBus(devp->config->i2cp);
1012 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
1018 #if LSM6DS0_SHARED_I2C
1019 i2cReleaseBus(devp->config->i2cp);
1025 if(devp->config->gyrosensitivity == NULL)
1026 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_245DPS;
1028 devp->gyrosensitivity[i] = devp->config->gyrosensitivity[i];
1030 devp->gyrofullscale = LSM6DS0_GYRO_245DPS;
1034 if(devp->config->gyrosensitivity == NULL)
1035 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_500DPS;
1037 devp->gyrosensitivity[i] = devp->config->gyrosensitivity[i];
1039 devp->gyrofullscale = LSM6DS0_GYRO_500DPS;
1043 if(devp->config->gyrosensitivity == NULL)
1044 devp->gyrosensitivity[i] = LSM6DS0_GYRO_SENS_2000DPS;
1046 devp->gyrosensitivity[i] = devp->config->gyrosensitivity[i];
1048 devp->gyrofullscale = LSM6DS0_GYRO_2000DPS;
1051 osalDbgAssert(FALSE,
"lsm6ds0Start(), gyroscope full scale issue");
1054 if(devp->config->gyrobias != NULL)
1056 devp->gyrobias[i] = devp->config->gyrobias[i];
1059 devp->gyrobias[i] = LSM6DS0_GYRO_BIAS;
1062 osalThreadSleepMilliseconds(5);
1077 osalDbgCheck(devp != NULL);
1080 "lsm6ds0Stop(), invalid state");
1084 #if LSM6DS0_SHARED_I2C
1085 i2cAcquireBus(devp->config->i2cp);
1086 i2cStart(devp->config->i2cp, devp->config->i2ccfg);
1090 cr[0] = LSM6DS0_AD_CTRL_REG6_XL;
1096 cr[0] = LSM6DS0_AD_CTRL_REG9;
1097 cr[1] = LSM6DS0_CTRL_REG9_SLEEP_G;
1101 i2cStop(devp->config->i2cp);
1102 #if LSM6DS0_SHARED_I2C
1103 i2cReleaseBus(devp->config->i2cp);