mirror of
https://github.com/meshtastic/firmware.git
synced 2025-10-28 07:13:25 +00:00
Some checks are pending
CI / setup (all) (push) Waiting to run
CI / setup (check) (push) Waiting to run
CI / version (push) Waiting to run
CI / check (push) Blocked by required conditions
CI / build (push) Blocked by required conditions
CI / build-debian-src (push) Waiting to run
CI / package-pio-deps-native-tft (push) Waiting to run
CI / test-native (push) Waiting to run
CI / docker (alpine, native, linux/amd64) (push) Waiting to run
CI / docker (alpine, native, linux/arm64) (push) Waiting to run
CI / docker (alpine, native-tft, linux/amd64) (push) Waiting to run
CI / docker (debian, native, linux/amd64) (push) Waiting to run
CI / docker (debian, native, linux/arm/v7) (push) Waiting to run
CI / docker (debian, native, linux/arm64) (push) Waiting to run
CI / docker (debian, native-tft, linux/amd64) (push) Waiting to run
CI / gather-artifacts (esp32) (push) Blocked by required conditions
CI / gather-artifacts (esp32c3) (push) Blocked by required conditions
CI / gather-artifacts (esp32c6) (push) Blocked by required conditions
CI / gather-artifacts (esp32s3) (push) Blocked by required conditions
CI / gather-artifacts (nrf52840) (push) Blocked by required conditions
CI / gather-artifacts (rp2040) (push) Blocked by required conditions
CI / gather-artifacts (rp2350) (push) Blocked by required conditions
CI / gather-artifacts (stm32) (push) Blocked by required conditions
CI / release-artifacts (push) Blocked by required conditions
CI / release-firmware (esp32) (push) Blocked by required conditions
CI / release-firmware (esp32c3) (push) Blocked by required conditions
CI / release-firmware (esp32c6) (push) Blocked by required conditions
CI / release-firmware (esp32s3) (push) Blocked by required conditions
CI / release-firmware (nrf52840) (push) Blocked by required conditions
CI / release-firmware (rp2040) (push) Blocked by required conditions
CI / release-firmware (rp2350) (push) Blocked by required conditions
CI / release-firmware (stm32) (push) Blocked by required conditions
CI / publish-firmware (push) Blocked by required conditions
* rework I2C sensor init the goal is to only instantiate sensors that are pressend to save memory. side effacts: - easyer sensor integration (less C&P code) - nodeTelemetrySensorsMap can be removed when all devices are migrated * add missing ifdef * refactor a bunch of more sensors RAM -816 Flash -916 * fix build for t1000 * refactor more sensors RAM -192 Flash -60 * improve error handling Flash -112 * fix build * fix build * fix IndicatorSensor * fix tracker-t1000-e build not sure what magic is used but it works * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/modules/Telemetry/Sensor/DFRobotGravitySensor.h Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fix --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
74 lines
2.2 KiB
C++
74 lines
2.2 KiB
C++
#include "configuration.h"
|
|
|
|
#if !MESHTASTIC_EXCLUDE_ENVIRONMENTAL_SENSOR
|
|
|
|
#pragma once
|
|
#include "../mesh/generated/meshtastic/telemetry.pb.h"
|
|
#include "MeshModule.h"
|
|
#include "NodeDB.h"
|
|
#include "detect/ScanI2C.h"
|
|
#include <utility>
|
|
|
|
#if !ARCH_PORTDUINO
|
|
class TwoWire;
|
|
#endif
|
|
|
|
#define DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS 1000
|
|
extern std::pair<uint8_t, TwoWire *> nodeTelemetrySensorsMap[_meshtastic_TelemetrySensorType_MAX + 1];
|
|
|
|
class TelemetrySensor
|
|
{
|
|
protected:
|
|
TelemetrySensor(meshtastic_TelemetrySensorType sensorType, const char *sensorName)
|
|
{
|
|
this->sensorName = sensorName;
|
|
this->sensorType = sensorType;
|
|
this->status = 0;
|
|
}
|
|
|
|
const char *sensorName;
|
|
meshtastic_TelemetrySensorType sensorType = meshtastic_TelemetrySensorType_SENSOR_UNSET;
|
|
unsigned status;
|
|
bool initialized = false;
|
|
|
|
int32_t initI2CSensor()
|
|
{
|
|
if (!status) {
|
|
LOG_WARN("Can't connect to detected %s sensor. Remove from nodeTelemetrySensorsMap", sensorName);
|
|
nodeTelemetrySensorsMap[sensorType].first = 0;
|
|
} else {
|
|
LOG_INFO("Opened %s sensor on i2c bus", sensorName);
|
|
setup();
|
|
}
|
|
initialized = true;
|
|
return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS;
|
|
}
|
|
|
|
// TODO: check is setup used at all?
|
|
virtual void setup() {}
|
|
|
|
public:
|
|
virtual ~TelemetrySensor() {}
|
|
|
|
virtual AdminMessageHandleResult handleAdminMessage(const meshtastic_MeshPacket &mp, meshtastic_AdminMessage *request,
|
|
meshtastic_AdminMessage *response)
|
|
{
|
|
return AdminMessageHandleResult::NOT_HANDLED;
|
|
}
|
|
|
|
// TODO: delete after migration
|
|
bool hasSensor() { return nodeTelemetrySensorsMap[sensorType].first > 0; }
|
|
|
|
#if WIRE_INTERFACES_COUNT > 1
|
|
// Set to true if Implementation only works first I2C port (Wire)
|
|
virtual bool onlyWire1() { return false; }
|
|
#endif
|
|
virtual int32_t runOnce() { return INT32_MAX; }
|
|
virtual bool isInitialized() { return initialized; }
|
|
virtual bool isRunning() { return status > 0; }
|
|
|
|
virtual bool getMetrics(meshtastic_Telemetry *measurement) = 0;
|
|
virtual bool initDevice(TwoWire *bus, ScanI2C::FoundDevice *dev) { return false; };
|
|
};
|
|
|
|
#endif |