ROHC compression/decompression library
Functions
decomp_scaled_rtp_ts.h File Reference

Scaled RTP Timestamp decoding. More...

#include "rohc_traces.h"
#include <stdlib.h>
#include <stdint.h>
#include <stdbool.h>
Include dependency graph for decomp_scaled_rtp_ts.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Functions

struct ts_sc_decompd_create_sc (rohc_trace_callback2_t trace_cb, void *const trace_cb_priv)
 Create the scaled RTP Timestamp decoding context. More...
 
void rohc_ts_scaled_free (struct ts_sc_decomp *const ts_scaled)
 Destroy the given ts_sc_decomp object. More...
 
void ts_update_context (struct ts_sc_decomp *const ts_sc, const uint32_t ts, const uint16_t sn)
 Store a new timestamp. More...
 
void d_record_ts_stride (struct ts_sc_decomp *const ts_sc, const uint32_t ts_stride)
 Store the newly-parsed TS_STRIDE value. More...
 
bool ts_decode_unscaled_bits (struct ts_sc_decomp *const ts_sc, const uint32_t ts_unscaled_bits, const size_t ts_unscaled_bits_nr, uint32_t *const decoded_ts)
 Decode timestamp (TS) value with some LSB bits of the unscaled value. More...
 
bool ts_decode_scaled_bits (struct ts_sc_decomp *const ts_sc, const uint32_t ts_scaled_bits, const size_t ts_scaled_bits_nr, uint32_t *const decoded_ts)
 Decode timestamp (TS) value with some LSB bits of the TS_SCALED value. More...
 
uint32_t ts_deduce_from_sn (struct ts_sc_decomp *const ts_sc, const uint16_t sn)
 Deduct timestamp (TS) from Sequence Number (SN) More...
 

Detailed Description

Scaled RTP Timestamp decoding.

Author
David Moreau from TAS
Didier Barvaux didie.nosp@m.r@ba.nosp@m.rvaux.nosp@m..org

Function Documentation

struct ts_sc_decomp* d_create_sc ( rohc_trace_callback2_t  trace_cb,
void *const  trace_cb_priv 
)

Create the scaled RTP Timestamp decoding context.

Parameters
trace_cbThe trace callback
trace_cb_privAn optional private context for the trace
Returns
The scaled RTP Timestamp decoding context in case of success, NULL otherwise
void d_record_ts_stride ( struct ts_sc_decomp *const  ts_sc,
const uint32_t  ts_stride 
)

Store the newly-parsed TS_STRIDE value.

Parameters
ts_scThe ts_sc_decomp object
ts_strideThe TS_STRIDE value to add
void rohc_ts_scaled_free ( struct ts_sc_decomp *const  ts_sc)

Destroy the given ts_sc_decomp object.

Parameters
ts_scThe ts_sc_decomp object to destroy
bool ts_decode_scaled_bits ( struct ts_sc_decomp *const  ts_sc,
const uint32_t  ts_scaled_bits,
const size_t  ts_scaled_bits_nr,
uint32_t *const  decoded_ts 
)

Decode timestamp (TS) value with some LSB bits of the TS_SCALED value.

Use the given TS and TS_SCALED bits. Use the TS_STRIDE and TS_OFFSET values found in context.

Parameters
ts_scThe ts_sc_decomp object
ts_scaled_bitsThe W-LSB-encoded TS_SCALED value
ts_scaled_bits_nrThe number of bits of TS_SCALED (W-LSB)
decoded_tsOUT: The decoded TS
Returns
true in case of success, false otherwise
bool ts_decode_unscaled_bits ( struct ts_sc_decomp *const  ts_sc,
const uint32_t  ts_unscaled_bits,
const size_t  ts_unscaled_bits_nr,
uint32_t *const  decoded_ts 
)

Decode timestamp (TS) value with some LSB bits of the unscaled value.

Use the given unscaled TS bits. If the TS_STRIDE value was updated by the current packet, compute new TS_SCALED and TS_OFFSET values from the new TS_STRIDE value.

Parameters
ts_scThe ts_sc_decomp object
ts_unscaled_bitsThe W-LSB-encoded TS value
ts_unscaled_bits_nrThe number of bits of TS_SCALED (W-LSB)
decoded_tsOUT: The decoded TS
Returns
true in case of success, false otherwise
uint32_t ts_deduce_from_sn ( struct ts_sc_decomp *const  ts_sc,
const uint16_t  sn 
)

Deduct timestamp (TS) from Sequence Number (SN)

Use the given SN bits to compute the new TS_SCALED value. Use the TS_STRIDE and TS_OFFSET values found in context.

Parameters
ts_scThe ts_sc_decomp object
snThe SN
Returns
The decoded TS
void ts_update_context ( struct ts_sc_decomp *const  ts_sc,
const uint32_t  ts,
const uint16_t  sn 
)

Store a new timestamp.

Parameters
ts_scThe ts_sc_decomp object
tsThe new decoded TimeStamp (TS)
snThe new decoded Sequence Number (SN)