Skip to content

Commit cf1c863

Browse files
authored
Merge pull request #284 from ngavars/main
Telemetry: INA3221 current sensor support for Promicro
2 parents e291b57 + 74c1ff3 commit cf1c863

File tree

5 files changed

+122
-5
lines changed

5 files changed

+122
-5
lines changed

.gitignore

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,3 +6,5 @@
66
.vscode/ipch
77
out/
88
.direnv/
9+
.DS_Store
10+
.vscode/settings.json

src/helpers/SensorManager.h

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,11 +2,18 @@
22

33
#include <CayenneLPP.h>
44

5-
#define TELEM_PERM_BASE 0x01 // 'base' permission includes battery
6-
#define TELEM_PERM_LOCATION 0x02
5+
#define TELEM_PERM_BASE 0x01 // 'base' permission includes battery
6+
#define TELEM_PERM_LOCATION 0x02
7+
#define TELEM_PERM_ENVIRONMENT 0x04 // permission to access environment sensors
78

89
#define TELEM_CHANNEL_SELF 1 // LPP data channel for 'self' device
910

11+
#define TELEM_INA3221_ADDRESS 0x42 // INA3221 3 channel current, voltage, power sensor I2C address
12+
#define TELEM_INA3221_SHUNT_VALUE 0.100 // most variants will have a 0.1 ohm shunts
13+
#define TELEM_INA3221_SETTING_CH1 "INA3221 Channel 1"
14+
#define TELEM_INA3221_SETTING_CH2 "INA3221 Channel 2"
15+
#define TELEM_INA3221_SETTING_CH3 "INA3221 Channel 3"
16+
1017
class SensorManager {
1118
public:
1219
double node_lat, node_lon; // modify these, if you want to affect Advert location

variants/promicro/platformio.ini

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,8 @@ build_flags =
3636
; -D MESH_DEBUG=1
3737
lib_deps = ${Faketec.lib_deps}
3838
adafruit/RTClib @ ^2.1.3
39-
39+
robtillaart/INA3221 @ ^0.4.1
40+
4041
[env:Faketec_room_server]
4142
extends = Faketec
4243
build_src_filter = ${Faketec.build_src_filter}

variants/promicro/target.cpp

Lines changed: 83 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ WRAPPER_CLASS radio_driver(radio, board);
1010

1111
VolatileRTCClock fallback_clock;
1212
AutoDiscoverRTCClock rtc_clock(fallback_clock);
13-
SensorManager sensors;
13+
PromicroSensorManager sensors;
1414

1515
#ifndef LORA_CR
1616
#define LORA_CR 5
@@ -74,3 +74,85 @@ mesh::LocalIdentity radio_new_identity() {
7474
RadioNoiseListener rng(radio);
7575
return mesh::LocalIdentity(&rng); // create new random identity
7676
}
77+
78+
INA3221 INA_3221(TELEM_INA3221_ADDRESS, &Wire);
79+
80+
bool PromicroSensorManager::begin() {
81+
if (INA_3221.begin() ) {
82+
Serial.print("Found INA3221 at address ");
83+
Serial.print(INA_3221.getAddress());
84+
Serial.println();
85+
Serial.print(INA_3221.getDieID(), HEX);
86+
Serial.print(INA_3221.getManufacturerID(), HEX);
87+
Serial.print(INA_3221.getConfiguration(), HEX);
88+
Serial.println();
89+
90+
for(int i = 0; i < 3; i++) {
91+
INA_3221.setShuntR(i, TELEM_INA3221_SHUNT_VALUE);
92+
}
93+
INA3221initialized = true;
94+
}
95+
else {
96+
INA3221initialized = false;
97+
Serial.print("INA3221 was not found at I2C address ");
98+
Serial.print(TELEM_INA3221_ADDRESS, HEX);
99+
Serial.println();
100+
}
101+
return true;
102+
}
103+
104+
bool PromicroSensorManager::querySensors(uint8_t requester_permissions, CayenneLPP& telemetry) {
105+
if (requester_permissions && TELEM_PERM_ENVIRONMENT) {
106+
if (INA3221initialized) {
107+
for(int i = 0; i < 3; i++) {
108+
// add only enabled INA3221 channels to telemetry
109+
if (INA3221_CHANNEL_ENABLED[i]) {
110+
telemetry.addVoltage(INA3221_CHANNELS[i], INA_3221.getBusVoltage(i));
111+
telemetry.addCurrent(INA3221_CHANNELS[i], INA_3221.getCurrent(i));
112+
telemetry.addPower(INA3221_CHANNELS[i], INA_3221.getPower(i));
113+
}
114+
}
115+
}
116+
}
117+
118+
return true;
119+
}
120+
121+
int PromicroSensorManager::getNumSettings() const {
122+
return NUM_SENSOR_SETTINGS;
123+
}
124+
125+
const char* PromicroSensorManager::getSettingName(int i) const {
126+
if (i >= 0 && i < NUM_SENSOR_SETTINGS) {
127+
return INA3221_CHANNEL_NAMES[i];
128+
}
129+
return NULL;
130+
}
131+
132+
const char* PromicroSensorManager::getSettingValue(int i) const {
133+
if (i >= 0 && i < NUM_SENSOR_SETTINGS) {
134+
return INA3221_CHANNEL_ENABLED[i] ? "1" : "0";
135+
}
136+
return NULL;
137+
}
138+
139+
bool PromicroSensorManager::setSettingValue(const char* name, const char* value) {
140+
for (int i = 0; i < NUM_SENSOR_SETTINGS; i++) {
141+
if (strcmp(name, INA3221_CHANNEL_NAMES[i]) == 0) {
142+
int channelEnabled = INA_3221.getEnableChannel(i);
143+
if (strcmp(value, "1") == 0) {
144+
INA3221_CHANNEL_ENABLED[i] = true;
145+
if (!channelEnabled) {
146+
INA_3221.enableChannel(i);
147+
}
148+
} else {
149+
INA3221_CHANNEL_ENABLED[i] = false;
150+
if (channelEnabled) {
151+
INA_3221.disableChannel(i);
152+
}
153+
}
154+
return true;
155+
}
156+
}
157+
return false;
158+
}

variants/promicro/target.h

Lines changed: 26 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,14 +8,39 @@
88
#include <helpers/CustomLLCC68Wrapper.h>
99
#include <helpers/AutoDiscoverRTCClock.h>
1010
#include <helpers/SensorManager.h>
11+
#include <INA3221.h>
12+
13+
#define NUM_SENSOR_SETTINGS 3
1114

1215
extern PromicroBoard board;
1316
extern WRAPPER_CLASS radio_driver;
1417
extern AutoDiscoverRTCClock rtc_clock;
15-
extern SensorManager sensors;
18+
1619

1720
bool radio_init();
1821
uint32_t radio_get_rng_seed();
1922
void radio_set_params(float freq, float bw, uint8_t sf, uint8_t cr);
2023
void radio_set_tx_power(uint8_t dbm);
2124
mesh::LocalIdentity radio_new_identity();
25+
26+
27+
class PromicroSensorManager: public SensorManager {
28+
bool INA3221initialized = false;
29+
30+
// INA3221 channels in telemetry
31+
int INA3221_CHANNELS[NUM_SENSOR_SETTINGS] = {TELEM_CHANNEL_SELF + 1, TELEM_CHANNEL_SELF + 2, TELEM_CHANNEL_SELF+ 3};
32+
char * INA3221_CHANNEL_NAMES[NUM_SENSOR_SETTINGS] = { TELEM_INA3221_SETTING_CH1, TELEM_INA3221_SETTING_CH2, TELEM_INA3221_SETTING_CH3};
33+
bool INA3221_CHANNEL_ENABLED[NUM_SENSOR_SETTINGS] = {true, true, true};
34+
35+
public:
36+
PromicroSensorManager(){};
37+
bool begin() override;
38+
bool querySensors(uint8_t requester_permissions, CayenneLPP& telemetry) override;
39+
int getNumSettings() const override;
40+
const char* getSettingName(int i) const override;
41+
const char* getSettingValue(int i) const override;
42+
bool setSettingValue(const char* name, const char* value) override;
43+
};
44+
45+
46+
extern PromicroSensorManager sensors;

0 commit comments

Comments
 (0)