Fix sample::FromSigned to not shift by a negative amount

custom
jacqueline 1 year ago
parent 62d51a304e
commit 8a260dad05
  1. 4
      src/codecs/include/sample.hpp
  2. 7
      src/codecs/miniflac.cpp

@ -34,9 +34,9 @@ constexpr auto Clip(int64_t v) -> Sample {
constexpr auto FromSigned(int32_t src, uint_fast8_t bits) -> Sample { constexpr auto FromSigned(int32_t src, uint_fast8_t bits) -> Sample {
if (bits > 16) { if (bits > 16) {
return src << (sizeof(Sample) * 8 - bits); return src >> (bits - sizeof(Sample) * 8);
} else if (bits < 16) { } else if (bits < 16) {
return src << (bits - (sizeof(Sample) * 8)); return src << (sizeof(Sample) * 8 - bits);
} }
return src; return src;
} }

@ -147,8 +147,6 @@ auto MiniFlacDecoder::DecodeTo(cpp::span<sample::Sample> output)
size_t samples_written = 0; size_t samples_written = 0;
if (current_sample_) { if (current_sample_) {
const uint8_t shift = flac_->frame.header.bps - 16;
while (*current_sample_ < flac_->frame.header.block_size) { while (*current_sample_ < flac_->frame.header.block_size) {
if (samples_written + flac_->frame.header.channels >= output.size()) { if (samples_written + flac_->frame.header.channels >= output.size()) {
// We can't fit the next full PCM frame into the buffer. // We can't fit the next full PCM frame into the buffer.
@ -157,8 +155,9 @@ auto MiniFlacDecoder::DecodeTo(cpp::span<sample::Sample> output)
} }
for (int channel = 0; channel < flac_->frame.header.channels; channel++) { for (int channel = 0; channel < flac_->frame.header.channels; channel++) {
output[samples_written++] = sample::FromSigned( output[samples_written++] =
samples_by_channel_[channel][*current_sample_] >> shift, 16); sample::FromSigned(samples_by_channel_[channel][*current_sample_],
flac_->frame.header.bps);
} }
(*current_sample_)++; (*current_sample_)++;
} }

Loading…
Cancel
Save