2021-03-17 14:49:07 +01:00
|
|
|
#ifndef SEQUENCENUMBER_H
|
|
|
|
#define SEQUENCENUMBER_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
// mask for sequence numbers (2^24 - 1)
|
|
|
|
#define SN_MASK 16777215
|
|
|
|
|
|
|
|
typedef uint32_t record_sequence_number_t;
|
|
|
|
|
2021-03-23 18:11:11 +01:00
|
|
|
/**
|
|
|
|
* Mask a given sequence number to get rid of MSB.
|
|
|
|
* TODO: maybe as #define?
|
|
|
|
*
|
|
|
|
* @param sn sequence number to mask
|
|
|
|
* @return masked sequence number
|
|
|
|
*/
|
|
|
|
record_sequence_number_t sn_mask(record_sequence_number_t sn);
|
|
|
|
|
2021-03-17 14:49:07 +01:00
|
|
|
/**
|
|
|
|
* Compare to sequence numbers for equality.
|
|
|
|
*
|
|
|
|
* @param a first sequence number
|
|
|
|
* @param b second sequence number
|
|
|
|
* @return 1, if sequence numbers are equal, 0 otherwise.
|
|
|
|
*/
|
2021-03-24 15:52:02 +01:00
|
|
|
int sn_equal(record_sequence_number_t a, record_sequence_number_t b);
|
2021-03-17 14:49:07 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Increment the given sequence number. Wraps around, if 2^24 is reached.
|
|
|
|
*
|
|
|
|
* @param sn sequence number to increment
|
|
|
|
* @return the incremented sequenced number
|
|
|
|
*/
|
2021-03-24 15:52:02 +01:00
|
|
|
record_sequence_number_t sn_increment(record_sequence_number_t sn);
|
2021-03-17 14:49:07 +01:00
|
|
|
#endif
|