summaryrefslogtreecommitdiff
path: root/src/driver/mpu9250.cc
diff options
context:
space:
mode:
authorDaniel Friesel <derf@finalrewind.org>2021-12-11 17:23:12 +0100
committerDaniel Friesel <derf@finalrewind.org>2021-12-11 17:23:12 +0100
commit32c669a38d7f7d50836ee5ca8ba9d5d574e19eee (patch)
treee0340bff3d59d6faba073c8f01b1b5e83af8eeaf /src/driver/mpu9250.cc
parent182a42b89c5eb2373a3725a7aea197e6b6d66523 (diff)
mpu9250: fix casting / sign extension on 32bit systems
Diffstat (limited to 'src/driver/mpu9250.cc')
-rw-r--r--src/driver/mpu9250.cc21
1 files changed, 11 insertions, 10 deletions
diff --git a/src/driver/mpu9250.cc b/src/driver/mpu9250.cc
index bef086f..de47597 100644
--- a/src/driver/mpu9250.cc
+++ b/src/driver/mpu9250.cc
@@ -5,6 +5,7 @@
#else
#include "driver/soft_i2c.h"
#endif
+#include <stdint.h>
/*
Copyright (c) 2016 SparkFun Electronics, Inc.
@@ -143,7 +144,7 @@ signed int MPU9250::getWordReg(unsigned char const regBase)
txbuf[0] = regBase;
i2c.xmit(address, 1, txbuf, 2, rxbuf);
- return ((signed int)rxbuf[0] << 8) + rxbuf[1];
+ return (int16_t)((rxbuf[0] << 8) + rxbuf[1]);
}
float MPU9250::getTemperature()
@@ -156,9 +157,9 @@ void MPU9250::getRawGyro(int *x, int *y, int *z)
txbuf[0] = 67;
i2c.xmit(address, 1, txbuf, 6, rxbuf);
- *x = ((signed int) rxbuf[0] << 8) + rxbuf[1];
- *y = ((signed int) rxbuf[2] << 8) + rxbuf[3];
- *z = ((signed int) rxbuf[4] << 8) + rxbuf[5];
+ *x = (int16_t)(( rxbuf[0] << 8) + rxbuf[1]);
+ *y = (int16_t)(( rxbuf[2] << 8) + rxbuf[3]);
+ *z = (int16_t)(( rxbuf[4] << 8) + rxbuf[5]);
}
void MPU9250::getRawAccel(int *x, int *y, int *z)
@@ -166,9 +167,9 @@ void MPU9250::getRawAccel(int *x, int *y, int *z)
txbuf[0] = 59;
i2c.xmit(address, 1, txbuf, 6, rxbuf);
- *x = ((signed int) rxbuf[0] << 8) + rxbuf[1];
- *y = ((signed int) rxbuf[2] << 8) + rxbuf[3];
- *z = ((signed int) rxbuf[4] << 8) + rxbuf[5];
+ *x = (int16_t)(( rxbuf[0] << 8) + rxbuf[1]);
+ *y = (int16_t)(( rxbuf[2] << 8) + rxbuf[3]);
+ *z = (int16_t)(( rxbuf[4] << 8) + rxbuf[5]);
}
void MPU9250::getAccel(float *g_x, float *g_y, float *g_z)
@@ -211,9 +212,9 @@ bool MPU9250::getRawMagnet(int *x, int *y, int *z)
i2c.xmit(0x0c, 1, txbuf, 8, rxbuf);
if ((rxbuf[0] & 0x01) && !(rxbuf[7] & 0x08)) {
- *x = ((signed int)rxbuf[2] << 8) + rxbuf[1];
- *y = ((signed int)rxbuf[4] << 8) + rxbuf[3];
- *z = ((signed int)rxbuf[6] << 8) + rxbuf[5];
+ *x = (int16_t)((rxbuf[2] << 8) + rxbuf[1]);
+ *y = (int16_t)((rxbuf[4] << 8) + rxbuf[3]);
+ *z = (int16_t)((rxbuf[6] << 8) + rxbuf[5]);
return true;
}
else {