Merge branch 'master' into andrews-local-changes

andrews-local-changes
Andrew 2 months ago committed by GitHub
commit 82926b1f5c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -22,12 +22,12 @@ upload_port = COM6
[env:dev] [env:dev]
build_flags = -D DEV ${env.build_flags} build_flags = -D DEV ${env.build_flags}
lib_deps = lib_deps =
knolleary/pubsubclient ; knolleary/pubsubclient
https://github.com/CircuitSetup/ATM90E36 ; https://github.com/CircuitSetup/ATM90E36
https://github.com/whatnick/ATM90E26_Arduino ; https://github.com/whatnick/ATM90E26_Arduino
bblanchon/ArduinoJson @ ^6.21.3 ; bblanchon/ArduinoJson @ ^6.21.3
paulstoffregen/OneWire@^2.3.8 ; paulstoffregen/OneWire@^2.3.8
milesburton/DallasTemperature@^3.11.0 ; milesburton/DallasTemperature@^3.11.0
build_src_filter = +<transformerMonitor.cpp> -<.git/> -<.svn/> -<tests/> build_src_filter = +<transformerMonitor.cpp> -<.git/> -<.svn/> -<tests/>
[env:store-creds] [env:store-creds]

@ -24,8 +24,13 @@ void setup()
// set LED to Red - FF0000 // set LED to Red - FF0000
setColor(255, 0, 0); setColor(255, 0, 0);
delay(10000); delay(10000);
Serial.begin(9600);
eicDataQueue = xQueueCreate( 50, sizeof( xformerMonitorData ) ); eicDataQueue = xQueueCreate( 50, sizeof( xformerMonitorData ) );
if (eicDataQueue == 0)
{
printf("Failed to create queue= %p\n", eicDataQueue);
}
// configure time // configure time
// TODO: make dst and timezone configurable // TODO: make dst and timezone configurable
int timezone = 3; int timezone = 3;
@ -39,12 +44,12 @@ void setup()
#endif #endif
// Start the DS18B20 sensors // Start the DS18B20 sensors
monitorTempSensors.cabinet.begin(); // monitorTempSensors.cabinet.begin();
monitorTempSensors.oil.begin(); // monitorTempSensors.oil.begin();
// Get each DS18B20 sensors' address // // Get each DS18B20 sensors' address
monitorTempSensors.oil.getAddress(oilTempSensorAddr, 0); // monitorTempSensors.oil.getAddress(oilTempSensorAddr, 0);
monitorTempSensors.cabinet.getAddress(cabinetTempSensorAddr, 0); // monitorTempSensors.cabinet.getAddress(cabinetTempSensorAddr, 0);
@ -61,7 +66,7 @@ void setup()
NULL, /* Task input parameter */ NULL, /* Task input parameter */
0, /* Priority of the task */ 0, /* Priority of the task */
&taskReadEIC, /* Task handle. */ &taskReadEIC, /* Task handle. */
0); /* Core where the task should run */ 1); /* Core where the task should run */
xTaskCreatePinnedToCore( xTaskCreatePinnedToCore(
sendSensorDataOverMQTT, /* Function to implement the task */ sendSensorDataOverMQTT, /* Function to implement the task */
@ -70,7 +75,7 @@ void setup()
NULL, /* Task input parameter */ NULL, /* Task input parameter */
0, /* Priority of the task */ 0, /* Priority of the task */
&taskSendData, /* Task handle. */ &taskSendData, /* Task handle. */
1); /* Core where the task should run */ 0); /* Core where the task should run */
} }
void connect() void connect()
@ -126,6 +131,12 @@ void loop()
{ {
// publish a message roughly every second. // publish a message roughly every second.
// // mqttClient.publish("xfmormermon", "buffer");
// // publish a message roughly every second.
// Serial.println("Sleeping 10s"); // Serial.println("Sleeping 10s");
// delay(10000); // delay(10000);
} }
@ -169,8 +180,9 @@ void setupEnergyMonitor()
// readEICData: reads the EIC and inserts data into queue // readEICData: reads the EIC and inserts data into queue
void readEICData(void *pvParameters) void readEICData(void *pvParameters)
{ {
Serial.print("Task1 running on core "); Serial.print("Task0 running on core ");
Serial.println(xPortGetCoreID()); Serial.println(xPortGetCoreID());
delay(2000);
// Attach interrupt for reading data every one second // Attach interrupt for reading data every one second
readEICTimer = timerBegin(0, 80, true); readEICTimer = timerBegin(0, 80, true);
@ -188,6 +200,7 @@ void sendSensorDataOverMQTT(void *pvParameters)
{ {
Serial.print("Task1 running on core "); Serial.print("Task1 running on core ");
Serial.println(xPortGetCoreID()); Serial.println(xPortGetCoreID());
delay(3000);
StaticJsonDocument<512> mqttJsonData; StaticJsonDocument<512> mqttJsonData;
JsonObject tempObj = mqttJsonData.createNestedObject("temps"); JsonObject tempObj = mqttJsonData.createNestedObject("temps");
JsonObject powerObj = mqttJsonData.createNestedObject("power"); JsonObject powerObj = mqttJsonData.createNestedObject("power");
@ -197,6 +210,7 @@ void sendSensorDataOverMQTT(void *pvParameters)
int emptySpaces = uxQueueSpacesAvailable(eicDataQueue); int emptySpaces = uxQueueSpacesAvailable(eicDataQueue);
for (;;) for (;;)
{ {
// Serial.println("hello from Sensor data");
if (messagesWaiting > 2) if (messagesWaiting > 2)
{ {
xQueueReceive(eicDataQueue, &mqttSensorData, portMAX_DELAY); xQueueReceive(eicDataQueue, &mqttSensorData, portMAX_DELAY);
@ -223,11 +237,11 @@ void sendSensorDataOverMQTT(void *pvParameters)
char buffer[512]; char buffer[512];
size_t n = serializeJson(mqttJsonData, buffer); size_t n = serializeJson(mqttJsonData, buffer);
delay(50);
mqttClient.publish("xfmormermon/", buffer, n); mqttClient.publish("xfmormermon/", buffer, n);
} }
delay(1000); // <- fixes some issues with WiFi stability
mqttClient.loop(); mqttClient.loop();
delay(10); // <- fixes some issues with WiFi stability
if (!mqttClient.connected()) if (!mqttClient.connected())
{ {
@ -249,12 +263,12 @@ void IRAM_ATTR ReadData(){
if (timesEnteredISR == 60) if (timesEnteredISR == 60)
{ {
timesEnteredISR = 0; timesEnteredISR = 0;
monitorTempSensors.cabinet.requestTemperatures(); // monitorTempSensors.cabinet.requestTemperatures();
monitorTempSensors.oil.requestTemperatures(); // monitorTempSensors.oil.requestTemperatures();
// get cabinet temp sensor data // get cabinet temp sensor data
sensorData.temps.cabinet = monitorTempSensors.cabinet.getTempC(cabinetTempSensorAddr); // sensorData.temps.cabinet = monitorTempSensors.cabinet.getTempC(cabinetTempSensorAddr);
// get oil temp sensor data // // get oil temp sensor data
sensorData.temps.oil = monitorTempSensors.oil.getTempC(oilTempSensorAddr); // sensorData.temps.oil = monitorTempSensors.oil.getTempC(oilTempSensorAddr);
} }
@ -268,11 +282,11 @@ void IRAM_ATTR ReadData(){
// sensorData.energy.exp = // sensorData.energy.exp =
xQueueSend(eicDataQueue, &sensorData, portMAX_DELAY); xQueueSend(eicDataQueue, &sensorData, portMAX_DELAY);
} }
void setColor(int R, int G, int B) { void setColor(int R, int G, int B) {
analogWrite(PIN_RED, R); analogWrite(PIN_RED, R);
analogWrite(PIN_GREEN, G); analogWrite(PIN_GREEN, G);
analogWrite(PIN_BLUE, B); analogWrite(PIN_BLUE, B);
Serial.println("hello from ISR");
} }
Loading…
Cancel
Save