remove timestamps in debug messages, debug nau7802 i2c connection
This commit is contained in:
parent
775eafc74f
commit
1ce266ab22
|
|
@ -170,7 +170,7 @@ void setup(void)
|
||||||
void setup_platform(void)
|
void setup_platform(void)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_platform\n", millis());
|
gCatena.SafePrintf("Setup_platform\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* add our application-specific commands */
|
/* add our application-specific commands */
|
||||||
|
|
@ -181,12 +181,12 @@ void setup_platform(void)
|
||||||
|
|
||||||
// read config_data from fram...
|
// read config_data from fram...
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - Reading Calibration Config from FRAM...\n", millis());
|
gCatena.SafePrintf("Reading Calibration Config from FRAM...\n");
|
||||||
}
|
}
|
||||||
gCatena.getFram()->getField(cFramStorage::kAppConf, (uint8_t *)&config_data, sizeof(config_data));
|
gCatena.getFram()->getField(cFramStorage::kAppConf, (uint8_t *)&config_data, sizeof(config_data));
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_platform, this is the configuration\n", millis());
|
gCatena.SafePrintf("Setup_platform, this is the configuration\n");
|
||||||
gCatena.SafePrintf("cal_w1_0: %d\n", config_data.cal_w1_0);
|
gCatena.SafePrintf("cal_w1_0: %d\n", config_data.cal_w1_0);
|
||||||
gCatena.SafePrintf("cal_w2_0: %d\n", config_data.cal_w2_0);
|
gCatena.SafePrintf("cal_w2_0: %d\n", config_data.cal_w2_0);
|
||||||
gCatena.SafePrintf("cal_w1_factor: %d.%03d\n", (int)config_data.cal_w1_factor, (int)abs(config_data.cal_w1_factor * 1000) % 1000);
|
gCatena.SafePrintf("cal_w1_factor: %d.%03d\n", (int)config_data.cal_w1_factor, (int)abs(config_data.cal_w1_factor * 1000) % 1000);
|
||||||
|
|
@ -286,7 +286,7 @@ void setup_platform(void)
|
||||||
void setup_bme280(void)
|
void setup_bme280(void)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_bme280\n", millis());
|
gCatena.SafePrintf("Setup_bme280\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gBME280.begin(BME280_ADDRESS, Adafruit_BME280::OPERATING_MODE::Sleep)) {
|
if (gBME280.begin(BME280_ADDRESS, Adafruit_BME280::OPERATING_MODE::Sleep)) {
|
||||||
|
|
@ -301,7 +301,7 @@ void setup_bme280(void)
|
||||||
bool setup_scales(void)
|
bool setup_scales(void)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_scales\n", millis());
|
gCatena.SafePrintf("Setup_scales\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool res;
|
bool res;
|
||||||
|
|
@ -311,7 +311,7 @@ bool setup_scales(void)
|
||||||
PowerupScale();
|
PowerupScale();
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_scale done\n", millis());
|
gCatena.SafePrintf("Setup_scale done\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
|
@ -320,14 +320,14 @@ bool setup_scales(void)
|
||||||
void setup_flash(void)
|
void setup_flash(void)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_flash\n", millis());
|
gCatena.SafePrintf("setup_flash\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gFlash.begin(&gSPI2, Catena::PIN_SPI2_FLASH_SS)) {
|
if (gFlash.begin(&gSPI2, Catena::PIN_SPI2_FLASH_SS)) {
|
||||||
fFlash = true;
|
fFlash = true;
|
||||||
gFlash.powerDown();
|
gFlash.powerDown();
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - FLASH found, but power down\n", millis());
|
gCatena.SafePrintf("FLASH found, but power down\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
@ -335,7 +335,7 @@ void setup_flash(void)
|
||||||
gFlash.end();
|
gFlash.end();
|
||||||
gSPI2.end();
|
gSPI2.end();
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - No FLASH found: check hardware\n", millis());
|
gCatena.SafePrintf("FLASH found: check hardware\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -343,7 +343,7 @@ void setup_flash(void)
|
||||||
void setup_uplink(void)
|
void setup_uplink(void)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_uplink\n", millis());
|
gCatena.SafePrintf("setup_uplink\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
LMIC_setClockError(1 * 65536 / 100);
|
LMIC_setClockError(1 * 65536 / 100);
|
||||||
|
|
@ -354,14 +354,14 @@ void setup_uplink(void)
|
||||||
|
|
||||||
// Do an unjoin, so every reboot will trigger a join
|
// Do an unjoin, so every reboot will trigger a join
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - do an unjoin...\n", millis());
|
gCatena.SafePrintf("do an unjoin...\n");
|
||||||
}
|
}
|
||||||
LMIC_unjoin();
|
LMIC_unjoin();
|
||||||
|
|
||||||
/* trigger a join by sending the first packet */
|
/* trigger a join by sending the first packet */
|
||||||
if (!(gCatena.GetOperatingFlags() & static_cast<uint32_t>(gCatena.OPERATING_FLAGS::fManufacturingTest))) {
|
if (!(gCatena.GetOperatingFlags() & static_cast<uint32_t>(gCatena.OPERATING_FLAGS::fManufacturingTest))) {
|
||||||
if (!gLoRaWAN.IsProvisioned())
|
if (!gLoRaWAN.IsProvisioned())
|
||||||
gCatena.SafePrintf("%010d - LoRaWAN not provisioned yet. Use the commands to set it up.\n");
|
gCatena.SafePrintf("LoRaWAN not provisioned yet. Use the commands to set it up.\n");
|
||||||
else {
|
else {
|
||||||
if (config_data.debug_level > 1) {
|
if (config_data.debug_level > 1) {
|
||||||
gLed.Set(LedPattern::Joining);
|
gLed.Set(LedPattern::Joining);
|
||||||
|
|
@ -422,7 +422,7 @@ void ClearLoraData(void)
|
||||||
|
|
||||||
void ShowLORAData(bool firstTime)
|
void ShowLORAData(bool firstTime)
|
||||||
{
|
{
|
||||||
gCatena.SafePrintf("%010d - ShowLORAData\n", millis());
|
gCatena.SafePrintf("ShowLORAData\n");
|
||||||
|
|
||||||
if (firstTime) {
|
if (firstTime) {
|
||||||
|
|
||||||
|
|
@ -503,7 +503,7 @@ uint8_t GetVBatValue(int millivolts)
|
||||||
void DoDeepSleep(uint32_t sleep_time)
|
void DoDeepSleep(uint32_t sleep_time)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - DoDeepSleep, now going to deep sleep\n", millis());
|
gCatena.SafePrintf("DoDeepSleep, now going to deep sleep\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prepare Deep Sleep
|
// Prepare Deep Sleep
|
||||||
|
|
@ -520,7 +520,7 @@ void DoDeepSleep(uint32_t sleep_time)
|
||||||
deepSleepRecovery();
|
deepSleepRecovery();
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - done with deep sleep\n", millis());
|
gCatena.SafePrintf("done with deep sleep\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -534,7 +534,7 @@ void ReadSensors(SENSOR_data &sensor_data) {
|
||||||
int vbat_mv = (int)(gCatena.ReadVbat() * 1000.0f);
|
int vbat_mv = (int)(gCatena.ReadVbat() * 1000.0f);
|
||||||
res.vbat = GetVBatValue(vbat_mv);
|
res.vbat = GetVBatValue(vbat_mv);
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - vBat: %d mV\n", millis(), vbat_mv);
|
gCatena.SafePrintf("vBat: %d mV\n", vbat_mv);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read Scales
|
// Read Scales
|
||||||
|
|
@ -542,36 +542,36 @@ void ReadSensors(SENSOR_data &sensor_data) {
|
||||||
w2_0_real = config_data.cal_w2_0;
|
w2_0_real = config_data.cal_w2_0;
|
||||||
if (setup_scales()) {
|
if (setup_scales()) {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - LoadCell is ready.\n", millis());
|
gCatena.SafePrintf("LoadCell is ready.\n");
|
||||||
}
|
}
|
||||||
if (config_data.cal_w1_0 != NOT_ATTACHED) {
|
if (config_data.cal_w1_0 != NOT_ATTACHED) {
|
||||||
res.weight1 = (int32_t)ReadScale('A');
|
res.weight1 = (int32_t)ReadScale('A');
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - Load_cell 1 weight1_current: %ld\n", millis(), res.weight1);
|
gCatena.SafePrintf("Load_cell 1 weight1_current: %ld\n", res.weight1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
res.weight1 = 0;
|
res.weight1 = 0;
|
||||||
w1_0_real = 0;
|
w1_0_real = 0;
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - Load_cell 1 is disabled\n", millis());
|
gCatena.SafePrintf("Load_cell 1 is disabled\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (config_data.cal_w2_0 != NOT_ATTACHED) {
|
if (config_data.cal_w2_0 != NOT_ATTACHED) {
|
||||||
res.weight2 = (int32_t)ReadScale('B');
|
res.weight2 = (int32_t)ReadScale('B');
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - Load_cell 2 weight2_current: %ld\n", millis(), res.weight2);
|
gCatena.SafePrintf("Load_cell 2 weight2_current: %ld\n", res.weight2);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
res.weight2 = 0;
|
res.weight2 = 0;
|
||||||
w2_0_real = 0;
|
w2_0_real = 0;
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - Load_cell 2 is disabled\n", millis());
|
gCatena.SafePrintf("Load_cell 2 is disabled\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - LoadCell not ready.\n", millis());
|
gCatena.SafePrintf("LoadCell not ready.\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -604,8 +604,7 @@ void ReadSensors(SENSOR_data &sensor_data) {
|
||||||
// humidity is one byte, where 0 == 0/256 and 0xFF == 255/256.
|
// humidity is one byte, where 0 == 0/256 and 0xFF == 255/256.
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf(
|
gCatena.SafePrintf(
|
||||||
"%010d - BME280: T: %d P: %d RH: %d\n",
|
"BME280: T: %d P: %d RH: %d\n",
|
||||||
millis(),
|
|
||||||
(int)m.Temperature,
|
(int)m.Temperature,
|
||||||
(int)m.Pressure,
|
(int)m.Pressure,
|
||||||
(int)m.Humidity);
|
(int)m.Humidity);
|
||||||
|
|
@ -614,7 +613,7 @@ void ReadSensors(SENSOR_data &sensor_data) {
|
||||||
res.humidity = (uint8_t)m.Humidity;
|
res.humidity = (uint8_t)m.Humidity;
|
||||||
res.pressure = (uint8_t)((m.Pressure / 100) - PRESSURE_OFFSET);
|
res.pressure = (uint8_t)((m.Pressure / 100) - PRESSURE_OFFSET);
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - pressure_current: %d\n", millis(), res.pressure);
|
gCatena.SafePrintf("pressure_current: %d\n", res.pressure);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -635,7 +634,7 @@ void StartNewIteration() {
|
||||||
// vBus
|
// vBus
|
||||||
float vBus = gCatena.ReadVbus();
|
float vBus = gCatena.ReadVbus();
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - vBus: %d mV\n", millis(), (int)(vBus * 1000.0f));
|
gCatena.SafePrintf("vBus: %d mV\n", (int)(vBus * 1000.0f));
|
||||||
}
|
}
|
||||||
fUsbPower = (vBus > 4.3) ? true : false;
|
fUsbPower = (vBus > 4.3) ? true : false;
|
||||||
|
|
||||||
|
|
@ -681,7 +680,7 @@ void StartNewIteration() {
|
||||||
if ( (next_package_is_init_package) || (my_position >= MAX_VALUES_TO_SEND) || ((last_sensor_reading.weight - current_sensor_reading.weight) > SEND_DIFF_THRESHOLD_5GRAMS) || ((millis() - timer_pos0) > 3600000)) {
|
if ( (next_package_is_init_package) || (my_position >= MAX_VALUES_TO_SEND) || ((last_sensor_reading.weight - current_sensor_reading.weight) > SEND_DIFF_THRESHOLD_5GRAMS) || ((millis() - timer_pos0) > 3600000)) {
|
||||||
lora_data.offset_last_reading = (uint8_t)((millis() - timer_pos0) / 1000 / 60);
|
lora_data.offset_last_reading = (uint8_t)((millis() - timer_pos0) / 1000 / 60);
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - startSendingUplink(), my_position: %d, iteration: %d, package_counter: %d\n", millis(), my_position, iteration, package_counter);
|
gCatena.SafePrintf("startSendingUplink(), my_position: %d, iteration: %d, package_counter: %d\n", my_position, iteration, package_counter);
|
||||||
}
|
}
|
||||||
// the first <INIT_PACKETS> packets are "Init-Packets" or each INIT_PACKAGE_INTERVAL ...
|
// the first <INIT_PACKETS> packets are "Init-Packets" or each INIT_PACKAGE_INTERVAL ...
|
||||||
startSendingUplink(next_package_is_init_package);
|
startSendingUplink(next_package_is_init_package);
|
||||||
|
|
@ -694,7 +693,7 @@ void StartNewIteration() {
|
||||||
// Loop while sending is in progress, timeout just in case after 300 seconds
|
// Loop while sending is in progress, timeout just in case after 300 seconds
|
||||||
long start_time = millis();
|
long start_time = millis();
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - waiting while send is in progress\n", millis());
|
gCatena.SafePrintf("waiting while send is in progress\n");
|
||||||
}
|
}
|
||||||
while (send_in_progress && ((millis() - start_time) < 300000))
|
while (send_in_progress && ((millis() - start_time) < 300000))
|
||||||
{
|
{
|
||||||
|
|
@ -703,7 +702,7 @@ void StartNewIteration() {
|
||||||
}
|
}
|
||||||
wait_time = (uint32_t)((millis() - start_time) / 1000);
|
wait_time = (uint32_t)((millis() - start_time) / 1000);
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - end waiting, wait time was %d seconds\n", millis(), wait_time);
|
gCatena.SafePrintf("end waiting, wait time was %d seconds\n", wait_time);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -726,11 +725,11 @@ void StartNewIteration() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - now going to sleep for %d seconds...\n", millis(), sleep_time_sec);
|
gCatena.SafePrintf("now going to sleep for %d seconds...\n", sleep_time_sec);
|
||||||
if (fUsbPower) {
|
if (fUsbPower) {
|
||||||
gCatena.SafePrintf("%010d - USB Power is on\n", millis());
|
gCatena.SafePrintf("USB Power is on\n");
|
||||||
} else {
|
} else {
|
||||||
gCatena.SafePrintf("%010d - USB Power is off\n", millis());
|
gCatena.SafePrintf("USB Power is off\n");
|
||||||
}
|
}
|
||||||
//Serial.flush();
|
//Serial.flush();
|
||||||
if (config_data.debug_level > 1) {
|
if (config_data.debug_level > 1) {
|
||||||
|
|
@ -751,7 +750,7 @@ void StartNewIteration() {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - light sleep; os_setTimedCallback for startNewIterationCb in %d...seconds\n", millis(), sleep_time_sec);
|
gCatena.SafePrintf("light sleep; os_setTimedCallback for startNewIterationCb in %d...seconds\n", sleep_time_sec);
|
||||||
}
|
}
|
||||||
os_setTimedCallback(
|
os_setTimedCallback(
|
||||||
&iterationJob,
|
&iterationJob,
|
||||||
|
|
@ -786,13 +785,13 @@ void startSendingUplink(bool firstTime)
|
||||||
|
|
||||||
if (firstTime) {
|
if (firstTime) {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - SendBuffer firstTime\n", millis());
|
gCatena.SafePrintf("SendBuffer firstTime\n");
|
||||||
}
|
}
|
||||||
gLoRaWAN.SendBuffer((uint8_t*)&lora_data_first, sizeof(LORA_data_first), sendBufferDoneCb, NULL, fConfirmed, kUplinkPort);
|
gLoRaWAN.SendBuffer((uint8_t*)&lora_data_first, sizeof(LORA_data_first), sendBufferDoneCb, NULL, fConfirmed, kUplinkPort);
|
||||||
package_counter++;
|
package_counter++;
|
||||||
} else {
|
} else {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - SendBuffer not firstTime\n", millis());
|
gCatena.SafePrintf("SendBuffer not firstTime\n");
|
||||||
}
|
}
|
||||||
gLoRaWAN.SendBuffer((uint8_t*)&lora_data, sizeof(LORA_data), sendBufferDoneCb, NULL, fConfirmed, kUplinkPort);
|
gLoRaWAN.SendBuffer((uint8_t*)&lora_data, sizeof(LORA_data), sendBufferDoneCb, NULL, fConfirmed, kUplinkPort);
|
||||||
package_counter++;
|
package_counter++;
|
||||||
|
|
@ -823,7 +822,7 @@ static void sendBufferDoneCb(
|
||||||
gLoRaWAN.Shutdown();
|
gLoRaWAN.Shutdown();
|
||||||
}
|
}
|
||||||
else if (config_data.debug_level > 0) {
|
else if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - send buffer failed\n", millis());
|
gCatena.SafePrintf("send buffer failed\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -854,7 +853,7 @@ static void settleDoneCb(
|
||||||
const bool fDeepSleep = checkDeepSleep();
|
const bool fDeepSleep = checkDeepSleep();
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - settleDoneCb\n", millis());
|
gCatena.SafePrintf("settleDoneCb\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_data.debug_level > 2) {
|
if (config_data.debug_level > 2) {
|
||||||
|
|
@ -1004,7 +1003,7 @@ void doDeepSleep(osjob_t *pJob)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - doDeepSleep, sleepInterval: %d...\n", millis(), sleepInterval);
|
gCatena.SafePrintf("doDeepSleep, sleepInterval: %d...\n", sleepInterval);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ok... now it's time for a deep sleep */
|
/* ok... now it's time for a deep sleep */
|
||||||
|
|
@ -1046,7 +1045,7 @@ void doLightSleep(osjob_t *pJob)
|
||||||
|
|
||||||
if (config_data.debug_level > 1) {
|
if (config_data.debug_level > 1) {
|
||||||
gLed.Set(LedPattern::Sleeping);
|
gLed.Set(LedPattern::Sleeping);
|
||||||
gCatena.SafePrintf("%010d - doLightSleep\n", millis());
|
gCatena.SafePrintf("doLightSleep\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gCatena.GetOperatingFlags() &
|
if (gCatena.GetOperatingFlags() &
|
||||||
|
|
@ -1070,7 +1069,7 @@ static void sleepDoneCb(osjob_t* pJob)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - sleepDoneCb\n", millis());
|
gCatena.SafePrintf("sleepDoneCb\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
os_setTimedCallback(
|
os_setTimedCallback(
|
||||||
|
|
@ -1082,7 +1081,7 @@ static void sleepDoneCb(osjob_t* pJob)
|
||||||
static void warmupDoneCb(osjob_t* pJob)
|
static void warmupDoneCb(osjob_t* pJob)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - warmupDoneCb\n", millis());
|
gCatena.SafePrintf("warmupDoneCb\n");
|
||||||
}
|
}
|
||||||
send_in_progress = false;
|
send_in_progress = false;
|
||||||
}
|
}
|
||||||
|
|
@ -1090,7 +1089,7 @@ static void warmupDoneCb(osjob_t* pJob)
|
||||||
static void startNewIterationCb(osjob_t* pJob)
|
static void startNewIterationCb(osjob_t* pJob)
|
||||||
{
|
{
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - startNewIterationCb\n", millis());
|
gCatena.SafePrintf("startNewIterationCb\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! stop_iterations) {
|
if (! stop_iterations) {
|
||||||
|
|
@ -1116,7 +1115,7 @@ static void receiveMessage(void *pContext, uint8_t port, const uint8_t *pMessage
|
||||||
SENSOR_data temp_sensor_data;
|
SENSOR_data temp_sensor_data;
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - receiveMessage was called!!!\n", millis());
|
gCatena.SafePrintf("receiveMessage was called!!!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_data.debug_level > 2) {
|
if (config_data.debug_level > 2) {
|
||||||
|
|
|
||||||
|
|
@ -56,7 +56,7 @@ enum {
|
||||||
|
|
|
|
||||||
\****************************************************************************/
|
\****************************************************************************/
|
||||||
|
|
||||||
static const int32_t fwVersion = 20200522;
|
static const int32_t fwVersion = 20200523;
|
||||||
|
|
||||||
static const byte INIT_PACKAGE_INTERVAL = 100; // send an init package every 100 packages;
|
static const byte INIT_PACKAGE_INTERVAL = 100; // send an init package every 100 packages;
|
||||||
static const byte MAX_VALUES_TO_SEND = 8;
|
static const byte MAX_VALUES_TO_SEND = 8;
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,7 @@ bool SetupScales(byte dbg_level)
|
||||||
{
|
{
|
||||||
debug_level = dbg_level;
|
debug_level = dbg_level;
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_scales\n", millis());
|
gCatena.SafePrintf("setup_scales\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool res;
|
bool res;
|
||||||
|
|
@ -30,7 +30,7 @@ bool SetupScales(byte dbg_level)
|
||||||
pinMode(D10, OUTPUT);
|
pinMode(D10, OUTPUT);
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_scale done\n", millis());
|
gCatena.SafePrintf("setup_scale done\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
|
@ -52,7 +52,7 @@ long ReadScale(char channel)
|
||||||
long readings[num_scale_readings]; // create arry to hold readings
|
long readings[num_scale_readings]; // create arry to hold readings
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - my_read_average, measurements:\n", millis());
|
gCatena.SafePrintf("my_read_average, measurements:\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < num_scale_readings; i++) {
|
for (int i = 0; i < num_scale_readings; i++) {
|
||||||
|
|
@ -89,6 +89,6 @@ void PowerupScale()
|
||||||
delay(400);
|
delay(400);
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - setup_scale done\n", millis());
|
gCatena.SafePrintf("setup_scale done\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
#include <Wire.h>
|
#include <Wire.h>
|
||||||
|
|
||||||
#ifndef _HELPER_H_
|
#ifndef _HELPER_H_
|
||||||
|
|
@ -6,7 +8,7 @@
|
||||||
|
|
||||||
#include "SparkFun_Qwiic_Scale_NAU7802_Arduino_Library.h"
|
#include "SparkFun_Qwiic_Scale_NAU7802_Arduino_Library.h"
|
||||||
|
|
||||||
#define SAMPLES 5
|
#define SAMPLES 10
|
||||||
#define IGNORE_READINGS 5
|
#define IGNORE_READINGS 5
|
||||||
|
|
||||||
NAU7802 myScale; //Create instance of the NAU7802 class
|
NAU7802 myScale; //Create instance of the NAU7802 class
|
||||||
|
|
@ -20,34 +22,50 @@ void SetScalesDebugLevel(byte dbg_level)
|
||||||
debug_level = dbg_level;
|
debug_level = dbg_level;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool InitializeScales()
|
||||||
|
{
|
||||||
|
bool result;
|
||||||
|
result &= myScale.reset(); //Reset all registers
|
||||||
|
result &= myScale.powerUp(); //Power on analog and digital sections of the scale
|
||||||
|
|
||||||
|
// we wait 100 ms to give it time to stabilze
|
||||||
|
delay(100);
|
||||||
|
|
||||||
|
result &= myScale.setIntPolarityHigh();
|
||||||
|
result &= myScale.setLDO(NAU7802_LDO_3V3); //Set LDO to 3.3V
|
||||||
|
result &= myScale.setGain(NAU7802_GAIN_128); //Set gain to 128
|
||||||
|
result &= myScale.setSampleRate(NAU7802_SPS_80); //Set samples per second to 10
|
||||||
|
result &= myScale.setRegister(NAU7802_ADC, 0x30); //Turn off CLK_CHP. From 9.1 power on sequencing.
|
||||||
|
result &= myScale.clearBit(NAU7802_PGA_PWR_PGA_CAP_EN, NAU7802_PGA_PWR);
|
||||||
|
result &= myScale.setRegister(NAU7802_OTP_B1, 0x30);
|
||||||
|
result &= myScale.setRegister(NAU7802_PGA, NAU7802_PGA_OUT_EN | NAU7802_PGA_CHP_DIS);
|
||||||
|
|
||||||
|
result &= myScale.calibrateAFE(); //Re-cal analog front end when we change gain, sample rate, or channel
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
bool SetupScales(byte dbg_level)
|
bool SetupScales(byte dbg_level)
|
||||||
{
|
{
|
||||||
debug_level = dbg_level;
|
debug_level = dbg_level;
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - SetupScales start\n", millis());
|
gCatena.SafePrintf("SetupScales start\n");
|
||||||
}
|
}
|
||||||
pinMode(interruptPin, INPUT);
|
pinMode(interruptPin, INPUT);
|
||||||
Wire.begin();
|
|
||||||
|
|
||||||
if (!myScale.begin())
|
if (!myScale.begin(Wire, false))
|
||||||
{
|
{
|
||||||
gCatena.SafePrintf("Scale not detected. Please check wiring. Freezing...\n");
|
gCatena.SafePrintf("Scale not detected. Please check wiring. Freezing...\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
gCatena.SafePrintf("Scale detected!\n");
|
gCatena.SafePrintf("Scale detected!\n");
|
||||||
|
|
||||||
myScale.setIntPolarityHigh();
|
bool result = InitializeScales();
|
||||||
|
|
||||||
myScale.clearBit(NAU7802_PGA_PWR_PGA_CAP_EN, NAU7802_PGA_PWR);
|
|
||||||
myScale.setSampleRate(NAU7802_SPS_80);
|
|
||||||
myScale.setLDO(NAU7802_LDO_3V3);
|
|
||||||
myScale.setGain(NAU7802_GAIN_128);
|
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - SetupScales done\n", millis());
|
gCatena.SafePrintf("SetupScales done, result: %d\n", result);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
long ReadScale(char channel)
|
long ReadScale(char channel)
|
||||||
|
|
@ -55,7 +73,7 @@ long ReadScale(char channel)
|
||||||
long res;
|
long res;
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - ReadScale Start\n", millis());
|
gCatena.SafePrintf("ReadScale Start, Channel %c\n", channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t channelNumber;
|
uint8_t channelNumber;
|
||||||
|
|
@ -84,31 +102,31 @@ long ReadScale(char channel)
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("Timeout while reading scale (dummy values)...\n");
|
gCatena.SafePrintf("Timeout while reading scale (dummy values)...\n");
|
||||||
}
|
}
|
||||||
return 0;
|
break;
|
||||||
}
|
}
|
||||||
delay(1);
|
delay(1);
|
||||||
}
|
}
|
||||||
dummy = myScale.getReading();
|
dummy = myScale.getReading();
|
||||||
|
if (debug_level > 0) {
|
||||||
|
gCatena.SafePrintf("Dummy Reading int32_t: %d\n", dummy);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// we use the median, not the average, see https://community.particle.io/t/boron-gpio-provides-less-current-than-electrons-gpio/46647/13
|
// we use the median, not the average, see https://community.particle.io/t/boron-gpio-provides-less-current-than-electrons-gpio/46647/13
|
||||||
startTime = millis();
|
|
||||||
long readings[num_scale_readings]; // create arry to hold readings
|
long readings[num_scale_readings]; // create arry to hold readings
|
||||||
for (int i = 0; i < num_scale_readings; i++) {
|
for (int i = 0; i < num_scale_readings; i++) {
|
||||||
//while (digitalRead(interruptPin) == LOW) {
|
//while (digitalRead(interruptPin) == LOW) {
|
||||||
while (! myScale.available()) {
|
while (! myScale.available()) {
|
||||||
//while(! myScale.available()) {
|
|
||||||
// we set a timeout of 60 seconds for the measurement...
|
// we set a timeout of 60 seconds for the measurement...
|
||||||
if ((millis() - startTime) > 60000) {
|
if ((millis() - startTime) > 60000) {
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("Timeout while reading scale...\n");
|
gCatena.SafePrintf("Timeout while reading scale...\n");
|
||||||
}
|
}
|
||||||
return 0;
|
break;
|
||||||
}
|
}
|
||||||
delay(1);
|
delay(1);
|
||||||
}
|
}
|
||||||
int32_t reading = myScale.getReading();
|
int32_t reading = myScale.getReading();
|
||||||
delay(10);
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("Reading int32_t: %d\n", reading);
|
gCatena.SafePrintf("Reading int32_t: %d\n", reading);
|
||||||
}
|
}
|
||||||
|
|
@ -140,7 +158,7 @@ long ReadScale(char channel)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - ReadScale Done\n", millis());
|
gCatena.SafePrintf("ReadScale Done\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
|
@ -149,25 +167,23 @@ long ReadScale(char channel)
|
||||||
void PowerdownScale()
|
void PowerdownScale()
|
||||||
{
|
{
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - PowerdownScale Start\n", millis());
|
gCatena.SafePrintf("PowerdownScale Start\n");
|
||||||
}
|
}
|
||||||
myScale.powerDown();
|
myScale.powerDown();
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - PowerdownScale Done\n", millis());
|
gCatena.SafePrintf("PowerdownScale Done\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void PowerupScale()
|
void PowerupScale()
|
||||||
{
|
{
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - PowerupScale Start\n", millis());
|
gCatena.SafePrintf("PowerupScale Start\n");
|
||||||
}
|
}
|
||||||
myScale.powerUp(); //Power up scale. This scale takes ~600ms to boot and take reading.
|
|
||||||
|
|
||||||
// we wait 100 ms to give it time to stabilze
|
InitializeScales();
|
||||||
delay(100);
|
|
||||||
|
|
||||||
if (debug_level > 0) {
|
if (debug_level > 0) {
|
||||||
gCatena.SafePrintf("%010d - PowerupScale Done\n", millis());
|
gCatena.SafePrintf("PowerupScale Done\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue