mirror of
https://github.com/espressif/esp-protocols.git
synced 2025-07-16 20:12:13 +02:00
cxx modem data mode working
This commit is contained in:
@ -277,17 +277,27 @@ static void modem_test_app(esp_modem_dte_config_t *dte_config, esp_modem_dce_con
|
|||||||
// std::cout << response << std::endl;
|
// std::cout << response << std::endl;
|
||||||
// return true;
|
// return true;
|
||||||
// }, 1000);
|
// }, 1000);
|
||||||
|
|
||||||
|
// return;
|
||||||
esp_netif_t *esp_netif = esp_netif_new(ppp_config);
|
esp_netif_t *esp_netif = esp_netif_new(ppp_config);
|
||||||
assert(esp_netif);
|
assert(esp_netif);
|
||||||
|
|
||||||
auto my_dce = create_dce(ddd, esp_netif);
|
auto my_dce = create_dce(ddd, esp_netif);
|
||||||
|
|
||||||
ddd->send_command("AT+COPS=?\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);
|
||||||
ESP_LOGI("in the lambda", "len=%d data %s", len, (char*)data);
|
ESP_LOGI("in the lambda", "len=%d data %s", len, (char*)data);
|
||||||
std::cout << response << std::endl;
|
std::cout << response << std::endl;
|
||||||
return true;
|
return true;
|
||||||
}, 60000);
|
}, 1000);
|
||||||
|
|
||||||
|
my_dce->set_data();
|
||||||
|
// ddd->send_command("AT+COPS=?\r", [&](uint8_t *data, size_t len) {
|
||||||
|
// std::string response((char*)data, len);
|
||||||
|
// ESP_LOGI("in the lambda", "len=%d data %s", len, (char*)data);
|
||||||
|
// std::cout << response << std::endl;
|
||||||
|
// return true;
|
||||||
|
// }, 60000);
|
||||||
|
|
||||||
// auto uart = create_uart_terminal(dte_config);
|
// auto uart = create_uart_terminal(dte_config);
|
||||||
// uart->set_data_cb([&](size_t len){
|
// uart->set_data_cb([&](size_t len){
|
||||||
|
@ -66,11 +66,23 @@ public:
|
|||||||
~dte() = default;
|
~dte() = default;
|
||||||
// void set_line_cb(got_line f) { on_line_cb = std::move(f); }
|
// void set_line_cb(got_line f) { on_line_cb = std::move(f); }
|
||||||
int write(uint8_t *data, size_t len) { return term->write(data, len); }
|
int write(uint8_t *data, size_t len) { return term->write(data, len); }
|
||||||
int read(uint8_t *data, size_t len) { return term->read(data, len); }
|
int read(uint8_t **d, size_t len) {
|
||||||
|
auto data_to_read = std::min(len, buffer_size);
|
||||||
|
auto data = buffer.get();
|
||||||
|
auto actual_len = term->read(data, data_to_read);
|
||||||
|
*d = data;
|
||||||
|
return actual_len;
|
||||||
|
}
|
||||||
|
void set_data_cb(std::function<void(size_t len)> f) { on_data = std::move(f); }
|
||||||
|
|
||||||
void start() { term->start(); }
|
void start() { term->start(); }
|
||||||
void data_mode_closed() { term->stop(); }
|
void data_mode_closed() { term->stop(); }
|
||||||
void set_mode(dte_mode m) { term->start(); mode = m; }
|
void set_mode(dte_mode m) {
|
||||||
|
term->start(); mode = m;
|
||||||
|
if (m == dte_mode::DATA_MODE) {
|
||||||
|
term->set_data_cb(on_data);
|
||||||
|
}
|
||||||
|
}
|
||||||
bool send_command(const std::string& command, got_line_cb got_line, uint32_t time_ms);
|
bool send_command(const std::string& command, got_line_cb got_line, uint32_t time_ms);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -82,14 +94,29 @@ private:
|
|||||||
got_line_cb on_line;
|
got_line_cb on_line;
|
||||||
dte_mode mode;
|
dte_mode mode;
|
||||||
signal_group signal;
|
signal_group signal;
|
||||||
|
std::function<void(size_t len)> on_data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class dce {
|
class dce {
|
||||||
public:
|
public:
|
||||||
explicit dce(std::shared_ptr<dte> d, esp_netif_t * netif);
|
explicit dce(std::shared_ptr<dte> d, esp_netif_t * netif);
|
||||||
|
void set_data() {
|
||||||
|
command("AT+CGDCONT=1,\"IP\",\"internet\"\r", [&](uint8_t *data, size_t len) {
|
||||||
|
return true;
|
||||||
|
}, 1000);
|
||||||
|
command("ATD*99***1#\r", [&](uint8_t *data, size_t len) {
|
||||||
|
return true;
|
||||||
|
}, 1000);
|
||||||
|
|
||||||
|
dce_dte->set_mode(dte_mode::DATA_MODE);
|
||||||
|
ppp_netif.start();
|
||||||
|
}
|
||||||
|
bool command(const std::string& command, got_line_cb got_line, uint32_t time_ms) {
|
||||||
|
return dce_dte->send_command(command, got_line, time_ms);
|
||||||
|
}
|
||||||
private:
|
private:
|
||||||
std::shared_ptr<dte> _dte;
|
std::shared_ptr<dte> dce_dte;
|
||||||
ppp ppp_netif;
|
ppp ppp_netif;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -20,9 +20,11 @@ class ppp {
|
|||||||
public:
|
public:
|
||||||
explicit ppp(std::shared_ptr<dte> e, esp_netif_t *netif);
|
explicit ppp(std::shared_ptr<dte> e, esp_netif_t *netif);
|
||||||
|
|
||||||
|
void start();
|
||||||
private:
|
private:
|
||||||
|
void receive(uint8_t *data, size_t len) const;
|
||||||
|
std::shared_ptr<dte> ppp_dte;
|
||||||
esp_netif_t *netif;
|
esp_netif_t *netif;
|
||||||
std::shared_ptr<dte> _dte;
|
|
||||||
struct ppp_netif_driver driver;
|
struct ppp_netif_driver driver;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -348,6 +348,6 @@ bool dte::send_command(const std::string& command, got_line_cb got_line, uint32_
|
|||||||
}
|
}
|
||||||
|
|
||||||
dce::dce(std::shared_ptr<dte> e, esp_netif_t * netif):
|
dce::dce(std::shared_ptr<dte> e, esp_netif_t * netif):
|
||||||
_dte(std::move(e)), ppp_netif(e, netif)
|
dce_dte(e), ppp_netif(e, netif)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@ static void on_ppp_changed(void *arg, esp_event_base_t event_base,
|
|||||||
int32_t event_id, void *event_data)
|
int32_t event_id, void *event_data)
|
||||||
{
|
{
|
||||||
dte *e = (dte*)arg;
|
dte *e = (dte*)arg;
|
||||||
|
ESP_LOGW("TAG", "PPP state changed event %d", event_id);
|
||||||
if (event_id < NETIF_PP_PHASE_OFFSET) {
|
if (event_id < NETIF_PP_PHASE_OFFSET) {
|
||||||
ESP_LOGI("TAG", "PPP state changed event %d", event_id);
|
ESP_LOGI("TAG", "PPP state changed event %d", event_id);
|
||||||
// only notify the modem on state/error events, ignoring phase transitions
|
// only notify the modem on state/error events, ignoring phase transitions
|
||||||
@ -35,10 +36,9 @@ static esp_err_t esp_modem_dte_transmit(void *h, void *buffer, size_t len)
|
|||||||
return ESP_FAIL;
|
return ESP_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static esp_err_t esp_modem_post_attach(esp_netif_t * esp_netif, void * args)
|
static esp_err_t esp_modem_post_attach(esp_netif_t * esp_netif, void * args)
|
||||||
{
|
{
|
||||||
ppp_netif_driver *d = (ppp_netif_driver*)args;
|
auto d = (ppp_netif_driver*)args;
|
||||||
esp_netif_driver_ifconfig_t driver_ifconfig = { };
|
esp_netif_driver_ifconfig_t driver_ifconfig = { };
|
||||||
driver_ifconfig.transmit = esp_modem_dte_transmit;
|
driver_ifconfig.transmit = esp_modem_dte_transmit;
|
||||||
driver_ifconfig.handle = (void*)d->e;
|
driver_ifconfig.handle = (void*)d->e;
|
||||||
@ -58,12 +58,26 @@ static esp_err_t esp_modem_post_attach(esp_netif_t * esp_netif, void * args)
|
|||||||
return ESP_OK;
|
return ESP_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ppp::receive(uint8_t *data, size_t len) const
|
||||||
|
{
|
||||||
|
esp_netif_receive(driver.base.netif, data, len, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
ppp::ppp(std::shared_ptr<dte> e, esp_netif_t *ppp_netif):
|
ppp::ppp(std::shared_ptr<dte> e, esp_netif_t *ppp_netif):
|
||||||
netif(ppp_netif), _dte(std::move(e))
|
ppp_dte(std::move(e)), netif(ppp_netif)
|
||||||
{
|
{
|
||||||
driver.base.netif = ppp_netif;
|
driver.base.netif = ppp_netif;
|
||||||
driver.e = this->_dte.get();
|
driver.e = this->ppp_dte.get();
|
||||||
driver.base.post_attach = esp_modem_post_attach;
|
driver.base.post_attach = esp_modem_post_attach;
|
||||||
|
ppp_dte->set_data_cb([&](size_t len){
|
||||||
|
uint8_t *data;
|
||||||
|
auto actual_len = ppp_dte->read(&data, len);
|
||||||
|
return receive(data, actual_len);
|
||||||
|
});
|
||||||
throw_if_esp_fail(esp_netif_attach(ppp_netif, &driver));
|
throw_if_esp_fail(esp_netif_attach(ppp_netif, &driver));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ppp::start()
|
||||||
|
{
|
||||||
|
esp_netif_action_start(driver.base.netif, 0, 0, 0);
|
||||||
|
}
|
Reference in New Issue
Block a user