Browse Source

rpn: sleep and rtcmem ops (#2366)

mcspr-patch-1
Max Prokhorov 4 years ago
committed by GitHub
parent
commit
da501a6bfa
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 113 additions and 1 deletions
  1. +102
    -1
      code/espurna/rpnrules.cpp
  2. +1
    -0
      code/espurna/system.cpp
  3. +8
    -0
      code/espurna/wifi.cpp
  4. +2
    -0
      code/espurna/wifi.h

+ 102
- 1
code/espurna/rpnrules.cpp View File

@ -14,10 +14,12 @@ Copyright (C) 2019 by Xose Pérez <xose dot perez at gmail dot com>
#include "mqtt.h"
#include "ntp.h"
#include "relay.h"
#include "rfbridge.h"
#include "rpc.h"
#include "rtcmem.h"
#include "sensor.h"
#include "rfbridge.h"
#include "terminal.h"
#include "wifi.h"
#include "ws.h"
#include <list>
@ -622,6 +624,100 @@ void _rpnInit() {
});
#endif
rpn_operator_set(_rpn_ctxt, "mem?", 0, [](rpn_context & ctxt) -> rpn_error {
rpn_stack_push(ctxt, rpn_value(rtcmemStatus()));
return 0;
});
rpn_operator_set(_rpn_ctxt, "mem_write", 2, [](rpn_context & ctxt) -> rpn_error {
auto addr = rpn_stack_pop(ctxt).toUint();
auto value = rpn_stack_pop(ctxt).toUint();
if (addr < RTCMEM_BLOCKS) {
auto* rtcmem = reinterpret_cast<volatile uint32_t*>(RTCMEM_ADDR);
*(rtcmem + addr) = value;
return 0;
}
return rpn_operator_error::InvalidArgument;
});
rpn_operator_set(_rpn_ctxt, "mem_read", 1, [](rpn_context & ctxt) -> rpn_error {
auto addr = rpn_stack_pop(ctxt).toUint();
if (addr < RTCMEM_BLOCKS) {
auto* rtcmem = reinterpret_cast<volatile uint32_t*>(RTCMEM_ADDR);
rpn_uint result = *(rtcmem + addr);
rpn_stack_push(ctxt, rpn_value(result));
return 0;
}
return rpn_operator_error::InvalidArgument;
});
rpn_operator_set(_rpn_ctxt, "sleep", 2, [](rpn_context & ctxt) -> rpn_error {
static bool once { false };
if (once) return rpn_operator_error::CannotContinue;
auto value = rpn_stack_pop(ctxt).checkedToUint();
if (!value.ok()) {
return value.error();
}
uint64_t duration = value.value();
if (!duration) {
return rpn_operator_error::CannotContinue;
}
auto mode = rpn_stack_pop(ctxt).toUint();
once = true;
schedule_function([duration, mode]() {
wifiTurnOff();
ESP.deepSleep(duration * 1000000ull, static_cast<RFMode>(mode));
});
return 0;
});
rpn_operator_set(_rpn_ctxt, "stations", 0, [](rpn_context & ctxt) -> rpn_error {
if (!(WiFi.getMode() & WIFI_AP)) return rpn_operator_error::CannotContinue;
rpn_stack_push(ctxt, rpn_value(static_cast<rpn_uint>(WiFi.softAPgetStationNum())));
return 0;
});
rpn_operator_set(_rpn_ctxt, "disconnect", 0, [](rpn_context & ctxt) -> rpn_error {
wifiDisconnect();
return 0;
});
rpn_operator_set(_rpn_ctxt, "rssi", 0, [](rpn_context & ctxt) -> rpn_error {
if (!wifiConnected()) return rpn_operator_error::CannotContinue;
rpn_stack_push(ctxt, rpn_value(static_cast<rpn_int>(WiFi.RSSI())));
return 0;
});
rpn_operator_set(_rpn_ctxt, "delay", 1, [](rpn_context & ctxt) -> rpn_error {
auto ms = rpn_stack_pop(ctxt);
delay(ms.toUint());
return 0;
});
rpn_operator_set(_rpn_ctxt, "yield", 0, [](rpn_context & ctxt) -> rpn_error {
yield();
return 0;
});
rpn_operator_set(_rpn_ctxt, "reset", 0, [](rpn_context & ctxt) -> rpn_error {
static bool once = ([]() {
deferredReset(100, CUSTOM_RESET_TERMINAL);
return true;
})();
return once
? rpn_operator_error::CannotContinue
: rpn_operator_error::Ok;
});
rpn_operator_set(_rpn_ctxt, "millis", 0, [](rpn_context & ctxt) -> rpn_error {
rpn_stack_push(ctxt, rpn_value(static_cast<uint32_t>(millis())));
return 0;
@ -637,6 +733,11 @@ void _rpnInit() {
return _rpnRunnerHandler(ctxt, RpnRunner::Policy::Periodic, every.toUint());
});
// XXX: workaround for the vector 2x growth on push. will need to fix this in the rpnlib
_rpn_ctxt.operators.shrink_to_fit();
DEBUG_MSG_P(PSTR("[RPN] Registered %u operators\n"), _rpn_ctxt.operators.size());
}
#if TERMINAL_SUPPORT


+ 1
- 0
code/espurna/system.cpp View File

@ -186,6 +186,7 @@ void systemLoop() {
if (checkNeedsReset()) {
reset();
return;
}
// -------------------------------------------------------------------------


+ 8
- 0
code/espurna/wifi.cpp View File

@ -748,6 +748,14 @@ WiFiApMode wifiApMode() {
return _wifi_ap_mode;
}
void wifiTurnOff() {
jw.turnOff();
}
void wifiTurnOn() {
jw.turnOn();
}
// -----------------------------------------------------------------------------
// INITIALIZATION
// -----------------------------------------------------------------------------


+ 2
- 0
code/espurna/wifi.h View File

@ -62,6 +62,8 @@ WiFiApMode wifiApMode();
void wifiStartAP();
void wifiStartSTA();
void wifiDisconnect();
void wifiTurnOff();
void wifiTurnOn();
void wifiStartWPS();
void wifiStartSmartConfig();


Loading…
Cancel
Save