ROHC compression/decompression library
Data Fields
rohc_comp_rfc3095_ctxt Struct Reference

The generic decompression context for RFC3095-based profiles. More...

#include <rohc_comp_rfc3095.h>

Collaboration diagram for rohc_comp_rfc3095_ctxt:
Collaboration graph
[legend]

Data Fields

uint32_t sn
 The Sequence Number (SN), may be 16-bit or 32-bit long. More...
 
struct c_wlsb sn_window
 A window used to encode the SN. More...
 
uint32_t msn_of_last_ctxt_updating_pkt
 
struct c_wlsb msn_non_acked
 
size_t ip_hdr_nr
 
struct ip_header_info ip_ctxts [ROHC_MAX_IP_HDRS]
 
bool is_crc_static_3_cached_valid
 
uint8_t crc_static_3_cached
 
bool is_crc_static_7_cached_valid
 
uint8_t crc_static_7_cached
 
struct generic_tmp_vars tmp
 Temporary variables that are used during one single compression of packet. More...
 
unsigned int next_header_proto
 The protocol number registered by IANA for the next header protocol. More...
 
unsigned int next_header_len
 The length of the next header. More...
 
bool(* encode_uncomp_fields )(struct rohc_comp_ctxt *const context, const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs)
 
rohc_packet_t(* decide_FO_packet )(const struct rohc_comp_ctxt *const context)
 The handler used to decide which packet to send in FO state. More...
 
rohc_packet_t(* decide_SO_packet )(const struct rohc_comp_ctxt *const context)
 The handler used to decide which packet to send in SO state. More...
 
rohc_ext_t(* decide_extension )(const struct rohc_comp_ctxt *const context, const rohc_packet_t packet_type)
 
uint32_t(* get_next_sn )(const struct rohc_comp_ctxt *const context, const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs)
 
size_t(* code_static_part )(const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)
 The handler used to add the static part of the next header to the ROHC packet. More...
 
size_t(* code_dynamic_part )(const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)
 The handler used to add the dynamic part of the next header to the ROHC pachet. More...
 
int(* code_ir_remainder )(const struct rohc_comp_ctxt *const context, uint8_t *const dest, const size_t dest_max_len, const size_t counter)
 The handler used to add the IR/IR-DYN remainder header to the ROHC pachet. More...
 
size_t(* code_uo_remainder )(const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)
 The handler used to add an additional header in the tail of the UO-0, UO-1 and UO-2 packets. More...
 
uint8_t(* compute_crc_static )(const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs, const rohc_crc_type_t crc_type, const uint8_t init_val)
 The handler used to compute the CRC-STATIC value. More...
 
uint8_t(* compute_crc_dynamic )(const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs, const rohc_crc_type_t crc_type, const uint8_t init_val)
 The handler used to compute the CRC-DYNAMIC value. More...
 
void * specific
 Profile-specific data. More...
 

Detailed Description

The generic decompression context for RFC3095-based profiles.

The object defines the generic context that manages IP(/nextheader) and IP/IP(/nextheader) packets. nextheader is managed by the profile-specific part of the context.

Field Documentation

◆ code_dynamic_part

size_t(* rohc_comp_rfc3095_ctxt::code_dynamic_part) (const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)

The handler used to add the dynamic part of the next header to the ROHC pachet.

◆ code_ir_remainder

int(* rohc_comp_rfc3095_ctxt::code_ir_remainder) (const struct rohc_comp_ctxt *const context, uint8_t *const dest, const size_t dest_max_len, const size_t counter)

The handler used to add the IR/IR-DYN remainder header to the ROHC pachet.

◆ code_static_part

size_t(* rohc_comp_rfc3095_ctxt::code_static_part) (const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)

The handler used to add the static part of the next header to the ROHC packet.

◆ code_uo_remainder

size_t(* rohc_comp_rfc3095_ctxt::code_uo_remainder) (const struct rohc_comp_ctxt *const context, const uint8_t *const next_header, uint8_t *const dest, const size_t counter)

The handler used to add an additional header in the tail of the UO-0, UO-1 and UO-2 packets.

◆ compute_crc_dynamic

uint8_t(* rohc_comp_rfc3095_ctxt::compute_crc_dynamic) (const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs, const rohc_crc_type_t crc_type, const uint8_t init_val)

The handler used to compute the CRC-DYNAMIC value.

◆ compute_crc_static

uint8_t(* rohc_comp_rfc3095_ctxt::compute_crc_static) (const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs, const rohc_crc_type_t crc_type, const uint8_t init_val)

The handler used to compute the CRC-STATIC value.

◆ crc_static_3_cached

uint8_t rohc_comp_rfc3095_ctxt::crc_static_3_cached

The cache for the CRC-3 value on CRC-STATIC fields

◆ crc_static_7_cached

uint8_t rohc_comp_rfc3095_ctxt::crc_static_7_cached

The cache for the CRC-7 value on CRC-STATIC fields

◆ decide_extension

rohc_ext_t(* rohc_comp_rfc3095_ctxt::decide_extension) (const struct rohc_comp_ctxt *const context, const rohc_packet_t packet_type)

The handler used to decide which extension to send

◆ decide_FO_packet

rohc_packet_t(* rohc_comp_rfc3095_ctxt::decide_FO_packet) (const struct rohc_comp_ctxt *const context)

The handler used to decide which packet to send in FO state.

◆ decide_SO_packet

rohc_packet_t(* rohc_comp_rfc3095_ctxt::decide_SO_packet) (const struct rohc_comp_ctxt *const context)

The handler used to decide which packet to send in SO state.

◆ encode_uncomp_fields

bool(* rohc_comp_rfc3095_ctxt::encode_uncomp_fields) (struct rohc_comp_ctxt *const context, const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs)

The handler for encoding profile-specific uncompressed header fields

◆ get_next_sn

uint32_t(* rohc_comp_rfc3095_ctxt::get_next_sn) (const struct rohc_comp_ctxt *const context, const struct rohc_pkt_hdrs *const uncomp_pkt_hdrs)

Determine the next SN value

◆ ip_ctxts

struct ip_header_info rohc_comp_rfc3095_ctxt::ip_ctxts[ROHC_MAX_IP_HDRS]

Information about the IP headers

◆ ip_hdr_nr

size_t rohc_comp_rfc3095_ctxt::ip_hdr_nr

The number of IP headers

◆ is_crc_static_3_cached_valid

bool rohc_comp_rfc3095_ctxt::is_crc_static_3_cached_valid

Whether the cache for the CRC-3 value on CRC-STATIC fields is initialized or not

◆ is_crc_static_7_cached_valid

bool rohc_comp_rfc3095_ctxt::is_crc_static_7_cached_valid

Whether the cache for the CRC-7 value on CRC-STATIC fields is initialized or not

◆ msn_non_acked

struct c_wlsb rohc_comp_rfc3095_ctxt::msn_non_acked

The W-LSB for non-acknowledged MSN

◆ msn_of_last_ctxt_updating_pkt

uint32_t rohc_comp_rfc3095_ctxt::msn_of_last_ctxt_updating_pkt

The SN of the last packet that updated the context (used to determine if a positive ACK may cause a transition to a higher compression state)

◆ next_header_len

unsigned int rohc_comp_rfc3095_ctxt::next_header_len

The length of the next header.

◆ next_header_proto

unsigned int rohc_comp_rfc3095_ctxt::next_header_proto

The protocol number registered by IANA for the next header protocol.

◆ sn

uint32_t rohc_comp_rfc3095_ctxt::sn

The Sequence Number (SN), may be 16-bit or 32-bit long.

◆ sn_window

struct c_wlsb rohc_comp_rfc3095_ctxt::sn_window

A window used to encode the SN.

◆ specific

void* rohc_comp_rfc3095_ctxt::specific

Profile-specific data.

◆ tmp

struct generic_tmp_vars rohc_comp_rfc3095_ctxt::tmp

Temporary variables that are used during one single compression of packet.


The documentation for this struct was generated from the following file: