aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i2c
diff options
context:
space:
mode:
authorJean-Francois Moine <moinejf@free.fr>2014-01-25 12:14:36 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2014-02-13 14:43:46 -0500
commit2470feccbf030652380c2d73304576137b0fb12e (patch)
treee422312c2c12d875ac2401ab39f914405841a15c /drivers/gpu/drm/i2c
parenta8b517e5312124e2dd7b6d6d9afac458aaecfbf3 (diff)
drm/i2c: tda998x: adjust the audio clock divider for S/PDIF
According to some tests on the Cubox (Marvell Armada 510 + TDA19988), the S/PDIF input asks for a greater audio clock divider. Tested-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Russell King <rmk+kernel@arm.linux.org.uk> Signed-off-by: Jean-Francois Moine <moinejf@free.fr> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'drivers/gpu/drm/i2c')
-rw-r--r--drivers/gpu/drm/i2c/tda998x_drv.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/drivers/gpu/drm/i2c/tda998x_drv.c b/drivers/gpu/drm/i2c/tda998x_drv.c
index 666ee24329b9..d0f3a4cbb866 100644
--- a/drivers/gpu/drm/i2c/tda998x_drv.c
+++ b/drivers/gpu/drm/i2c/tda998x_drv.c
@@ -680,10 +680,14 @@ tda998x_configure_audio(struct tda998x_priv *priv,
680 * There is no detailed info in the datasheet, so we just 680 * There is no detailed info in the datasheet, so we just
681 * assume 100MHz requires larger divider. 681 * assume 100MHz requires larger divider.
682 */ 682 */
683 adiv = AUDIO_DIV_SERCLK_8;
683 if (mode->clock > 100000) 684 if (mode->clock > 100000)
684 adiv = AUDIO_DIV_SERCLK_16; 685 adiv++; /* AUDIO_DIV_SERCLK_16 */
685 else 686
686 adiv = AUDIO_DIV_SERCLK_8; 687 /* S/PDIF asks for a larger divider */
688 if (p->audio_format == AFMT_SPDIF)
689 adiv++; /* AUDIO_DIV_SERCLK_16 or _32 */
690
687 reg_write(priv, REG_AUDIO_DIV, adiv); 691 reg_write(priv, REG_AUDIO_DIV, adiv);
688 692
689 /* 693 /*