| ROHC compression/decompression library
   
    | 
ROHC decompression routines. More...
#include "rohc_decomp.h"#include "rohc_traces.h"#include "rohc_time.h"#include "rohc_utils.h"#include "rohc_debug.h"#include "feedback.h"#include "wlsb.h"#include "decode.h"#include "crc.h"#include <assert.h>
| Data Structures | |
| struct | d_decode_data | 
| Decompression-related data.  More... | |
| Functions | |
| int | d_decode_header (struct rohc_decomp *decomp, unsigned char *ibuf, int isize, unsigned char *obuf, int osize, struct d_decode_data *ddata) | 
| Decompress the compressed headers. | |
| void | d_operation_mode_feedback (struct rohc_decomp *decomp, int rohc_status, const uint16_t cid, int addcidUsed, const rohc_cid_type_t cid_type, int mode, struct d_context *context) | 
| Send feedback depending on the mode: Unidirectional, Optimistic or Reliable. | |
| struct d_context * | find_context (struct rohc_decomp *decomp, int cid) | 
| Find one decompression context thanks to its CID. | |
| struct d_context * | context_create (struct rohc_decomp *decomp, int with_cid, struct d_profile *profile) | 
| Create one new decompression context with profile specific data. | |
| void | context_free (struct d_context *context) | 
| Destroy one decompression context and the profile specific data associated with it. | |
| struct rohc_decomp * | rohc_alloc_decompressor (struct rohc_comp *compressor) | 
| Create one ROHC decompressor. | |
| void | rohc_free_decompressor (struct rohc_decomp *decomp) | 
| Destroy one ROHC decompressor. | |
| int | rohc_decompress (struct rohc_decomp *decomp, unsigned char *ibuf, int isize, unsigned char *obuf, int osize) | 
| Decompress a ROHC packet. | |
| int | rohc_decompress_both (struct rohc_decomp *decomp, unsigned char *ibuf, int isize, unsigned char *obuf, int osize, int large) | 
| Decompress both large and small CID packets. | |
| void | d_optimistic_feedback (struct rohc_decomp *decomp, int rohc_status, const uint16_t cid, int addcidUsed, const rohc_cid_type_t cid_type, struct d_context *context) | 
| Send feedback in Optimistic Mode. | |
| void | clear_statistics (struct rohc_decomp *decomp) | 
| Clear all the statistics. | |
| int | rohc_d_statistics (struct rohc_decomp *decomp, unsigned int indent, char *buffer) | 
| Output the decompression statistics of one decompressor to a buffer. The buffer must be large enough to store all the statistics. | |
| int | rohc_d_context (struct rohc_decomp *decomp, int index, unsigned int indent, char *buffer) | 
| Output the statistics of one decompression context to a buffer. | |
| const char * | rohc_decomp_get_state_descr (const rohc_d_state state) | 
| Give a description for the given ROHC decompression context state. | |
| void | d_change_mode_feedback (struct rohc_decomp *decomp, struct d_context *context) | 
| Create a feedback ACK packet telling the compressor to change state. | |
| void | user_interactions (struct rohc_decomp *decomp, int feedback_maxval) | 
| Update feedback interval by the user. | |
| bool | rohc_decomp_set_cid_type (struct rohc_decomp *const decomp, const rohc_cid_type_t cid_type) | 
| Set the type of CID to use for the given decompressor. | |
| bool | rohc_decomp_set_max_cid (struct rohc_decomp *const decomp, const size_t max_cid) | 
| Set the MAX_CID allowed for the given decompressor. | |
| Variables | |
| struct d_profile d_uncomp_profile d_udp_profile d_ip_profile d_udplite_profile d_esp_profile | d_rtp_profile | 
| Define the decompression part of the RTP profile as described in the RFC 3095. | |
ROHC decompression routines.
| struct d_context* context_create | ( | struct rohc_decomp * | decomp, | 
| int | with_cid, | ||
| struct d_profile * | profile | ||
| ) |  [read] | 
Create one new decompression context with profile specific data.
| decomp | The ROHC decompressor | 
| with_cid | The CID of the new context (not implemented) | 
| profile | The profile to be assigned with the new context | 
References d_profile::allocate_decode_data, c_create_wlsb(), c_destroy_wlsb(), d_context::curval, d_context::first_used, d_profile::free_decode_data, d_context::header_16_compressed, d_context::header_16_uncompressed, d_context::header_compressed_size, d_context::header_uncompressed_size, d_context::latest_used, d_context::mode, NO_CONTEXT, d_context::num_decomp_failures, d_context::num_decomp_repairs, d_context::num_recv_ir, d_context::num_recv_ir_dyn, d_context::num_recv_packets, d_context::num_sent_feedbacks, d_context::profile, rohc_debugf, ROHC_LSB_SHIFT_STATS, d_context::specific, d_context::state, d_context::total_16_compressed, d_context::total_16_uncompressed, d_context::total_compressed_size, d_context::total_uncompressed_size, U_MODE, and zfree.
Referenced by d_decode_header().
| void context_free | ( | struct d_context * | context | ) | 
Destroy one decompression context and the profile specific data associated with it.
| context | The context to destroy | 
References c_destroy_wlsb(), d_profile::free_decode_data, d_context::header_16_compressed, d_context::header_16_uncompressed, d_context::profile, d_context::specific, d_context::total_16_compressed, d_context::total_16_uncompressed, and zfree.
Referenced by d_decode_header(), and rohc_free_decompressor().
| int d_decode_header | ( | struct rohc_decomp * | decomp, | 
| unsigned char * | ibuf, | ||
| int | isize, | ||
| unsigned char * | obuf, | ||
| int | osize, | ||
| struct d_decode_data * | ddata | ||
| ) | 
Decompress the compressed headers.
| decomp | The ROHC decompressor | 
| ibuf | The ROHC packet to decompress | 
| isize | The size of the ROHC packet | 
| obuf | The buffer where to store the decompressed packet | 
| osize | The size of the buffer for the decompressed packet | 
| ddata | Decompression-related data (e.g. the context) | 
References d_decode_data::active, d_decode_data::addcidUsed, d_decode_data::cid, context_create(), context_free(), rohc_decomp::contexts, rohc_decomp::curval, d_is_ir(), d_is_irdyn(), d_profile::decode, find_context(), d_decode_data::large_cid_size, rohc_decomp::last_context, d_context::latest_used, medium::max_cid, rohc_decomp::maxval, rohc_decomp::medium, d_context::num_recv_ir, d_context::num_recv_ir_dyn, d_context::profile, rohc_debugf, ROHC_ERROR_NO_CONTEXT, ROHC_FEEDBACK_ONLY, and ROHC_OK.
Referenced by rohc_decompress().
| void d_operation_mode_feedback | ( | struct rohc_decomp * | decomp, | 
| int | rohc_status, | ||
| const uint16_t | cid, | ||
| int | addcidUsed, | ||
| const rohc_cid_type_t | cid_type, | ||
| int | mode, | ||
| struct d_context * | context | ||
| ) | 
Send feedback depending on the mode: Unidirectional, Optimistic or Reliable.
| decomp | The ROHC decompressor | 
| rohc_status | The type of feedback to send: 0 = OK (ack), -1 = ContextInvalid (S-nack), -2 = PackageFailed (Nack) | 
| cid | The Context ID (CID) to which the feedback is related | 
| addcidUsed | Whether add-CID is used or not | 
| cid_type | The type of CID used for the feedback | 
| mode | The mode in which the ROHC decompressor operates: U_MODE, O_MODE or R_MODE | 
| context | The context to which the feedback is related | 
References d_optimistic_feedback(), O_MODE, R_MODE, and U_MODE.
Referenced by rohc_decompress().
| void d_optimistic_feedback | ( | struct rohc_decomp * | decomp, | 
| int | rohc_status, | ||
| const uint16_t | cid, | ||
| int | addcidUsed, | ||
| const rohc_cid_type_t | cid_type, | ||
| struct d_context * | context | ||
| ) | 
Send feedback in Optimistic Mode.
| decomp | The ROHC decompressor | 
| rohc_status | The type of feedback to send: 0 = OK (ack), -1 = ContextInvalid (S-nack), -2 = PackageFailed (Nack) | 
| cid | The Context ID (CID) to which the feedback is related | 
| addcidUsed | Whether add-CID is used or not | 
| cid_type | The type of CID used for the feedback | 
| context | The context to which the feedback is related | 
References ACKTYPE_ACK, ACKTYPE_NACK, ACKTYPE_STATIC_NACK, c_piggyback_feedback(), medium::cid_type, rohc_decomp::compressor, rohc_decomp::crc_table_8, f_add_option(), f_feedback2(), f_wrap_feedback(), FULL_CONTEXT, d_profile::get_sn, medium::max_cid, rohc_decomp::medium, d_context::mode, NO_CONTEXT, NO_CRC, d_context::num_sent_feedbacks, O_MODE, OPT_TYPE_SN_NOT_VALID, d_context::profile, rohc_debugf, ROHC_ERROR_CRC, ROHC_ERROR_NO_CONTEXT, ROHC_ERROR_PACKET_FAILED, ROHC_LARGE_CID_MAX, ROHC_OK, ROHC_SMALL_CID, ROHC_SMALL_CID_MAX, d_context::state, STATIC_CONTEXT, WITH_CRC, and zfree.
Referenced by d_operation_mode_feedback().
| struct d_context* find_context | ( | struct rohc_decomp * | decomp, | 
| int | cid | ||
| ) |  [read] | 
Find one decompression context thanks to its CID.
| decomp | The ROHC decompressor | 
| cid | The CID of the context to find out | 
References rohc_decomp::contexts, and medium::max_cid.
Referenced by d_decode_header().
| int rohc_d_context | ( | struct rohc_decomp * | decomp, | 
| int | index, | ||
| unsigned int | indent, | ||
| char * | buffer | ||
| ) | 
Output the statistics of one decompression context to a buffer.
The buffer must be large enough to store the statistics of one context.
| decomp | The ROHC decompressor | 
| index | The index of the decompression context in the contexts array | 
| indent | The level of indentation to add during output | 
| buffer | The buffer where to outputs the statistics | 
References c_mean_wlsb(), c_sum_wlsb(), rohc_decomp::contexts, d_profile::description, d_context::first_used, d_context::header_16_compressed, d_context::header_16_uncompressed, d_context::header_compressed_size, d_context::header_uncompressed_size, d_context::latest_used, medium::max_cid, rohc_decomp::medium, d_context::mode, d_context::num_decomp_failures, d_context::num_decomp_repairs, d_context::num_recv_ir, d_context::num_recv_ir_dyn, d_context::num_recv_packets, d_context::num_sent_feedbacks, d_context::profile, rohc_decomp_get_state_descr(), rohc_get_mode_descr(), d_context::state, d_context::total_16_compressed, d_context::total_16_uncompressed, d_context::total_compressed_size, and d_context::total_uncompressed_size.
Referenced by rohc_d_statistics().
| struct d_profile d_uncomp_profile d_udp_profile d_ip_profile d_udplite_profile d_esp_profile d_rtp_profile | 
Define the decompression part of the RTP profile as described in the RFC 3095.
 1.7.6.1
 1.7.6.1