X-Git-Url: http://git.scottworley.com/tattlekey/blobdiff_plain/9266b741959871619b5431a2b4e4ebdad5567a3d..e9fa253687e2ce7b932bd2f6dc72c696a806aaf2:/client/net.c?ds=inline diff --git a/client/net.c b/client/net.c index 1e0790e..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,7 +48,10 @@ 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; u32_t ago; @@ -53,7 +60,7 @@ struct tattle_message_wire_format { 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,6 +69,7 @@ void send_report_packet(u16_t seq, u32_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 = htonl(ago);