mirror of
https://projects.vdr-developer.org/git/vdr-plugin-softhddevice.git
synced 2023-10-10 19:16:51 +02:00
Fix bug: don't normalize or compress AC3 samples.
This commit is contained in:
parent
47d840bbff
commit
3b5c1adef2
@ -1,6 +1,8 @@
|
|||||||
User johns
|
User johns
|
||||||
Date:
|
Date:
|
||||||
|
|
||||||
|
Release Version 0.5.1
|
||||||
|
Fix bug: don't normalize or compress pass-through samples.
|
||||||
Make audio ring buffer size a multiple of 3,5,7,8.
|
Make audio ring buffer size a multiple of 3,5,7,8.
|
||||||
Add reset ring buffer support.
|
Add reset ring buffer support.
|
||||||
Fix bug: alloca wrong size for audio buffer.
|
Fix bug: alloca wrong size for audio buffer.
|
||||||
|
12
audio.c
12
audio.c
@ -3570,7 +3570,7 @@ void AudioEnqueue(const void *samples, int count)
|
|||||||
int16_t *buffer;
|
int16_t *buffer;
|
||||||
int frames;
|
int frames;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef noDEBUG
|
||||||
static uint32_t last_tick;
|
static uint32_t last_tick;
|
||||||
uint32_t tick;
|
uint32_t tick;
|
||||||
|
|
||||||
@ -3585,11 +3585,15 @@ void AudioEnqueue(const void *samples, int count)
|
|||||||
Debug(3, "audio: enqueue not ready\n");
|
Debug(3, "audio: enqueue not ready\n");
|
||||||
return; // no setup yet
|
return; // no setup yet
|
||||||
}
|
}
|
||||||
|
if (AudioRing[AudioRingWrite].UseAc3) {
|
||||||
|
buffer = (void*)samples;
|
||||||
|
} else {
|
||||||
//
|
//
|
||||||
// Convert / resample input to hardware format
|
// Convert / resample input to hardware format
|
||||||
//
|
//
|
||||||
frames =
|
frames =
|
||||||
count / (AudioRing[AudioRingWrite].InChannels * AudioBytesProSample);
|
count / (AudioRing[AudioRingWrite].InChannels *
|
||||||
|
AudioBytesProSample);
|
||||||
buffer =
|
buffer =
|
||||||
alloca(frames * AudioRing[AudioRingWrite].HwChannels *
|
alloca(frames * AudioRing[AudioRingWrite].HwChannels *
|
||||||
AudioBytesProSample);
|
AudioBytesProSample);
|
||||||
@ -3597,7 +3601,8 @@ void AudioEnqueue(const void *samples, int count)
|
|||||||
buffer, AudioRing[AudioRingWrite].HwChannels);
|
buffer, AudioRing[AudioRingWrite].HwChannels);
|
||||||
|
|
||||||
count =
|
count =
|
||||||
frames * AudioRing[AudioRingWrite].HwChannels * AudioBytesProSample;
|
frames * AudioRing[AudioRingWrite].HwChannels *
|
||||||
|
AudioBytesProSample;
|
||||||
|
|
||||||
// resample into ring-buffer is too complex in the case of a roundabout
|
// resample into ring-buffer is too complex in the case of a roundabout
|
||||||
// just use a temporary buffer
|
// just use a temporary buffer
|
||||||
@ -3608,6 +3613,7 @@ void AudioEnqueue(const void *samples, int count)
|
|||||||
if (AudioNormalize) { // in place operation
|
if (AudioNormalize) { // in place operation
|
||||||
AudioNormalizer(buffer, count);
|
AudioNormalizer(buffer, count);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
n = RingBufferWrite(AudioRing[AudioRingWrite].RingBuffer, buffer, count);
|
n = RingBufferWrite(AudioRing[AudioRingWrite].RingBuffer, buffer, count);
|
||||||
if (n != (size_t) count) {
|
if (n != (size_t) count) {
|
||||||
|
Loading…
Reference in New Issue
Block a user