mirror of
https://github.com/espressif/esp-protocols.git
synced 2025-07-17 12:32:14 +02:00
added scope lock
This commit is contained in:
@ -294,10 +294,10 @@ static void modem_test_app(esp_modem_dte_config_t *dte_config, esp_modem_dce_con
|
|||||||
|
|
||||||
std::string apn = "internet";
|
std::string apn = "internet";
|
||||||
auto device = create_device(uart_dte, apn);
|
auto device = create_device(uart_dte, apn);
|
||||||
// bool pin_ok = true;
|
bool pin_ok = true;
|
||||||
// if (device->read_pin(pin_ok) == command_result::OK && !pin_ok) {
|
if (device->read_pin(pin_ok) == command_result::OK && !pin_ok) {
|
||||||
// throw_if_false(device->set_pin("1234") == command_result::OK, "Cannot set PIN!");
|
throw_if_false(device->set_pin("1234") == command_result::OK, "Cannot set PIN!");
|
||||||
// }
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// std::string number;
|
// std::string number;
|
||||||
@ -315,17 +315,16 @@ static void modem_test_app(esp_modem_dte_config_t *dte_config, esp_modem_dce_con
|
|||||||
auto my_dce = create_dce(uart_dte, device, esp_netif);
|
auto my_dce = create_dce(uart_dte, device, esp_netif);
|
||||||
|
|
||||||
// return;
|
// return;
|
||||||
my_dce->set_cmux();
|
// my_dce->set_cmux();
|
||||||
// my_dce->set_cmux();
|
// my_dce->set_cmux();
|
||||||
|
|
||||||
while (1) {
|
// while (1) {
|
||||||
vTaskDelay(pdMS_TO_TICKS(1000));
|
// vTaskDelay(pdMS_TO_TICKS(1000));
|
||||||
// uart_dte->send_cmux_command(1, "AT+CPIN?\r");
|
// uart_dte->write((uint8_t*)"AT+CPIN?\r", 9);
|
||||||
uart_dte->write((uint8_t*)"AT+CPIN?\r", 9);
|
//
|
||||||
|
// }
|
||||||
}
|
|
||||||
// uart_dte->send_cmux_command(2, "AT+CPIN?");
|
// uart_dte->send_cmux_command(2, "AT+CPIN?");
|
||||||
return;
|
// return;
|
||||||
|
|
||||||
my_dce->command("AT+CPIN?\r", [&](uint8_t *data, size_t len) {
|
my_dce->command("AT+CPIN?\r", [&](uint8_t *data, size_t len) {
|
||||||
std::string response((char*)data, len);
|
std::string response((char*)data, len);
|
||||||
|
@ -39,7 +39,7 @@ enum class cmux_state {
|
|||||||
HEADER,
|
HEADER,
|
||||||
PAYLOAD,
|
PAYLOAD,
|
||||||
FOOTER,
|
FOOTER,
|
||||||
|
RECOVER,
|
||||||
};
|
};
|
||||||
|
|
||||||
class CMUXedTerminal: public Terminal {
|
class CMUXedTerminal: public Terminal {
|
||||||
@ -67,7 +67,6 @@ private:
|
|||||||
size_t consumed;
|
size_t consumed;
|
||||||
std::unique_ptr<uint8_t[]> buffer;
|
std::unique_ptr<uint8_t[]> buffer;
|
||||||
bool on_cmux(size_t len);
|
bool on_cmux(size_t len);
|
||||||
static bool s_on_cmux(size_t len);
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -96,26 +95,6 @@ struct CMUXHelper {
|
|||||||
|
|
||||||
typedef std::function<command_result(uint8_t *data, size_t len)> got_line_cb;
|
typedef std::function<command_result(uint8_t *data, size_t len)> got_line_cb;
|
||||||
|
|
||||||
//class CMUX {
|
|
||||||
//public:
|
|
||||||
// void setup_cmux();
|
|
||||||
// void send_sabm(size_t dlci);
|
|
||||||
//
|
|
||||||
// bool on_cmux(size_t len);
|
|
||||||
// static bool s_on_cmux(size_t len);
|
|
||||||
// cmux_state state;
|
|
||||||
// uint8_t dlci;
|
|
||||||
// uint8_t type;
|
|
||||||
// size_t payload_len;
|
|
||||||
// uint8_t frame_header[6];
|
|
||||||
// size_t frame_header_offset;
|
|
||||||
// size_t buffer_size;
|
|
||||||
// size_t consumed;
|
|
||||||
//// std::shared_ptr<std::vector<uint8_t>> buffer;
|
|
||||||
// std::unique_ptr<uint8_t[]> buffer;
|
|
||||||
//
|
|
||||||
//};
|
|
||||||
|
|
||||||
class DTE {
|
class DTE {
|
||||||
public:
|
public:
|
||||||
explicit DTE(std::unique_ptr<Terminal> t);
|
explicit DTE(std::unique_ptr<Terminal> t);
|
||||||
@ -154,6 +133,7 @@ public:
|
|||||||
|
|
||||||
void send_cmux_command(uint8_t i, const std::string& command);
|
void send_cmux_command(uint8_t i, const std::string& command);
|
||||||
private:
|
private:
|
||||||
|
Lock lock;
|
||||||
// std::unique_ptr<CMUXedTerminal> cmux;
|
// std::unique_ptr<CMUXedTerminal> cmux;
|
||||||
void setup_cmux();
|
void setup_cmux();
|
||||||
// void send_sabm(size_t dlci);
|
// void send_sabm(size_t dlci);
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
#define SIMPLE_CXX_CLIENT_TERMINAL_OBJECTS_HPP
|
#define SIMPLE_CXX_CLIENT_TERMINAL_OBJECTS_HPP
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
#include "freertos/event_groups.h"
|
#include "freertos/event_groups.h"
|
||||||
|
#include "freertos/semphr.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class esp_err_exception: virtual public std::exception {
|
class esp_err_exception: virtual public std::exception {
|
||||||
@ -44,6 +46,29 @@ static inline void throw_if_esp_fail(esp_err_t err)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct Lock {
|
||||||
|
explicit Lock(): lock(nullptr)
|
||||||
|
{
|
||||||
|
lock = xSemaphoreCreateMutex();
|
||||||
|
throw_if_false(lock != nullptr, "create signal event group failed");
|
||||||
|
}
|
||||||
|
~Lock() { vSemaphoreDelete(lock); }
|
||||||
|
void take() { xSemaphoreTake(lock, portMAX_DELAY); }
|
||||||
|
|
||||||
|
void give() { xSemaphoreGive(lock); }
|
||||||
|
xSemaphoreHandle lock;
|
||||||
|
};
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
class Scoped {
|
||||||
|
public:
|
||||||
|
explicit Scoped(T &l):lock(l) { lock.take(); }
|
||||||
|
~Scoped() { lock.give(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
T& lock;
|
||||||
|
};
|
||||||
|
|
||||||
struct signal_group {
|
struct signal_group {
|
||||||
explicit signal_group(): event_group(nullptr)
|
explicit signal_group(): event_group(nullptr)
|
||||||
{
|
{
|
||||||
|
@ -94,13 +94,6 @@ bool CMUXedTerminal::process_cmux_recv(size_t len)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static CMUXedTerminal * s_cmux;
|
|
||||||
bool CMUXedTerminal::s_on_cmux(size_t len)
|
|
||||||
{
|
|
||||||
s_cmux->on_cmux(len);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool output(uint8_t *data, size_t len, std::string message)
|
bool output(uint8_t *data, size_t len, std::string message)
|
||||||
{
|
{
|
||||||
printf("OUTPUT: %s len=%d \n", message.c_str(), len);
|
printf("OUTPUT: %s len=%d \n", message.c_str(), len);
|
||||||
@ -130,6 +123,9 @@ bool CMUXedTerminal::on_cmux(size_t len)
|
|||||||
size_t footer_offset = 0;
|
size_t footer_offset = 0;
|
||||||
while (available_len > 0) {
|
while (available_len > 0) {
|
||||||
switch (state) {
|
switch (state) {
|
||||||
|
case cmux_state::RECOVER:
|
||||||
|
// TODO: Implement recovery, looking for SOF_MARKER's
|
||||||
|
break;
|
||||||
case cmux_state::INIT:
|
case cmux_state::INIT:
|
||||||
if (frame[0] != SOF_MARKER) {
|
if (frame[0] != SOF_MARKER) {
|
||||||
ESP_LOGW("CMUX", "TODO: Recover!");
|
ESP_LOGW("CMUX", "TODO: Recover!");
|
||||||
@ -199,10 +195,12 @@ bool CMUXedTerminal::on_cmux(size_t len)
|
|||||||
}
|
}
|
||||||
void CMUXedTerminal::setup_cmux()
|
void CMUXedTerminal::setup_cmux()
|
||||||
{
|
{
|
||||||
s_cmux = this;
|
|
||||||
frame_header_offset = 0;
|
frame_header_offset = 0;
|
||||||
state = cmux_state::INIT;
|
state = cmux_state::INIT;
|
||||||
term->set_data_cb(s_on_cmux);
|
term->set_data_cb([this](size_t len){
|
||||||
|
this->on_cmux(len);
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
for (size_t i = 0; i < 3; i++)
|
for (size_t i = 0; i < 3; i++)
|
||||||
{
|
{
|
||||||
|
@ -9,6 +9,7 @@ DTE::DTE(std::unique_ptr<Terminal> terminal):
|
|||||||
|
|
||||||
command_result DTE::command(const std::string& command, got_line_cb got_line, uint32_t time_ms)
|
command_result DTE::command(const std::string& command, got_line_cb got_line, uint32_t time_ms)
|
||||||
{
|
{
|
||||||
|
Scoped<Lock> l(lock);
|
||||||
command_result res = command_result::TIMEOUT;
|
command_result res = command_result::TIMEOUT;
|
||||||
term->write((uint8_t *)command.c_str(), command.length());
|
term->write((uint8_t *)command.c_str(), command.length());
|
||||||
term->set_data_cb([&](size_t len){
|
term->set_data_cb([&](size_t len){
|
||||||
|
@ -88,7 +88,7 @@ PPP::PPP(std::shared_ptr<DTE> e, esp_netif_t *ppp_netif):
|
|||||||
|
|
||||||
void PPP::start()
|
void PPP::start()
|
||||||
{
|
{
|
||||||
ppp_dte->set_data_cb([&](size_t len) -> bool {
|
ppp_dte->set_data_cb([this](size_t len) -> bool {
|
||||||
uint8_t *data;
|
uint8_t *data;
|
||||||
auto actual_len = ppp_dte->read(&data, len);
|
auto actual_len = ppp_dte->read(&data, len);
|
||||||
receive(data, actual_len);
|
receive(data, actual_len);
|
||||||
|
Reference in New Issue
Block a user