diff --git a/Userland/Libraries/LibAudio/FlacLoader.cpp b/Userland/Libraries/LibAudio/FlacLoader.cpp index b79c9fa8f8..44f8671f01 100644 --- a/Userland/Libraries/LibAudio/FlacLoader.cpp +++ b/Userland/Libraries/LibAudio/FlacLoader.cpp @@ -596,7 +596,7 @@ Vector FlacLoaderPlugin::parse_subframe(FlacSubframeHeader& subframe_header samples.ensure_capacity(m_current_frame->sample_count); for (u32 i = 0; i < m_current_frame->sample_count; ++i) { - samples.unchecked_append(sign_extend(constant_value, subframe_header.bits_per_sample)); + samples.unchecked_append(sign_extend(constant_value, subframe_header.bits_per_sample - subframe_header.wasted_bits_per_sample)); } break; } @@ -645,8 +645,7 @@ Vector FlacLoaderPlugin::decode_custom_lpc(FlacSubframeHeader& subframe, In // warm-up samples for (auto i = 0; i < subframe.order; ++i) { - decoded.unchecked_append(sign_extend(bit_input.read_bits_big_endian(subframe.bits_per_sample - subframe.wasted_bits_per_sample), subframe.bits_per_sample)); - decoded[i] <<= subframe.wasted_bits_per_sample; + decoded.unchecked_append(sign_extend(bit_input.read_bits_big_endian(subframe.bits_per_sample - subframe.wasted_bits_per_sample), subframe.bits_per_sample - subframe.wasted_bits_per_sample)); } // precision of the coefficients @@ -695,7 +694,7 @@ Vector FlacLoaderPlugin::decode_fixed_lpc(FlacSubframeHeader& subframe, Inp // warm-up samples for (auto i = 0; i < subframe.order; ++i) { - decoded.unchecked_append(sign_extend(bit_input.read_bits_big_endian(subframe.bits_per_sample - subframe.wasted_bits_per_sample), subframe.bits_per_sample)); + decoded.unchecked_append(sign_extend(bit_input.read_bits_big_endian(subframe.bits_per_sample - subframe.wasted_bits_per_sample), subframe.bits_per_sample - subframe.wasted_bits_per_sample)); } decode_residual(decoded, subframe, bit_input);