blob: 611004540c10162c3c8ad107e1869b329ecbd8f0 [file] [log] [blame]
/*
* Copyright (c) 2021, Alliance for Open Media. All rights reserved
*
* This source code is subject to the terms of the BSD 3-Clause Clear License
* and the Alliance for Open Media Patent License 1.0. If the BSD 3-Clause Clear
* License was not distributed with this source code in the LICENSE file, you
* can obtain it at aomedia.org/license/software-license/bsd-3-c-c/. If the
* Alliance for Open Media Patent License 1.0 was not distributed with this
* source code in the PATENTS file, you can obtain it at
* aomedia.org/license/patent-license/.
*/
#ifndef AVM_AVM_DSP_BITREADER_BUFFER_H_
#define AVM_AVM_DSP_BITREADER_BUFFER_H_
#include <limits.h>
#include "avm/avm_codec.h"
#include "avm/avm_integer.h"
#ifdef __cplusplus
extern "C" {
#endif
typedef void (*avm_rb_error_handler)(void *data, avm_codec_err_t error,
const char *detail);
struct avm_read_bit_buffer {
const uint8_t *bit_buffer;
const uint8_t *bit_buffer_end;
uint32_t bit_offset;
void *error_handler_data;
avm_rb_error_handler error_handler;
};
size_t avm_rb_bytes_read(const struct avm_read_bit_buffer *rb);
int avm_rb_read_bit(struct avm_read_bit_buffer *rb);
int avm_rb_read_literal(struct avm_read_bit_buffer *rb, int bits);
uint32_t avm_rb_read_unsigned_literal(struct avm_read_bit_buffer *rb, int bits);
int avm_rb_read_inv_signed_literal(struct avm_read_bit_buffer *rb, int bits);
// Reads a variable length unsigned integer. Valid range is 0..UINT32_MAX - 1.
// Returns UINT32_MAX if the input is too long (has 32 or more leading zero
// bits); if rb->error_handler is not null, rb->error_handler() is invoked.
// If rb->error_handler() calls avm_internal_error(), the function does a long
// jump and does not return.
uint32_t avm_rb_read_uvlc(struct avm_read_bit_buffer *rb);
// Reads a variable length signed integer. Valid range is
// INT32_MIN + 1..INT32_MAX. Returns INT32_MIN if the input is too long (has 32
// or more leading zero bits); if rb->error_handler is not null,
// rb->error_handler() is invoked. If rb->error_handler() calls
// avm_internal_error(), the function does a long jump and does not return.
int32_t avm_rb_read_svlc(struct avm_read_bit_buffer *rb);
// Reads a Rice Golomb descriptor with a parameter k. k must be <= 26. Valid
// range is 0..2^(k + 5) - 1. Returns UINT32_MAX if the quotient part of the
// coding is too long (has 32 or more leading one bits); if rb->error_handler
// is not null, rb->error_handler() is invoked. If rb->error_handler() calls
// avm_internal_error(), the function does a long jump and does not return.
uint32_t avm_rb_read_rice_golomb(struct avm_read_bit_buffer *rb, int k);
uint16_t avm_rb_read_primitive_refsubexpfin(struct avm_read_bit_buffer *rb,
uint16_t n, uint16_t k,
uint16_t ref);
int16_t avm_rb_read_signed_primitive_refsubexpfin(
struct avm_read_bit_buffer *rb, uint16_t n, uint16_t k, int16_t ref);
uint16_t avm_rb_read_primitive_quniform(struct avm_read_bit_buffer *rb,
uint16_t n);
uint16_t avm_rb_read_primitive_ref_quniform(struct avm_read_bit_buffer *rb,
uint16_t n, uint16_t r);
uint32_t avm_rb_read_uleb(struct avm_read_bit_buffer *rb);
#ifdef __cplusplus
} // extern "C"
#endif
#endif // AVM_AVM_DSP_BITREADER_BUFFER_H_