ROHC compression/decompression library
|
Compute the interpretation interval for LSB and W-LSB encoding. More...
#include <stdlib.h>
#include <stdint.h>
#include <assert.h>
Go to the source code of this file.
Data Structures | |
struct | rohc_interval8 |
An interval of 8-bit values. More... | |
struct | rohc_interval16 |
An interval of 16-bit values. More... | |
struct | rohc_interval32 |
An interval of 32-bit values. More... | |
Macros | |
#define | ROHC_LSB_SHIFT_TCP_TS_1B ROHC_LSB_SHIFT_SN |
#define | ROHC_LSB_SHIFT_TCP_TS_2B ROHC_LSB_SHIFT_SN |
#define | ROHC_LSB_SHIFT_TCP_ACK_SCALED ROHC_LSB_SHIFT_TCP_TTL |
Enumerations | |
enum | rohc_lsb_shift_t { ROHC_LSB_SHIFT_SN = -1, ROHC_LSB_SHIFT_IP_ID = 0, ROHC_LSB_SHIFT_TCP_TTL = 3, ROHC_LSB_SHIFT_TCP_SN = 4, ROHC_LSB_SHIFT_TCP_SEQ_SCALED = 7, ROHC_LSB_SHIFT_RTP_TS = 100, ROHC_LSB_SHIFT_RTP_SN = 101, ROHC_LSB_SHIFT_ESP_SN = 102, ROHC_LSB_SHIFT_VAR = 103, ROHC_LSB_SHIFT_TCP_WINDOW = 16383, ROHC_LSB_SHIFT_TCP_TS_3B = 0x00040000, ROHC_LSB_SHIFT_TCP_TS_4B = 0x04000000 } |
the different values of the shift parameter of the LSB algorithm More... | |
Functions | |
static int32_t | rohc_interval_compute_p (const size_t k, const rohc_lsb_shift_t p) |
Compute the shift parameter p for the f function. More... | |
struct rohc_interval8 | rohc_f_8bits (const uint8_t v_ref, const size_t k, const rohc_lsb_shift_t p) |
The f function as defined in LSB encoding for 8-bit fields. More... | |
struct rohc_interval16 | rohc_f_16bits (const uint16_t v_ref, const size_t k, const rohc_lsb_shift_t p) |
The f function as defined in LSB encoding for 16-bit fields. More... | |
struct rohc_interval32 | rohc_f_32bits (const uint32_t v_ref, const size_t k, const rohc_lsb_shift_t p) |
The f function as defined in LSB encoding for 32-bit fields. More... | |
Compute the interpretation interval for LSB and W-LSB encoding.
#define ROHC_LSB_SHIFT_TCP_ACK_SCALED ROHC_LSB_SHIFT_TCP_TTL |
#define ROHC_LSB_SHIFT_TCP_TS_1B ROHC_LSB_SHIFT_SN |
real value for TCP TS
#define ROHC_LSB_SHIFT_TCP_TS_2B ROHC_LSB_SHIFT_SN |
real value for TCP TS
enum rohc_lsb_shift_t |
the different values of the shift parameter of the LSB algorithm
The shift parameter is also named 'p' in some RFCs.
Some values are the real values to use directly. Some others are code that means that the real value to use shall be computed from the number of least significant bits that are transmitted.
struct rohc_interval16 rohc_f_16bits | ( | const uint16_t | v_ref, |
const size_t | k, | ||
const rohc_lsb_shift_t | p | ||
) |
The f function as defined in LSB encoding for 16-bit fields.
Find out the interval [v_ref - p, v_ref + (2^k - 1) - p] for a given k. See 4.5.1 in the RFC 3095 for details.
As stated RFC, the values to be encoded have a finite range and the interpretation interval can straddle the wraparound boundary. So, the min value may be greater than the max value!
v_ref | The reference value |
k | The number of least significant bits of the value that are transmitted |
p | The shift parameter (may be negative) |
struct rohc_interval32 rohc_f_32bits | ( | const uint32_t | v_ref, |
const size_t | k, | ||
const rohc_lsb_shift_t | p | ||
) |
The f function as defined in LSB encoding for 32-bit fields.
Find out the interval [v_ref - p, v_ref + (2^k - 1) - p] for a given k. See 4.5.1 in the RFC 3095 for details.
As stated RFC, the values to be encoded have a finite range and the interpretation interval can straddle the wraparound boundary. So, the min value may be greater than the max value!
v_ref | The reference value |
k | The number of least significant bits of the value that are transmitted |
p | The shift parameter (may be negative) |
struct rohc_interval8 rohc_f_8bits | ( | const uint8_t | v_ref, |
const size_t | k, | ||
const rohc_lsb_shift_t | p | ||
) |
The f function as defined in LSB encoding for 8-bit fields.
Find out the interval [v_ref - p, v_ref + (2^k - 1) - p] for a given k. See 4.5.1 in the RFC 3095 for details.
As stated RFC, the values to be encoded have a finite range and the interpretation interval can straddle the wraparound boundary. So, the min value may be greater than the max value!
v_ref | The reference value |
k | The number of least significant bits of the value that are transmitted |
p | The shift parameter (may be negative) |
|
inlinestatic |
Compute the shift parameter p for the f function.
k | The number of least significant bits of the value that are transmitted |
p | The shift parameter (may be negative) |