Use a macro for aligning PCM chunks instead of explictly coding it each time.

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@31152 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Michael Sevakis 2011-12-05 13:58:35 +00:00
parent 6461f74ae4
commit 906905aa43
3 changed files with 13 additions and 20 deletions

View file

@ -70,11 +70,6 @@ static struct mixer_channel * active_channels[PCM_MIXER_NUM_CHANNELS+1] IBSS_ATT
#define MAX_IDLE_FRAMES (NATIVE_FREQUENCY*3 / MIX_FRAME_SAMPLES)
static unsigned int idle_counter = 0;
/* Cheapo buffer align macro to align to the 16-16 PCM size */
#define ALIGN_CHANNEL(start, size) \
({ start = (void *)(((uintptr_t)start + 3) & ~3); \
size &= ~3; })
#if (CONFIG_PLATFORM & PLATFORM_NATIVE)
/* Include any implemented CPU-optimized mixdown routines */
@ -244,7 +239,7 @@ fill_frame:
if (chan->get_more)
{
chan->get_more(&chan->start, &chan->size);
ALIGN_CHANNEL(chan->start, chan->size);
ALIGN_AUDIOBUF(chan->start, chan->size);
}
if (!(chan->start && chan->size))
@ -368,7 +363,7 @@ static void mixer_channel_play_start(struct mixer_channel *chan,
{
pcm_play_unlock(); /* Allow playback while doing any callback */
ALIGN_CHANNEL(start, size);
ALIGN_AUDIOBUF(start, size);
if (!(start && size))
{
@ -377,7 +372,7 @@ static void mixer_channel_play_start(struct mixer_channel *chan,
if (get_more)
{
get_more(&start, &size);
ALIGN_CHANNEL(start, size);
ALIGN_AUDIOBUF(start, size);
}
}