X-Git-Url: http://git.scottworley.com/tattlekey/blobdiff_plain/a4a617fd9b53e294a057d1b01a6a8896658f2be3..f9625e91cfed21a65b720609ed1d8a7e7c0f36bd:/client/net.c diff --git a/client/net.c b/client/net.c index 6253d61..3d4be8c 100644 --- a/client/net.c +++ b/client/net.c @@ -20,6 +20,7 @@ #include "config.h" #include "pico/cyw43_arch.h" +#include "pico/rand.h" #include "lwip/pbuf.h" #include "lwip/udp.h" @@ -27,11 +28,14 @@ /* We only ever send to one address, and we only ever have one thread, so just * use one udp_pcb */ static struct udp_pcb *the_pcb = NULL; +static uint32_t epoch = 0; -static void initialize_the_pcb() { +static void net_local_init() { if (the_pcb) return; + new_epoch(); + the_pcb = udp_new(); if (!the_pcb) signal_error_by_blinking(); @@ -44,16 +48,19 @@ static void initialize_the_pcb() { signal_error_by_blinking(); } +void new_epoch() { epoch = get_rand_32(); } + struct tattle_message_wire_format { + u32_t epoch; u16_t sender; u16_t seq; - u16_t ago; + u32_t ago; }; -void send_report_packet(u16_t seq, u16_t ago) { +void send_report_packet(u16_t seq, u32_t ago) { cyw43_arch_lwip_begin(); - initialize_the_pcb(); + net_local_init(); struct pbuf *p = pbuf_alloc( PBUF_TRANSPORT, sizeof(struct tattle_message_wire_format), PBUF_RAM); @@ -62,9 +69,10 @@ void send_report_packet(u16_t seq, u16_t ago) { struct tattle_message_wire_format *msg = (struct tattle_message_wire_format *)(p->payload); + msg->epoch = htonl(epoch); msg->sender = htons(config_this_tattler_identity); msg->seq = htons(seq); - msg->ago = htons(ago); + msg->ago = htonl(ago); if (udp_send(the_pcb, p) != ERR_OK) signal_error_by_blinking();