try to make it more stable...
This commit is contained in:
parent
85b0f6db06
commit
6d3053d8ad
|
|
@ -143,8 +143,6 @@ bool fFlash;
|
||||||
bool fUsbPower;
|
bool fUsbPower;
|
||||||
|
|
||||||
// have we printed the sleep info?
|
// have we printed the sleep info?
|
||||||
bool g_fPrintedSleeping = false;
|
|
||||||
|
|
||||||
// the job that's used to synchronize us with the LMIC code
|
// the job that's used to synchronize us with the LMIC code
|
||||||
static osjob_t iterationJob;
|
static osjob_t iterationJob;
|
||||||
static osjob_t sendJob;
|
static osjob_t sendJob;
|
||||||
|
|
@ -690,15 +688,15 @@ void StartNewIteration() {
|
||||||
gLed.Set(LedPattern::TwoShort);
|
gLed.Set(LedPattern::TwoShort);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Loop while sending is in progress, timeout just in case after 300 seconds
|
// Loop 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("waiting while send is in progress\n");
|
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))
|
||||||
{
|
{
|
||||||
os_runloop_once();
|
gCatena.poll();
|
||||||
delay(10);
|
yield();
|
||||||
}
|
}
|
||||||
// handle timeout...
|
// handle timeout...
|
||||||
if (send_in_progress) {
|
if (send_in_progress) {
|
||||||
|
|
@ -726,33 +724,11 @@ void StartNewIteration() {
|
||||||
sleep_time_sec = 5;
|
sleep_time_sec = 5;
|
||||||
}
|
}
|
||||||
|
|
||||||
// for the first <INIT_PACKETS> iterations, we set the sleep time to 10 seconds only...
|
// for the first <INIT_PACKETS> iterations, we set the sleep time to 120 seconds only...
|
||||||
if (iteration <= INIT_PACKETS) {
|
if (iteration <= INIT_PACKETS) {
|
||||||
sleep_time_sec = 10;
|
sleep_time_sec = 120;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Before we go to sleep, we'd like to be sure that this is safe!
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("We wait until is is safe to go to sleep...\n");
|
|
||||||
}
|
|
||||||
long loopCount = 0;
|
|
||||||
long prevPrint;
|
|
||||||
while(os_queryTimeCriticalJobs(ms2osticks(8000)) != 0)
|
|
||||||
{
|
|
||||||
loopCount++;
|
|
||||||
os_runloop_once();
|
|
||||||
if(millis() - prevPrint > 1000) {
|
|
||||||
prevPrint = millis();
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("LMIC.opmode: %#x\n", LMIC.opmode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("Now it is safe to go to sleep\n");
|
|
||||||
}
|
|
||||||
delay(10);
|
|
||||||
|
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("now going to sleep for %d seconds...\n", sleep_time_sec);
|
gCatena.SafePrintf("now going to sleep for %d seconds...\n", sleep_time_sec);
|
||||||
if (fUsbPower) {
|
if (fUsbPower) {
|
||||||
|
|
@ -819,9 +795,6 @@ void startSendingUplink(bool firstTime)
|
||||||
fConfirmed = true;
|
fConfirmed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
os_runloop_once();
|
|
||||||
//gCatena.poll();
|
|
||||||
|
|
||||||
if (firstTime) {
|
if (firstTime) {
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("SendBuffer firstTime\n");
|
gCatena.SafePrintf("SendBuffer firstTime\n");
|
||||||
|
|
@ -846,8 +819,6 @@ static void sendBufferDoneCb(
|
||||||
{
|
{
|
||||||
osjobcb_t pFn;
|
osjobcb_t pFn;
|
||||||
|
|
||||||
send_in_progress = false;
|
|
||||||
|
|
||||||
if (config_data.debug_level > 1) {
|
if (config_data.debug_level > 1) {
|
||||||
gLed.Set(LedPattern::Settling);
|
gLed.Set(LedPattern::Settling);
|
||||||
gCatena.SafePrintf("LMIC.opmode in sendBufferDoneCb: %#x\n", LMIC.opmode);
|
gCatena.SafePrintf("LMIC.opmode in sendBufferDoneCb: %#x\n", LMIC.opmode);
|
||||||
|
|
@ -889,6 +860,70 @@ static void txNotProvisionedCb(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool checkDeepSleep(void)
|
||||||
|
{
|
||||||
|
return !fUsbPower;
|
||||||
|
}
|
||||||
|
|
||||||
|
void doSleepAlert(const bool fDeepSleep)
|
||||||
|
{
|
||||||
|
if (config_data.debug_level > 0) {
|
||||||
|
gCatena.SafePrintf("We wait until is is safe to go to sleep...\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i <= 15; i++) {
|
||||||
|
long prevPrint = millis();
|
||||||
|
while (os_queryTimeCriticalJobs(ms2osticks(2000)) != 0)
|
||||||
|
{
|
||||||
|
gCatena.poll();
|
||||||
|
yield();
|
||||||
|
if (millis() - prevPrint > 1000) {
|
||||||
|
prevPrint = millis();
|
||||||
|
if (config_data.debug_level > 0) {
|
||||||
|
gCatena.SafePrintf("LMIC.opmode: %#x in loop %d\n", LMIC.opmode, i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// we wait an extra five seconds...
|
||||||
|
uint32_t tNow = millis();
|
||||||
|
while (uint32_t(millis() - tNow) < 5000)
|
||||||
|
{
|
||||||
|
gCatena.poll();
|
||||||
|
yield();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (config_data.debug_level > 0) {
|
||||||
|
gCatena.SafePrintf("Now it is safe to go to sleep\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void updateSleepCounters(void)
|
||||||
|
{
|
||||||
|
// update the sleep parameters
|
||||||
|
if (gTxCycleCount > 1)
|
||||||
|
{
|
||||||
|
// values greater than one are decremented and ultimately reset to default.
|
||||||
|
--gTxCycleCount;
|
||||||
|
}
|
||||||
|
else if (gTxCycleCount == 1)
|
||||||
|
{
|
||||||
|
// it's now one (otherwise we couldn't be here.)
|
||||||
|
if (config_data.debug_level > 0) {
|
||||||
|
gCatena.SafePrintf("resetting tx cycle to default: %u\n", CATCFG_T_CYCLE);
|
||||||
|
}
|
||||||
|
gTxCycleCount = 0;
|
||||||
|
gTxCycle = CATCFG_T_CYCLE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// it's zero. Leave it alone.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void settleDoneCb(
|
static void settleDoneCb(
|
||||||
osjob_t* pSendJob)
|
osjob_t* pSendJob)
|
||||||
|
|
@ -896,6 +931,21 @@ static void settleDoneCb(
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
gCatena.SafePrintf("settleDoneCb - we are at the end of the callback chain!\n");
|
gCatena.SafePrintf("settleDoneCb - we are at the end of the callback chain!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const bool fDeepSleep = checkDeepSleep();
|
||||||
|
|
||||||
|
if (uint32_t(millis()) > gRebootMs)
|
||||||
|
{
|
||||||
|
// time to reboot
|
||||||
|
NVIC_SystemReset();
|
||||||
|
}
|
||||||
|
|
||||||
|
doSleepAlert(fDeepSleep);
|
||||||
|
|
||||||
|
/* count what we're up to */
|
||||||
|
updateSleepCounters();
|
||||||
|
|
||||||
|
send_in_progress = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void deepSleepPrepare(void)
|
void deepSleepPrepare(void)
|
||||||
|
|
|
||||||
|
|
@ -56,7 +56,7 @@ enum {
|
||||||
|
|
|
|
||||||
\****************************************************************************/
|
\****************************************************************************/
|
||||||
|
|
||||||
static const int32_t fwVersion = 20200530;
|
static const int32_t fwVersion = 20200601;
|
||||||
|
|
||||||
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;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue