20200604
This commit is contained in:
parent
a8fe52fa0e
commit
d0a173a54a
|
|
@ -147,11 +147,6 @@ bool fUsbPower;
|
||||||
static osjob_t iterationJob;
|
static osjob_t iterationJob;
|
||||||
static osjob_t sendJob;
|
static osjob_t sendJob;
|
||||||
|
|
||||||
// the cycle time to use
|
|
||||||
unsigned gTxCycle;
|
|
||||||
// remaining before we reset to default
|
|
||||||
unsigned gTxCycleCount;
|
|
||||||
|
|
||||||
void setup(void)
|
void setup(void)
|
||||||
{
|
{
|
||||||
gCatena.begin();
|
gCatena.begin();
|
||||||
|
|
@ -251,7 +246,6 @@ void setup_platform(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
gLoRaWAN.SetReceiveBufferBufferCb(receiveMessage);
|
gLoRaWAN.SetReceiveBufferBufferCb(receiveMessage);
|
||||||
setTxCycleTime(CATCFG_T_CYCLE_INITIAL, CATCFG_INTERVAL_COUNT_INITIAL);
|
|
||||||
gCatena.registerObject(&gLoRaWAN);
|
gCatena.registerObject(&gLoRaWAN);
|
||||||
|
|
||||||
/* find the platform */
|
/* find the platform */
|
||||||
|
|
@ -346,6 +340,9 @@ void setup_uplink(void)
|
||||||
|
|
||||||
LMIC_setClockError(1 * 65536 / 100);
|
LMIC_setClockError(1 * 65536 / 100);
|
||||||
|
|
||||||
|
// explicitly enable LinkCheckMode
|
||||||
|
gLoRaWAN.SetLinkCheckMode(true);
|
||||||
|
|
||||||
/* figure out when to reboot */
|
/* figure out when to reboot */
|
||||||
gRebootMs = (CATCFG_T_REBOOT + os_getRndU2() - 32768) * 1000;
|
gRebootMs = (CATCFG_T_REBOOT + os_getRndU2() - 32768) * 1000;
|
||||||
|
|
||||||
|
|
@ -925,30 +922,6 @@ void doSleepAlert(const bool fDeepSleep)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
{
|
{
|
||||||
|
|
@ -966,9 +939,6 @@ static void settleDoneCb(
|
||||||
|
|
||||||
doSleepAlert(fDeepSleep);
|
doSleepAlert(fDeepSleep);
|
||||||
|
|
||||||
/* count what we're up to */
|
|
||||||
updateSleepCounters();
|
|
||||||
|
|
||||||
send_in_progress = false;
|
send_in_progress = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1005,8 +975,6 @@ static void startNewIterationCb(osjob_t* pJob)
|
||||||
|
|
||||||
static void receiveMessage(void *pContext, uint8_t port, const uint8_t *pMessage, size_t nMessage)
|
static void receiveMessage(void *pContext, uint8_t port, const uint8_t *pMessage, size_t nMessage)
|
||||||
{
|
{
|
||||||
unsigned txCycle;
|
|
||||||
unsigned txCount;
|
|
||||||
|
|
||||||
long cal_w1_0;
|
long cal_w1_0;
|
||||||
long cal_w2_0;
|
long cal_w2_0;
|
||||||
|
|
@ -1122,59 +1090,8 @@ static void receiveMessage(void *pContext, uint8_t port, const uint8_t *pMessage
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (port == 0)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
else if (! (port == 1 && 2 <= nMessage && nMessage <= 3))
|
|
||||||
{
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("invalid message port(%02x)/length(%x)\n",
|
|
||||||
port, nMessage
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
txCycle = (pMessage[0] << 8) | pMessage[1];
|
|
||||||
|
|
||||||
if (txCycle < CATCFG_T_MIN || txCycle > CATCFG_T_MAX)
|
|
||||||
{
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("tx cycle time out of range: %u\n", txCycle);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// byte [2], if present, is the repeat count.
|
|
||||||
// explicitly sending zero causes it to stick.
|
|
||||||
txCount = CATCFG_INTERVAL_COUNT;
|
|
||||||
if (nMessage >= 3)
|
|
||||||
{
|
|
||||||
txCount = pMessage[2];
|
|
||||||
}
|
|
||||||
|
|
||||||
setTxCycleTime(txCycle, txCount);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void setTxCycleTime(unsigned txCycle, unsigned txCount)
|
|
||||||
{
|
|
||||||
if (txCount > 0) {
|
|
||||||
if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("message cycle time %u seconds for %u messages\n", txCycle, txCount);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (config_data.debug_level > 0) {
|
|
||||||
gCatena.SafePrintf("message cycle time %u seconds indefinitely\n", txCycle);
|
|
||||||
}
|
|
||||||
|
|
||||||
gTxCycle = txCycle;
|
|
||||||
gTxCycleCount = txCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* process "application hello" -- args are ignored */
|
/* process "application hello" -- args are ignored */
|
||||||
// argv[0] is "hello"
|
// argv[0] is "hello"
|
||||||
// argv[1..argc-1] are the (ignored) arguments
|
// argv[1..argc-1] are the (ignored) arguments
|
||||||
|
|
|
||||||
|
|
@ -56,7 +56,7 @@ enum {
|
||||||
|
|
|
|
||||||
\****************************************************************************/
|
\****************************************************************************/
|
||||||
|
|
||||||
static const int32_t fwVersion = 20200603;
|
static const int32_t fwVersion = 20200604;
|
||||||
|
|
||||||
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