Commit c998b8df authored by Hans Verkuil's avatar Hans Verkuil Committed by Greg Kroah-Hartman

V4L: Fix msp343xG handling regression

The msp3430G and msp3435G models cannot do Automatic Standard Detection,
so these should be forced to BTSC. These chips are early production
versions for the msp34xxG series and are quite rare.

The workaround for kernel 2.6.18 is to use 'standard=32' as msp3400 module
option.
Signed-off-by: default avatarHans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: default avatarMichael Krufky <mkrufky@linuxtv.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent e392c24a
...@@ -904,6 +904,8 @@ static int msp_attach(struct i2c_adapter *adapter, int address, int kind) ...@@ -904,6 +904,8 @@ static int msp_attach(struct i2c_adapter *adapter, int address, int kind)
state->has_virtual_dolby_surround = msp_revision == 'G' && msp_prod_lo == 1; state->has_virtual_dolby_surround = msp_revision == 'G' && msp_prod_lo == 1;
/* Has Virtual Dolby Surround & Dolby Pro Logic: only in msp34x2 */ /* Has Virtual Dolby Surround & Dolby Pro Logic: only in msp34x2 */
state->has_dolby_pro_logic = msp_revision == 'G' && msp_prod_lo == 2; state->has_dolby_pro_logic = msp_revision == 'G' && msp_prod_lo == 2;
/* The msp343xG supports BTSC only and cannot do Automatic Standard Detection. */
state->force_btsc = msp_family == 3 && msp_revision == 'G' && msp_prod_hi == 3;
state->opmode = opmode; state->opmode = opmode;
if (state->opmode == OPMODE_AUTO) { if (state->opmode == OPMODE_AUTO) {
......
...@@ -64,6 +64,7 @@ struct msp_state { ...@@ -64,6 +64,7 @@ struct msp_state {
u8 has_sound_processing; u8 has_sound_processing;
u8 has_virtual_dolby_surround; u8 has_virtual_dolby_surround;
u8 has_dolby_pro_logic; u8 has_dolby_pro_logic;
u8 force_btsc;
int radio; int radio;
int opmode; int opmode;
......
...@@ -960,9 +960,10 @@ int msp34xxg_thread(void *data) ...@@ -960,9 +960,10 @@ int msp34xxg_thread(void *data)
/* setup the chip*/ /* setup the chip*/
msp34xxg_reset(client); msp34xxg_reset(client);
state->std = state->radio ? 0x40 : msp_standard; state->std = state->radio ? 0x40 :
/* start autodetect */ (state->force_btsc && msp_standard == 1) ? 32 : msp_standard;
msp_write_dem(client, 0x20, state->std); msp_write_dem(client, 0x20, state->std);
/* start autodetect */
if (state->std != 1) if (state->std != 1)
goto unmute; goto unmute;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment