AP_Networking: allow for PPP on ChibiOS

This commit is contained in:
Andrew Tridgell 2023-12-26 06:27:13 +11:00
parent 94ea22d16f
commit 1d9d599bb0
4 changed files with 41 additions and 16 deletions

View File

@ -21,22 +21,25 @@
// Backends // Backends
// --------------------------- // ---------------------------
#ifndef AP_NETWORKING_BACKEND_CHIBIOS #ifndef AP_NETWORKING_BACKEND_CHIBIOS
#define AP_NETWORKING_BACKEND_CHIBIOS (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS)) #ifndef HAL_USE_MAC
#define HAL_USE_MAC 0
#endif
#define AP_NETWORKING_BACKEND_CHIBIOS (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS) && HAL_USE_MAC)
#endif #endif
#ifndef AP_NETWORKING_BACKEND_PPP #ifndef AP_NETWORKING_BACKEND_PPP
#define AP_NETWORKING_BACKEND_PPP (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS)) #define AP_NETWORKING_BACKEND_PPP (AP_NETWORKING_BACKEND_DEFAULT_ENABLED)
#endif #endif
#ifndef AP_NETWORKING_BACKEND_SLIP #ifndef AP_NETWORKING_BACKEND_SLIP
#define AP_NETWORKING_BACKEND_SLIP (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS)) #define AP_NETWORKING_BACKEND_SLIP 0
#endif #endif
#ifndef AP_NETWORKING_BACKEND_SITL #ifndef AP_NETWORKING_BACKEND_SITL
#define AP_NETWORKING_BACKEND_SITL (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_SITL)) #define AP_NETWORKING_BACKEND_SITL (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_SITL))
#endif #endif
#define AP_NETWORKING_SOCKETS_ENABLED (HAL_OS_SOCKETS || AP_NETWORKING_BACKEND_CHIBIOS) #define AP_NETWORKING_SOCKETS_ENABLED AP_NETWORKING_ENABLED
// --------------------------- // ---------------------------
// IP Features // IP Features

View File

@ -6,7 +6,6 @@
#include "AP_Networking_PPP.h" #include "AP_Networking_PPP.h"
#include <GCS_MAVLink/GCS.h> #include <GCS_MAVLink/GCS.h>
#include <lwipthread.h>
#include <lwip/udp.h> #include <lwip/udp.h>
#include <lwip/ip_addr.h> #include <lwip/ip_addr.h>
#include <netif/ppp/ppp_opts.h> #include <netif/ppp/ppp_opts.h>
@ -17,6 +16,7 @@
extern const AP_HAL::HAL& hal; extern const AP_HAL::HAL& hal;
#if CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS
/* /*
uint32_t timestamp in smallest available units uint32_t timestamp in smallest available units
*/ */
@ -24,6 +24,15 @@ uint32_t sys_jiffies(void)
{ {
return AP_HAL::micros(); return AP_HAL::micros();
} }
#endif
#if LWIP_TCPIP_CORE_LOCKING
#define LWIP_TCPIP_LOCK() sys_lock_tcpip_core()
#define LWIP_TCPIP_UNLOCK() sys_unlock_tcpip_core()
#else
#define LWIP_TCPIP_LOCK()
#define LWIP_TCPIP_UNLOCK()
#endif
/* /*
output some data to the uart output some data to the uart
@ -39,8 +48,6 @@ uint32_t AP_Networking_PPP::ppp_output_cb(ppp_pcb *pcb, const void *data, uint32
if (n > 0) { if (n > 0) {
remaining -= n; remaining -= n;
ptr += n; ptr += n;
} else {
hal.scheduler->delay_microseconds(100);
} }
} }
return len; return len;
@ -137,24 +144,26 @@ bool AP_Networking_PPP::init()
} }
// initialise TCP/IP thread // initialise TCP/IP thread
LWIP_TCPIP_LOCK();
tcpip_init(NULL, NULL); tcpip_init(NULL, NULL);
LWIP_TCPIP_UNLOCK();
hal.scheduler->delay(100); hal.scheduler->delay(100);
// create ppp connection // create ppp connection
LWIP_TCPIP_LOCK();
ppp = pppos_create(pppif, ppp_output_cb, ppp_status_callback, this); ppp = pppos_create(pppif, ppp_output_cb, ppp_status_callback, this);
if (ppp == nullptr) { if (ppp == nullptr) {
GCS_SEND_TEXT(MAV_SEVERITY_INFO, "PPP: failed to create link"); GCS_SEND_TEXT(MAV_SEVERITY_INFO, "PPP: failed to create link");
return false; return false;
} }
LWIP_TCPIP_UNLOCK();
// connect and set as default route
ppp_connect(ppp, 0);
netif_set_default(pppif);
GCS_SEND_TEXT(MAV_SEVERITY_INFO, "PPP: started"); GCS_SEND_TEXT(MAV_SEVERITY_INFO, "PPP: started");
hal.scheduler->thread_create(FUNCTOR_BIND_MEMBER(&AP_Networking_PPP::ppp_loop, void), hal.scheduler->thread_create(FUNCTOR_BIND_MEMBER(&AP_Networking_PPP::ppp_loop, void),
"ppp", "ppp",
8192, AP_HAL::Scheduler::PRIORITY_UART, 0); 2048, AP_HAL::Scheduler::PRIORITY_UART, 0);
return true; return true;
} }
@ -164,6 +173,17 @@ bool AP_Networking_PPP::init()
*/ */
void AP_Networking_PPP::ppp_loop(void) void AP_Networking_PPP::ppp_loop(void)
{ {
while (!hal.scheduler->is_system_initialized()) {
hal.scheduler->delay_microseconds(1000);
}
// connect and set as default route
LWIP_TCPIP_LOCK();
ppp_connect(ppp, 0);
netif_set_default(pppif);
LWIP_TCPIP_UNLOCK();
// ensure this thread owns the uart // ensure this thread owns the uart
uart->begin(0); uart->begin(0);
@ -171,9 +191,12 @@ void AP_Networking_PPP::ppp_loop(void)
uint8_t buf[1024]; uint8_t buf[1024];
auto n = uart->read(buf, sizeof(buf)); auto n = uart->read(buf, sizeof(buf));
if (n > 0) { if (n > 0) {
LWIP_TCPIP_LOCK();
pppos_input(ppp, buf, n); pppos_input(ppp, buf, n);
} else { LWIP_TCPIP_UNLOCK();
hal.scheduler->delay_microseconds(100); hal.scheduler->delay_microseconds(100);
} else {
hal.scheduler->delay_microseconds(1000);
} }
} }
} }

View File

@ -6,7 +6,6 @@
#include "AP_Networking_SLIP.h" #include "AP_Networking_SLIP.h"
#include <GCS_MAVLink/GCS.h> #include <GCS_MAVLink/GCS.h>
#include <lwipthread.h>
#include <lwip/udp.h> #include <lwip/udp.h>
#include <lwip/ip_addr.h> #include <lwip/ip_addr.h>
#include <lwip/sio.h> #include <lwip/sio.h>

View File

@ -8,6 +8,7 @@
#include <arpa/inet.h> #include <arpa/inet.h>
#include "AP_Networking.h" #include "AP_Networking.h"
#include <AP_HAL/utility/Socket.h>
const AP_Param::GroupInfo AP_Networking_IPV4::var_info[] = { const AP_Param::GroupInfo AP_Networking_IPV4::var_info[] = {
// @Param: 0 // @Param: 0
@ -72,8 +73,7 @@ void AP_Networking_IPV4::set_default_uint32(uint32_t v)
const char* AP_Networking_IPV4::get_str() const char* AP_Networking_IPV4::get_str()
{ {
const auto ip = ntohl(get_uint32()); const auto ip = ntohl(get_uint32());
inet_ntop(AF_INET, &ip, strbuf, sizeof(strbuf)); return SocketAPM::inet_addr_to_str(&ip, strbuf, sizeof(strbuf));
return strbuf;
} }
#endif // AP_NETWORKING_ENABLED #endif // AP_NETWORKING_ENABLED