Remove variable bits per sample - it's always 16.

This commit is contained in:
Dr. Chat 2015-05-30 21:01:55 -05:00
parent d97a6d1929
commit fedf7357a5
3 changed files with 14 additions and 27 deletions

View File

@ -46,20 +46,13 @@ AudioDecoder::~AudioDecoder() {
} }
} }
int AudioDecoder::Initialize(int bits) { int AudioDecoder::Initialize() {
static bool avcodec_initialized = false; static bool avcodec_initialized = false;
if (!avcodec_initialized) { if (!avcodec_initialized) {
avcodec_register_all(); avcodec_register_all();
avcodec_initialized = true; avcodec_initialized = true;
} }
if (bits <= 0 || bits > 32 || (bits % 8) != 0) {
assert_always();
}
// Output bits per sample
bits_ = bits;
// Allocate important stuff // Allocate important stuff
codec_ = avcodec_find_decoder(AV_CODEC_ID_WMAPRO); codec_ = avcodec_find_decoder(AV_CODEC_ID_WMAPRO);
if (!codec_) { if (!codec_) {
@ -154,7 +147,6 @@ int AudioDecoder::DecodePacket(uint8_t *output, size_t output_offset,
size_t output_size) { size_t output_size) {
size_t to_copy = 0; size_t to_copy = 0;
size_t original_offset = output_offset; size_t original_offset = output_offset;
uint32_t sample_size = bits_ / 8;
// We're holding onto an already-decoded frame. Copy it out. // We're holding onto an already-decoded frame. Copy it out.
if (current_frame_pos_ != frame_samples_size_) { if (current_frame_pos_ != frame_samples_size_) {
@ -204,27 +196,23 @@ int AudioDecoder::DecodePacket(uint8_t *output, size_t output_offset,
float *sample_array = (float *)decoded_frame_->data[0]; float *sample_array = (float *)decoded_frame_->data[0];
// Loop through every sample, convert and drop it into the output array. // Loop through every sample, convert and drop it into the output array.
if (sample_size == 2) { for (int i = 0; i < decoded_frame_->nb_samples; i++) {
for (int i = 0; i < decoded_frame_->nb_samples; i++) { // Raw sample should be within [-1, 1].
// Raw sample should be within [-1, 1]. // Clamp it, just in case.
// Clamp it, just in case. float raw_sample = xe::saturate(sample_array[i]);
float raw_sample = xe::saturate(sample_array[i]);
// Convert the sample and output it in big endian. // Convert the sample and output it in big endian.
float scaled_sample = raw_sample * (1 << (bits_ - 1)); float scaled_sample = raw_sample * (1 << 15);
int sample = static_cast<int>(scaled_sample); int sample = static_cast<int>(scaled_sample);
xe::store_and_swap<uint16_t>(&current_frame_[i * 2], xe::store_and_swap<uint16_t>(&current_frame_[i * 2],
sample & 0xFFFF); sample & 0xFFFF);
}
} else {
// 1 byte? 4 bytes?
assert_unhandled_case(sample_size);
} }
current_frame_pos_ = 0; current_frame_pos_ = 0;
// Total size of the frame's samples // Total size of the frame's samples
// Magic number 2 is sizeof the output
frame_samples_size_ = frame_samples_size_ =
context_->channels * decoded_frame_->nb_samples * sample_size; context_->channels * decoded_frame_->nb_samples * 2;
to_copy = std::min(output_size, (size_t)(frame_samples_size_)); to_copy = std::min(output_size, (size_t)(frame_samples_size_));
std::memcpy(output + output_offset, current_frame_, to_copy); std::memcpy(output + output_offset, current_frame_, to_copy);

View File

@ -36,7 +36,7 @@ class AudioDecoder {
AudioDecoder(); AudioDecoder();
~AudioDecoder(); ~AudioDecoder();
int Initialize(int bits); int Initialize();
int PreparePacket(uint8_t* input, size_t seq_offset, size_t size, int PreparePacket(uint8_t* input, size_t seq_offset, size_t size,
int sample_rate, int channels); int sample_rate, int channels);
@ -51,7 +51,6 @@ class AudioDecoder {
AVPacket* packet_; AVPacket* packet_;
uint8_t bits_per_frame_; uint8_t bits_per_frame_;
uint32_t bits_;
size_t current_frame_pos_; size_t current_frame_pos_;
uint8_t* current_frame_; uint8_t* current_frame_;
uint32_t frame_samples_size_; uint32_t frame_samples_size_;

View File

@ -102,7 +102,7 @@ X_STATUS AudioSystem::Setup() {
// Needed because some data needs to be persisted across calls // Needed because some data needs to be persisted across calls
// TODO: Need to destroy this on class destruction // TODO: Need to destroy this on class destruction
context.decoder = new AudioDecoder(); context.decoder = new AudioDecoder();
context.decoder->Initialize(16); context.decoder->Initialize();
} }
registers_.next_context = 1; registers_.next_context = 1;