提交 7f7e846c 编写于 作者: T Torsten Seeboth 提交者: Linus Torvalds

[PATCH] V4L: 919: improves the audio handling for nicam on cx88-audio

Improves the audio handling for NICAM on cx88 audio.
Signed-off-by: NTorsten Seeboth <Torsten.Seeboth@t-online.de>
Signed-off-by: NMauro Carvalho Chehab <mchehab@brturbo.com.br>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 7bde8076
...@@ -123,7 +123,9 @@ static void set_audio_start(struct cx88_core *core, u32 mode) ...@@ -123,7 +123,9 @@ static void set_audio_start(struct cx88_core *core, u32 mode)
cx_write(AUD_VOL_CTL, (1 << 6)); cx_write(AUD_VOL_CTL, (1 << 6));
// start programming // start programming
cx_write(AUD_CTL, 0x0000); cx_write(MO_AUD_DMACNTRL, 0x0000);
msleep(100);
//cx_write(AUD_CTL, 0x0000);
cx_write(AUD_INIT, mode); cx_write(AUD_INIT, mode);
cx_write(AUD_INIT_LD, 0x0001); cx_write(AUD_INIT_LD, 0x0001);
cx_write(AUD_SOFT_RESET, 0x0001); cx_write(AUD_SOFT_RESET, 0x0001);
...@@ -151,6 +153,7 @@ static void set_audio_finish(struct cx88_core *core, u32 ctl) ...@@ -151,6 +153,7 @@ static void set_audio_finish(struct cx88_core *core, u32 ctl)
/* finish programming */ /* finish programming */
cx_write(AUD_SOFT_RESET, 0x0000); cx_write(AUD_SOFT_RESET, 0x0000);
cx_write(MO_AUD_DMACNTRL, 0x0003);
/* unmute */ /* unmute */
volume = cx_sread(SHADOW_AUD_VOL_CTL); volume = cx_sread(SHADOW_AUD_VOL_CTL);
...@@ -341,6 +344,7 @@ static void set_audio_standard_NICAM(struct cx88_core *core, u32 mode) ...@@ -341,6 +344,7 @@ static void set_audio_standard_NICAM(struct cx88_core *core, u32 mode)
{ /* end of list */ }, { /* end of list */ },
}; };
set_audio_start(core,SEL_NICAM);
switch (core->tvaudio) { switch (core->tvaudio) {
case WW_L: case WW_L:
dprintk("%s SECAM-L NICAM (status: devel)\n", __FUNCTION__); dprintk("%s SECAM-L NICAM (status: devel)\n", __FUNCTION__);
...@@ -740,7 +744,7 @@ void cx88_set_tvaudio(struct cx88_core *core) ...@@ -740,7 +744,7 @@ void cx88_set_tvaudio(struct cx88_core *core)
/* set nicam mode - otherwise /* set nicam mode - otherwise
AUD_NICAM_STATUS2 contains wrong values */ AUD_NICAM_STATUS2 contains wrong values */
set_audio_standard_NICAM(core, EN_NICAM_FORCE_MONO1); set_audio_standard_NICAM(core, EN_NICAM_AUTO_STEREO);
if (0 == cx88_detect_nicam(core)) { if (0 == cx88_detect_nicam(core)) {
/* fall back to fm / am mono */ /* fall back to fm / am mono */
set_audio_standard_A2(core, EN_A2_FORCE_MONO1); set_audio_standard_A2(core, EN_A2_FORCE_MONO1);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册