Window-based Least Significant Bits (W-LSB) decoding.  
More...
#include "interval.h"
#include <stdlib.h>
#include <stdint.h>
#include <stddef.h>
#include <stdbool.h>
Go to the source code of this file.
|  | 
| void | rohc_lsb_init (struct rohc_lsb_decode *const lsb, const size_t max_len) | 
|  | Initialize a given Least Significant Bits (LSB) decoding context.  More... 
 | 
|  | 
| bool | rohc_lsb_is_ready (const struct rohc_lsb_decode *const lsb) | 
|  | Is the LSB decoding context ready to decode a compressed value.  More... 
 | 
|  | 
| bool | rohc_lsb_decode (const struct rohc_lsb_decode *const lsb, const rohc_lsb_ref_t ref_type, const uint32_t v_ref_d_offset, const uint32_t m, const size_t k, const rohc_lsb_shift_t p, uint32_t *const decoded) | 
|  | Decode a LSB-encoded value.  More... 
 | 
|  | 
| void | rohc_lsb_set_ref (struct rohc_lsb_decode *const lsb, const uint32_t v_ref_d, const bool keep_ref_minus_1) | 
|  | Update the LSB reference value.  More... 
 | 
|  | 
| uint32_t | rohc_lsb_get_ref (const struct rohc_lsb_decode *const lsb, const rohc_lsb_ref_t ref_type) | 
|  | Get the current LSB reference value (ref 0)  More... 
 | 
|  | 
◆ rohc_lsb_ref_t
The different reference values for LSB decoding 
| Enumerator | 
|---|
| ROHC_LSB_REF_MINUS_1 | Use the 'ref -1' reference value  | 
| ROHC_LSB_REF_0 | Use the 'ref 0' reference value  | 
| ROHC_LSB_REF_MAX | The number of different reference values  | 
 
 
◆ rohc_lsb_decode()
Decode a LSB-encoded value. 
See 4.5.1 in the RFC 3095 for details about LSB encoding.
- Parameters
- 
  
    | lsb | The LSB object used to decode |  | ref_type | The reference value to use to decode (used for context repair upon CRC failure) |  | v_ref_d_offset | The offset to apply on v_ref_d (used for context repair upon CRC failure) |  | m | The LSB value to decode |  | k | The length of the LSB value to decode |  | p | The shift value p used to efficiently encode/decode the values |  | decoded | OUT: The decoded value |  
 
- Returns
- true in case of success, false otherwise 
 
 
◆ rohc_lsb_get_ref()
Get the current LSB reference value (ref 0) 
- Parameters
- 
  
    | lsb | The LSB object |  | ref_type | The reference value to retrieve |  
 
- Returns
- The current reference value 
 
 
◆ rohc_lsb_init()
      
        
          | void rohc_lsb_init | ( | struct rohc_lsb_decode *const | lsb, | 
        
          |  |  | const size_t | max_len | 
        
          |  | ) |  |  | 
      
 
Initialize a given Least Significant Bits (LSB) decoding context. 
See 4.5.1 in the RFC 3095 for details about LSB encoding.
- Parameters
- 
  
    | [in,out] | lsb | The LSB decoding context to init |  |  | max_len | The max length (in bits) of the non-compressed field |  
 
 
 
◆ rohc_lsb_is_ready()
Is the LSB decoding context ready to decode a compressed value. 
- Parameters
- 
  
    | lsb | The LSB object used to decode |  
 
- Returns
- Whether the LSB decoding context is ready to decode a value 
 
 
◆ rohc_lsb_set_ref()
      
        
          | void rohc_lsb_set_ref | ( | struct rohc_lsb_decode *const | lsb, | 
        
          |  |  | const uint32_t | v_ref_d, | 
        
          |  |  | const bool | keep_ref_minus_1 | 
        
          |  | ) |  |  | 
      
 
Update the LSB reference value. 
This function is called after a CRC success to update the last decoded value (for example, the SN value). See 4.5.1 in the RFC 3095 for details about LSB encoding.
- Parameters
- 
  
    | lsb | The LSB object |  | v_ref_d | The new reference value |  | keep_ref_minus_1 | Keep ref -1 unchanged (used for SN context repair after CRC failure, see RFC3095 ยง5.3.2.2.5) |