Remove USB/serial support: network-only protocol, drop tinyusb and PICOBOOT
This commit is contained in:
@@ -1,9 +1,7 @@
|
||||
#include "dispatch.h"
|
||||
#include <unordered_map>
|
||||
#include "pico/stdlib.h"
|
||||
#include "tusb.h"
|
||||
#include "wire.h"
|
||||
#include "usb_cdc.h"
|
||||
#include "timer_queue.h"
|
||||
#include "net.h"
|
||||
#include "igmp.h"
|
||||
@@ -19,7 +17,6 @@ static void igmp_reannounce() {
|
||||
}
|
||||
|
||||
void dispatch_init() {
|
||||
tusb_init();
|
||||
net_init();
|
||||
dispatch_schedule_ms(60000, igmp_reannounce);
|
||||
dlog("dispatch_init complete");
|
||||
@@ -41,8 +38,6 @@ bool dispatch_cancel_timer(timer_handle h) {
|
||||
handler_map[entry.type_id] = entry.handle;
|
||||
}
|
||||
|
||||
static usb_cdc usb;
|
||||
static static_vector<uint8_t, 4096> usb_rx_buf;
|
||||
static std::array<uint8_t, 4096> tx_buf;
|
||||
|
||||
auto dispatch_msg = [&](const DecodedMessage& msg, send_fn send) {
|
||||
@@ -65,48 +60,9 @@ bool dispatch_cancel_timer(timer_handle h) {
|
||||
while (true) {
|
||||
uint32_t save = save_and_disable_interrupts();
|
||||
|
||||
dlog_if_slow("tud_task", 1000, [&]{ tud_task(); });
|
||||
dlog_if_slow("drain", 1000, [&]{ usb.drain(); });
|
||||
dlog_if_slow("timers", 1000, [&]{ timers.run(); });
|
||||
dlog_if_slow("net_poll", 1000, [&]{ net_poll(std::span{tx_buf}); });
|
||||
|
||||
while (tud_cdc_available()) {
|
||||
uint8_t byte;
|
||||
if (tud_cdc_read(&byte, 1) != 1) break;
|
||||
|
||||
usb_rx_buf.push_back(byte);
|
||||
|
||||
auto msg = try_decode(usb_rx_buf);
|
||||
if (!msg) {
|
||||
if (usb_rx_buf.full()) usb_rx_buf.clear();
|
||||
continue;
|
||||
}
|
||||
|
||||
dispatch_msg(*msg, [&](encode_fn encode) {
|
||||
uint8_t buf[4096];
|
||||
span_writer out(buf, sizeof(buf));
|
||||
auto r = encode(out);
|
||||
if (!r) return;
|
||||
std::span<const uint8_t> data{buf, *r};
|
||||
if (data.size() <= usb.tx.free()) {
|
||||
if (!usb.send(data))
|
||||
dlogf("usb send failed: %zu bytes, %u free", data.size(), usb.tx.free());
|
||||
} else {
|
||||
dlogf("usb response too large: %zu bytes, %u free", data.size(), usb.tx.free());
|
||||
uint8_t err_buf[256];
|
||||
span_writer err_out(err_buf, sizeof(err_buf));
|
||||
auto err = encode_response_into(err_out, msg->message_id,
|
||||
[&]{
|
||||
char m[48];
|
||||
snprintf(m, sizeof(m), "response too large: %zu", data.size());
|
||||
return DeviceError{2, m};
|
||||
}());
|
||||
if (err) usb.send(std::span<const uint8_t>{err_buf, *err});
|
||||
}
|
||||
});
|
||||
usb_rx_buf.clear();
|
||||
}
|
||||
|
||||
__wfi();
|
||||
restore_interrupts(save);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user