DOKK / manpages / debian 12 / liblcrq0.0 / rq_pidsetesi.3.en
RQ_PID2SBN(3) Librecast Programmer's Manual RQ_PID2SBN(3)

rq_pid2sbn, rq_pid2esi, rq_pidsetsbn, rq_pidsetesi - get/set SBN,ESI in rq_pid_t

#include <lcrq.h>
uint8_t rq_pid2sbn(rq_pid_t pid);
uint32_t rq_pid2esi(rq_pid_t pid);
rq_pid_t rq_pidsetsbn(rq_pid_t pid, uint8_t sbn);
rq_pid_t rq_pidsetesi(rq_pid_t pid, uint32_t esi);

Compile and link with -llcrq.

Bitshifting macros for getting and setting the SBN and ESI bits of rq_pid_t.

0                   1                   2                   3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|     SBN       |               Encoding Symbol ID              |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

SBN (Source Block Number) is an 8 bit unsigned integer. The Encoding Symbol ID (ESI) is a 24 bit unsigned integer in network byte order.

rq_pid2sbn() and rq_pid2esi() return the uint8_t SBN and uint32_t ESI numbers respectively. rq_pidsetsbn() and rq_pidsetesi() both return rq_pid_t with the appropriate bits set.

These macros do not return errors.

#include <assert.h>
#include <lcrq.h>
int main(void)
{
	rq_pid_t pid = 0;
	uint32_t esi = 19;
	uint8_t sbn = 42;
	/* set SBN and ESI bits */
	pid = rq_pidsetsbn(pid, sbn);
	pid = rq_pidsetesi(pid, esi);
	/* make sure we can read them back */
	assert(sbn == rq_pid2sbn(pid));
	assert(esi == rq_pid2esi(pid));
	return 0;
}

rq_init(3), rq_free(3), rq_decode(3), rq_encode(3), rq_symbol(3), lcrq(7)

2022-07-15 LCRQ