mongoose/examples/pico-sdk/pico-rndis-dashboard/main.c

82 lines
2.2 KiB
C
Raw Normal View History

2023-01-03 03:49:15 +08:00
// Copyright (c) 2022 Cesanta Software Limited
// All rights reserved
#include "mongoose.h"
2023-05-27 01:43:36 +08:00
#include "net.h"
2023-01-03 03:49:15 +08:00
#include "pico/stdlib.h"
2023-01-21 21:42:25 +08:00
#include "tusb.h"
2023-01-03 03:49:15 +08:00
static struct mg_tcpip_if *s_ifp;
2023-01-03 03:49:15 +08:00
const uint8_t tud_network_mac_address[6] = {2, 2, 0x84, 0x6A, 0x96, 0};
static void blink_cb(void *arg) { // Blink periodically
gpio_put(PICO_DEFAULT_LED_PIN, !gpio_get_out_level(PICO_DEFAULT_LED_PIN));
(void) arg;
}
bool tud_network_recv_cb(const uint8_t *buf, uint16_t len) {
mg_tcpip_qwrite((void *) buf, len, s_ifp);
2023-01-03 03:49:15 +08:00
// MG_INFO(("RECV %hu", len));
// mg_hexdump(buf, len);
tud_network_recv_renew();
return true;
}
2023-01-21 21:42:25 +08:00
void tud_network_init_cb(void) {}
2023-01-03 03:49:15 +08:00
uint16_t tud_network_xmit_cb(uint8_t *dst, void *ref, uint16_t arg) {
// MG_INFO(("SEND %hu", arg));
memcpy(dst, ref, arg);
return arg;
}
static size_t usb_tx(const void *buf, size_t len, struct mg_tcpip_if *ifp) {
2023-01-03 03:49:15 +08:00
if (!tud_ready()) return 0;
while (!tud_network_can_xmit(len)) tud_task();
tud_network_xmit((void *) buf, len);
(void) ifp;
return len;
}
static bool usb_up(struct mg_tcpip_if *ifp) {
2023-01-03 03:49:15 +08:00
(void) ifp;
return tud_inited() && tud_ready() && tud_connected();
}
2023-01-21 21:42:25 +08:00
static void fn(struct mg_connection *c, int ev, void *ev_data, void *fn_dta) {
if (ev == MG_EV_HTTP_MSG) return mg_http_reply(c, 200, "", "ok\n");
}
2023-01-03 03:49:15 +08:00
int main(void) {
2023-01-21 21:42:25 +08:00
gpio_init(PICO_DEFAULT_LED_PIN);
gpio_set_dir(PICO_DEFAULT_LED_PIN, GPIO_OUT);
stdio_init_all();
2023-01-03 03:49:15 +08:00
2023-01-21 21:42:25 +08:00
struct mg_mgr mgr; // Initialise Mongoose event manager
mg_mgr_init(&mgr); // and attach it to the interface
2023-01-03 03:49:15 +08:00
mg_timer_add(&mgr, 500, MG_TIMER_REPEAT, blink_cb, &mgr);
2023-02-27 22:28:42 +08:00
struct mg_tcpip_driver driver = {.tx = usb_tx, .up = usb_up};
struct mg_tcpip_if mif = {.mac = {2, 0, 1, 2, 3, 0x77},
2023-01-03 03:49:15 +08:00
.ip = mg_htonl(MG_U32(192, 168, 3, 1)),
.mask = mg_htonl(MG_U32(255, 255, 255, 0)),
.enable_dhcp_server = true,
.driver = &driver,
2023-02-27 22:28:42 +08:00
.recv_queue.size = 4096};
2023-01-03 03:49:15 +08:00
s_ifp = &mif;
mg_tcpip_init(&mgr, &mif);
2023-01-03 03:49:15 +08:00
tusb_init();
2023-01-21 21:42:25 +08:00
MG_INFO(("Initialising application..."));
2023-05-27 01:43:36 +08:00
web_init(&mgr);
2023-01-21 21:42:25 +08:00
MG_INFO(("Starting event loop"));
2023-01-03 03:49:15 +08:00
for (;;) {
mg_mgr_poll(&mgr, 0);
tud_task();
}
return 0;
}