mirror of
https://github.com/meshtastic/firmware.git
synced 2025-09-07 12:09:31 +00:00

* First addition of __has_include for sensor support * Add __has_include blocks for sensors * Put BMP and BME back in the right sensors * Make TelemetrySensor::setup() a pure virtual finction * Split environmental_base to environmental_extra, to compile the working sensor libs for Native * Remove hard-coded checks for ARCH_PORTDUINO * Un-clobber bmx160 * Move BusIO to environmental_extra due to Armv7 compile error * Move to forked BusIO for the moment * Enable HAS_SENSOR for Portduino * Move back to Adafruit BusIO after patch
31 lines
918 B
C++
Executable File
31 lines
918 B
C++
Executable File
#include "MPU6050Sensor.h"
|
|
|
|
#if !defined(ARCH_STM32WL) && !MESHTASTIC_EXCLUDE_I2C && __has_include(<Adafruit_MPU6050.h>)
|
|
|
|
MPU6050Sensor::MPU6050Sensor(ScanI2C::FoundDevice foundDevice) : MotionSensor::MotionSensor(foundDevice) {}
|
|
|
|
bool MPU6050Sensor::init()
|
|
{
|
|
if (sensor.begin(deviceAddress())) {
|
|
// setup motion detection
|
|
sensor.setHighPassFilter(MPU6050_HIGHPASS_0_63_HZ);
|
|
sensor.setMotionDetectionThreshold(1);
|
|
sensor.setMotionDetectionDuration(20);
|
|
sensor.setInterruptPinLatch(true); // Keep it latched. Will turn off when reinitialized.
|
|
sensor.setInterruptPinPolarity(true);
|
|
LOG_DEBUG("MPU6050 init ok");
|
|
return true;
|
|
}
|
|
LOG_DEBUG("MPU6050 init failed");
|
|
return false;
|
|
}
|
|
|
|
int32_t MPU6050Sensor::runOnce()
|
|
{
|
|
if (sensor.getMotionInterruptStatus()) {
|
|
wakeScreen();
|
|
}
|
|
return MOTION_SENSOR_CHECK_INTERVAL_MS;
|
|
}
|
|
|
|
#endif |