jz47xx: Audio path tweaks:

* Increase audio buffer size to better handle IRQ latency (256->2048)
 * Ensure DMA engine is idle prior to starting transfers
 * Set AIC to repeat last sample in case of underflows

Change-Id: I9c45c20481ee072e5882b7586fb7d50bd8ef2f35
This commit is contained in:
Solomon Peachy 2020-09-04 15:55:11 -04:00
parent 5f5e44f593
commit 90a4f28c27
5 changed files with 10 additions and 0 deletions

View file

@ -30,6 +30,10 @@
#if CONFIG_CPU == PP5002 #if CONFIG_CPU == PP5002
/* There's far less time to do mixing because HW FIFOs are short */ /* There's far less time to do mixing because HW FIFOs are short */
#define MIX_FRAME_SAMPLES 64 #define MIX_FRAME_SAMPLES 64
#elif (CONFIG_CPU == JZ4760B) || (CONFIG_CPU == JZ4732)
/* These MIPS32r1 targets have a very high interrupt latency, which
unfortunately causes a lot of audio underruns under even moderate load */
#define MIX_FRAME_SAMPLES 2048
#elif (CONFIG_PLATFORM & PLATFORM_MAEMO5) || defined(DX50) || defined(DX90) #elif (CONFIG_PLATFORM & PLATFORM_MAEMO5) || defined(DX50) || defined(DX90)
/* Maemo 5 needs 2048 samples for decent performance. /* Maemo 5 needs 2048 samples for decent performance.
Otherwise the locking overhead inside gstreamer costs too much */ Otherwise the locking overhead inside gstreamer costs too much */

View file

@ -267,6 +267,7 @@ void audiohw_postinit(void)
void audiohw_init(void) void audiohw_init(void)
{ {
__aic_play_lastsample(); /* on FIFO underflow */
i2s_codec_init(); i2s_codec_init();
} }

View file

@ -115,6 +115,7 @@ void audiohw_init(void)
__cpm_start_aic(); __cpm_start_aic();
/* Init AIC */ /* Init AIC */
__aic_play_lastsample(); /* on FIFO underflow. Versus 0.. */
__i2s_enable_sclk(); __i2s_enable_sclk();
__i2s_external_codec(); __i2s_external_codec();
__i2s_select_msbjustified(); __i2s_select_msbjustified();

View file

@ -137,6 +137,8 @@ void DMA_CALLBACK(DMA_AIC_TX_CHANNEL)(void)
void pcm_play_dma_start(const void *addr, size_t size) void pcm_play_dma_start(const void *addr, size_t size)
{ {
pcm_play_dma_stop();
dma_enable(); dma_enable();
set_dma(addr, size); set_dma(addr, size);

View file

@ -128,6 +128,8 @@ void DMA_CALLBACK(DMA_AIC_TX_CHANNEL)(void)
void pcm_play_dma_start(const void *addr, size_t size) void pcm_play_dma_start(const void *addr, size_t size)
{ {
pcm_play_dma_stop();
__dmac_channel_enable_clk(DMA_AIC_TX_CHANNEL); __dmac_channel_enable_clk(DMA_AIC_TX_CHANNEL);
set_dma(addr, size); set_dma(addr, size);