summaryrefslogtreecommitdiff
path: root/src/codecs
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2023-12-19 21:50:33 +1100
committerjacqueline <me@jacqueline.id.au>2023-12-19 21:50:33 +1100
commit8a260dad05f068727e538092ef9c56e714a7edb4 (patch)
tree1b35d431f0e85148ac211a2b6b3383123ec10239 /src/codecs
parent62d51a304eb02f0eab0645488c0b922b4a45e1c9 (diff)
downloadtangara-fw-8a260dad05f068727e538092ef9c56e714a7edb4.tar.gz
Fix sample::FromSigned to not shift by a negative amount
Diffstat (limited to 'src/codecs')
-rw-r--r--src/codecs/include/sample.hpp4
-rw-r--r--src/codecs/miniflac.cpp7
2 files changed, 5 insertions, 6 deletions
diff --git a/src/codecs/include/sample.hpp b/src/codecs/include/sample.hpp
index f77284bb..937b6b79 100644
--- a/src/codecs/include/sample.hpp
+++ b/src/codecs/include/sample.hpp
@@ -34,9 +34,9 @@ constexpr auto Clip(int64_t v) -> Sample {
constexpr auto FromSigned(int32_t src, uint_fast8_t bits) -> Sample {
if (bits > 16) {
- return src << (sizeof(Sample) * 8 - bits);
+ return src >> (bits - sizeof(Sample) * 8);
} else if (bits < 16) {
- return src << (bits - (sizeof(Sample) * 8));
+ return src << (sizeof(Sample) * 8 - bits);
}
return src;
}
diff --git a/src/codecs/miniflac.cpp b/src/codecs/miniflac.cpp
index cc261f75..e4eadeca 100644
--- a/src/codecs/miniflac.cpp
+++ b/src/codecs/miniflac.cpp
@@ -147,8 +147,6 @@ auto MiniFlacDecoder::DecodeTo(cpp::span<sample::Sample> output)
size_t samples_written = 0;
if (current_sample_) {
- const uint8_t shift = flac_->frame.header.bps - 16;
-
while (*current_sample_ < flac_->frame.header.block_size) {
if (samples_written + flac_->frame.header.channels >= output.size()) {
// 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++) {
- output[samples_written++] = sample::FromSigned(
- samples_by_channel_[channel][*current_sample_] >> shift, 16);
+ output[samples_written++] =
+ sample::FromSigned(samples_by_channel_[channel][*current_sample_],
+ flac_->frame.header.bps);
}
(*current_sample_)++;
}