]> git.scottworley.com Git - tattlekey/blobdiff - client/net.c
Describe this project
[tattlekey] / client / net.c
index 6253d611aac776593d50e200b7284c9a9973d5ae..3d4be8cea998f707472740155a601ea912f46001 100644 (file)
@@ -20,6 +20,7 @@
 #include "config.h"
 
 #include "pico/cyw43_arch.h"
+#include "pico/rand.h"
 
 #include "lwip/pbuf.h"
 #include "lwip/udp.h"
 /* 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();