2017-08-28 18:06:01 +02:00
|
|
|
#ifndef LIGHTNING_LIGHTNINGD_GOSSIP_BROADCAST_H
|
|
|
|
#define LIGHTNING_LIGHTNINGD_GOSSIP_BROADCAST_H
|
2017-01-26 22:47:52 +01:00
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <ccan/intmap/intmap.h>
|
|
|
|
#include <ccan/list/list.h>
|
|
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
#include <ccan/tal/tal.h>
|
|
|
|
|
|
|
|
/* Common functionality to implement staggered broadcasts with replacement. */
|
|
|
|
|
|
|
|
struct queued_message {
|
|
|
|
int type;
|
|
|
|
|
|
|
|
/* Unique tag specifying the msg origin */
|
|
|
|
void *tag;
|
|
|
|
|
|
|
|
/* Serialized payload */
|
|
|
|
u8 *payload;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct broadcast_state {
|
|
|
|
u32 next_index;
|
|
|
|
UINTMAP(struct queued_message *) broadcasts;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct broadcast_state *new_broadcast_state(tal_t *ctx);
|
|
|
|
|
2017-02-02 19:54:52 +01:00
|
|
|
/* Queue a new message to be broadcast and replace any outdated
|
|
|
|
* broadcast. Replacement is done by comparing the `type` and the
|
|
|
|
* `tag`, if both match the old message is dropped from the queue. The
|
|
|
|
* new message is added to the top of the broadcast queue. */
|
2017-01-26 22:47:52 +01:00
|
|
|
void queue_broadcast(struct broadcast_state *bstate,
|
|
|
|
const int type,
|
|
|
|
const u8 *tag,
|
|
|
|
const u8 *payload);
|
|
|
|
|
2017-12-11 04:16:50 +01:00
|
|
|
struct queued_message *next_broadcast_message(struct broadcast_state *bstate, u64 last_index);
|
2017-01-26 22:47:52 +01:00
|
|
|
|
2017-08-28 18:06:01 +02:00
|
|
|
#endif /* LIGHTNING_LIGHTNINGD_GOSSIP_BROADCAST_H */
|