decoder: replaced music_pipe.audioFormat with dc.out_audio_format

.. and rename dc.audioFormat to dc.in_audio_format.  The music pipe
does not need to know the audio format, and its former "audioFormat"
property indicated the format of the most recently added chunk, which
might be confusing when you are reading the oldest chunks.
This commit is contained in:
Max Kellermann 2008-11-02 16:55:43 +01:00
parent 30fca5e5a9
commit 8b1f6ff3c8
6 changed files with 34 additions and 22 deletions

View File

@ -21,6 +21,7 @@
#include "audio.h" #include "audio.h"
#include "pcm_utils.h" #include "pcm_utils.h"
#include "pipe.h" #include "pipe.h"
#include "audio_format.h"
#include <assert.h> #include <assert.h>
#include <string.h> #include <string.h>

View File

@ -39,8 +39,8 @@ void decoder_initialized(struct decoder * decoder,
pcm_convert_init(&decoder->conv_state); pcm_convert_init(&decoder->conv_state);
dc.audioFormat = *audio_format; dc.in_audio_format = *audio_format;
getOutputAudioFormat(audio_format, &ob.audioFormat); getOutputAudioFormat(audio_format, &dc.out_audio_format);
dc.totalTime = total_time; dc.totalTime = total_time;
@ -157,12 +157,12 @@ decoder_data(struct decoder *decoder,
static char *convBuffer; static char *convBuffer;
static size_t convBufferLen; static size_t convBufferLen;
if (audio_format_equals(&ob.audioFormat, &dc.audioFormat)) { if (audio_format_equals(&dc.in_audio_format, &dc.out_audio_format)) {
data = dataIn; data = dataIn;
datalen = dataInLen; datalen = dataInLen;
} else { } else {
datalen = pcm_convert_size(&(dc.audioFormat), dataInLen, datalen = pcm_convert_size(&dc.in_audio_format, dataInLen,
&(ob.audioFormat)); &dc.out_audio_format);
if (datalen > convBufferLen) { if (datalen > convBufferLen) {
if (convBuffer != NULL) if (convBuffer != NULL)
free(convBuffer); free(convBuffer);
@ -170,18 +170,21 @@ decoder_data(struct decoder *decoder,
convBufferLen = datalen; convBufferLen = datalen;
} }
data = convBuffer; data = convBuffer;
datalen = pcm_convert(&(dc.audioFormat), dataIn, datalen = pcm_convert(&dc.in_audio_format, dataIn,
dataInLen, &(ob.audioFormat), dataInLen, &dc.out_audio_format,
data, &decoder->conv_state); data, &decoder->conv_state);
} }
if (replayGainInfo != NULL && (replayGainState != REPLAYGAIN_OFF)) if (replayGainInfo != NULL && (replayGainState != REPLAYGAIN_OFF))
doReplayGain(replayGainInfo, data, datalen, &ob.audioFormat); doReplayGain(replayGainInfo, data, datalen,
&dc.out_audio_format);
else if (normalizationEnabled) else if (normalizationEnabled)
normalizeData(data, datalen, &ob.audioFormat); normalizeData(data, datalen, &dc.out_audio_format);
while (datalen > 0) { while (datalen > 0) {
nbytes = music_pipe_append(data, datalen, data_time, bitRate); nbytes = music_pipe_append(data, datalen,
&dc.out_audio_format,
data_time, bitRate);
datalen -= nbytes; datalen -= nbytes;
data += nbytes; data += nbytes;

View File

@ -47,7 +47,13 @@ struct decoder_control {
bool seekError; bool seekError;
bool seekable; bool seekable;
volatile double seekWhere; volatile double seekWhere;
struct audio_format audioFormat;
/** the format of the song file */
struct audio_format in_audio_format;
/** the format being sent to the music pipe */
struct audio_format out_audio_format;
struct song *current_song; struct song *current_song;
struct song *volatile next_song; struct song *volatile next_song;
volatile float totalTime; volatile float totalTime;

View File

@ -19,6 +19,7 @@
#include "pipe.h" #include "pipe.h"
#include "notify.h" #include "notify.h"
#include "utils.h" #include "utils.h"
#include "audio_format.h"
#include <assert.h> #include <assert.h>
#include <string.h> #include <string.h>
@ -185,10 +186,11 @@ tail_chunk(float data_time, uint16_t bitRate, size_t frame_size)
} }
size_t music_pipe_append(const void *data0, size_t datalen, size_t music_pipe_append(const void *data0, size_t datalen,
const struct audio_format *audio_format,
float data_time, uint16_t bitRate) float data_time, uint16_t bitRate)
{ {
const unsigned char *data = data0; const unsigned char *data = data0;
const size_t frame_size = audio_format_frame_size(&ob.audioFormat); const size_t frame_size = audio_format_frame_size(audio_format);
size_t ret = 0, dataToSend; size_t ret = 0, dataToSend;
struct music_chunk *chunk = NULL; struct music_chunk *chunk = NULL;

View File

@ -19,14 +19,15 @@
#ifndef MPD_PIPE_H #ifndef MPD_PIPE_H
#define MPD_PIPE_H #define MPD_PIPE_H
#include "audio_format.h"
#include <stddef.h> #include <stddef.h>
#include <stdint.h>
#include <stdbool.h> #include <stdbool.h>
/* pick 1020 since its devisible for 8,16,24, and 32-bit audio */ /* pick 1020 since its devisible for 8,16,24, and 32-bit audio */
#define CHUNK_SIZE 1020 #define CHUNK_SIZE 1020
struct audio_format;
struct music_chunk { struct music_chunk {
uint16_t chunkSize; uint16_t chunkSize;
uint16_t bitRate; uint16_t bitRate;
@ -53,8 +54,6 @@ struct music_pipe {
the buffer becomes non-empty */ the buffer becomes non-empty */
bool lazy; bool lazy;
struct audio_format audioFormat;
struct notify *notify; struct notify *notify;
}; };
@ -109,6 +108,7 @@ music_pipe_get_chunk(const unsigned i);
* @return the number of bytes actually written * @return the number of bytes actually written
*/ */
size_t music_pipe_append(const void *data, size_t datalen, size_t music_pipe_append(const void *data, size_t datalen,
const struct audio_format *audio_format,
float data_time, uint16_t bitRate); float data_time, uint16_t bitRate);
void music_pipe_skip(unsigned num); void music_pipe_skip(unsigned num);

View File

@ -288,7 +288,7 @@ static void do_play(void)
else if (!decoder_is_starting()) { else if (!decoder_is_starting()) {
/* the decoder is ready and ok */ /* the decoder is ready and ok */
player.decoder_starting = false; player.decoder_starting = false;
if (!openAudioDevice(&ob.audioFormat)) { if (!openAudioDevice(&dc.out_audio_format)) {
char tmp[MPD_PATH_MAX]; char tmp[MPD_PATH_MAX];
assert(dc.next_song == NULL || dc.next_song->url != NULL); assert(dc.next_song == NULL || dc.next_song->url != NULL);
pc.errored_song = dc.next_song; pc.errored_song = dc.next_song;
@ -303,9 +303,9 @@ static void do_play(void)
closeAudioDevice(); closeAudioDevice();
pc.totalTime = dc.totalTime; pc.totalTime = dc.totalTime;
pc.audio_format = dc.audioFormat; pc.audio_format = dc.in_audio_format;
play_audio_format = ob.audioFormat; play_audio_format = dc.out_audio_format;
sizeToTime = audioFormatSizeToTime(&ob.audioFormat); sizeToTime = audioFormatSizeToTime(&dc.out_audio_format);
} }
else { else {
/* the decoder is not yet ready; wait /* the decoder is not yet ready; wait
@ -341,7 +341,7 @@ static void do_play(void)
for it */ for it */
crossFadeChunks = crossFadeChunks =
cross_fade_calc(pc.crossFade, dc.totalTime, cross_fade_calc(pc.crossFade, dc.totalTime,
&(ob.audioFormat), &dc.out_audio_format,
ob.size - ob.size -
pc.buffered_before_play); pc.buffered_before_play);
if (crossFadeChunks > 0) { if (crossFadeChunks > 0) {
@ -378,7 +378,7 @@ static void do_play(void)
music_pipe_set_lazy(true); music_pipe_set_lazy(true);
cross_fade_apply(beginChunk, cross_fade_apply(beginChunk,
music_pipe_get_chunk(nextChunk), music_pipe_get_chunk(nextChunk),
&(ob.audioFormat), &dc.out_audio_format,
fadePosition, fadePosition,
crossFadeChunks); crossFadeChunks);
} else { } else {