diff options
Diffstat (limited to 'linux/drivers/media/video')
32 files changed, 685 insertions, 623 deletions
| diff --git a/linux/drivers/media/video/bt8xx/bt832.c b/linux/drivers/media/video/bt8xx/bt832.c index 5838fc3d0..d4201f8eb 100644 --- a/linux/drivers/media/video/bt8xx/bt832.c +++ b/linux/drivers/media/video/bt8xx/bt832.c @@ -31,7 +31,6 @@  #include <linux/init.h>  #include <linux/errno.h>  #include <linux/slab.h> -#include <media/audiochip.h>  #include <media/v4l2-common.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) diff --git a/linux/drivers/media/video/bt8xx/bttv-cards.c b/linux/drivers/media/video/bt8xx/bttv-cards.c index e464bcdab..51e47b7cc 100644 --- a/linux/drivers/media/video/bt8xx/bttv-cards.c +++ b/linux/drivers/media/video/bt8xx/bttv-cards.c @@ -41,6 +41,7 @@  #include "bttvp.h"  #include <media/v4l2-common.h> +#include <media/tvaudio.h>  #if 0 /* not working yet */  #include "bt832.h"  #endif @@ -360,7 +361,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 2, 0, 0, 0, 10 }, +		.gpiomux 	= { 2, 0, 0, 0 }, +		.gpiomute 	= 10,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -374,7 +376,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 7,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 1, 2, 3, 4 }, +		.gpiomux 	= { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -388,7 +391,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 7,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 4, 0, 2, 3, 1 }, +		.gpiomux 	= { 4, 0, 2, 3 }, +		.gpiomute 	= 1,  		.no_msp34xx	= 1,  		.needs_tvaudio	= 1,  		.tuner_type     = TUNER_PHILIPS_NTSC, @@ -407,7 +411,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.needs_tvaudio	= 0,  		.tuner_type	= 4,  		.tuner_addr	= ADDR_UNSET, @@ -421,7 +425,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 3,  		.muxsel		= { 2, 3, 1, 0 }, -		.audiomux	= { 0, 1, 0, 1, 3 }, +		.gpiomux 	= { 0, 1, 0, 1 }, +		.gpiomute 	= 3,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -435,7 +440,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 3,  		.muxsel		= { 2, 3, 1, 1 },  		.gpiomask	= 0x0f, -		.audiomux	= { 0x0c, 0x04, 0x08, 0x04, 0 }, +		.gpiomux 	= { 0x0c, 0x04, 0x08, 0x04 },  		/*                0x04 for some cards ?? */  		.needs_tvaudio	= 1,  		.tuner_type	= -1, @@ -452,7 +457,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 3,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 0, 0 }, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -468,7 +473,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xc00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0xc00, 0x800, 0x400, 0xc00, 0 }, +		.gpiomux 	= { 0, 0xc00, 0x800, 0x400 }, +		.gpiomute 	= 0xc00,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -483,7 +489,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 3,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 1, 1, 2, 3, 0 }, +		.gpiomux 	= { 1, 1, 2, 3 },  		.needs_tvaudio	= 0,  		.pll		= PLL_28,  		.tuner_type	= TUNER_TEMIC_PAL, @@ -498,7 +504,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x0f, /* old: 7 */  		.muxsel		= { 2, 0, 1, 1 }, -		.audiomux	= { 0, 1, 2, 3, 4 }, +		.gpiomux 	= { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -513,7 +520,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x3014f,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x20001,0x10001, 0, 0,10 }, +		.gpiomux 	= { 0x20001,0x10001, 0, 0 }, +		.gpiomute 	= 10,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -529,7 +537,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 13, 14, 11, 7, 0, 0 }, +		.gpiomux 	= { 13, 14, 11, 7 },  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -543,7 +551,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 13, 14, 11, 7, 0, 0 }, +		.gpiomux 	= { 13, 14, 11, 7 },  		.needs_tvaudio	= 1,  		.msp34xx_alt    = 1,  		.pll		= PLL_28, @@ -561,7 +569,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 7,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 2, 1, 3, 4 }, /* old: {0, 1, 2, 3, 4} */ +		.gpiomux 	= { 0, 2, 1, 3 }, /* old: {0, 1, 2, 3, 4} */ +		.gpiomute 	= 4,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -576,7 +585,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0 , 0, 1 , 0, 10 }, +		.gpiomux 	= { 0, 0, 1, 0 }, +		.gpiomute 	= 10,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -594,10 +604,11 @@ struct tvcard bttv_tvcards[] = {  		.muxsel		= { 2, 3, 1, 1 },  	#if 0  		/* old */ -		.audiomux	= { 0x01c000, 0, 0x018000, 0x014000, 0x002000, 0 }, +		.gpiomux 	= { 0x01c000, 0, 0x018000, 0x014000, 0x002000 },  	#else  		/* 2003-10-20 by "Anton A. Arapov" <arapov@mail.ru> */ -		.audiomux       = { 0x001e00, 0, 0x018000, 0x014000, 0x002000, 0 }, +		.gpiomux        = { 0x001e00, 0, 0x018000, 0x014000 }, +		.gpiomute 	= 0x002000,  	#endif  		.needs_tvaudio	= 1,  		.pll		= PLL_28, @@ -611,7 +622,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x8300f8,  		.muxsel		= { 2, 3, 1, 1,0 }, -		.audiomux	= { 0x4fa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007 }, +		.gpiomux 	= { 0x4fa007,0xcfa007,0xcfa007,0xcfa007 }, +		.gpiomute 	= 0xcfa007,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -627,7 +639,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 1, 0, 0, 0, 0 }, +		.gpiomux 	= { 1, 0, 0, 0 },  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -641,7 +653,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= -1,  		.gpiomask	= 0x8dff00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.no_msp34xx	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -668,7 +680,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1800,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0x800, 0x1000, 0x1000, 0x1800 }, +		.gpiomux 	= { 0, 0x800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL_I,  		.tuner_addr	= ADDR_UNSET, @@ -682,7 +695,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xc00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 1, 0x800, 0x400, 0xc00, 0 }, +		.gpiomux 	= { 0, 1, 0x800, 0x400 }, +		.gpiomute 	= 0xc00,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -698,7 +712,7 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask	= 7,  		.muxsel		= { 2, 3, -1 },  		.digital_mode   = DIGITAL_MODE_CAMERA, -		.audiomux	= { 0, 0, 0, 0, 0 }, +		.gpiomux 	= { 0, 0, 0, 0 },  		.no_msp34xx	= 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_ALPS_TSBB5_PAL_I, @@ -715,7 +729,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xe00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= {0x400, 0x400, 0x400, 0x400, 0xc00 }, +		.gpiomux 	= {0x400, 0x400, 0x400, 0x400 }, +		.gpiomute 	= 0xc00,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -731,7 +746,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask       = 0x1f0fff,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux       = { 0x20000, 0x30000, 0x10000, 0, 0x40000 }, +		.gpiomux        = { 0x20000, 0x30000, 0x10000, 0 }, +		.gpiomute 	= 0x40000,  		.needs_tvaudio	= 0,  		.tuner_type	= TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -746,7 +762,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 3,  		.gpiomask	= 7,  		.muxsel		= { 2, 0, 1, 1 }, -		.audiomux	= { 0, 1, 2, 3, 4 }, +		.gpiomux 	= { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -760,7 +777,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1800,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0x800, 0x1000, 0x1000, 0x1800 }, +		.gpiomux 	= { 0, 0x800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll            = PLL_28,  		.tuner_type	= TUNER_PHILIPS_SECAM,  		.tuner_addr	= ADDR_UNSET, @@ -776,7 +794,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1f0fff,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x20000, 0x30000, 0x10000, 0x00000, 0x40000 }, +		.gpiomux 	= { 0x20000, 0x30000, 0x10000, 0x00000 }, +		.gpiomute 	= 0x40000,  		.needs_tvaudio	= 0,  		.tuner_type	= TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -823,7 +842,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 1, /* was: 4 */  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 0, 0}, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.needs_tvaudio	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -839,7 +858,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1800,  /* 0x8dfe00 */  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0x0800, 0x1000, 0x1000, 0x1800, 0 }, +		.gpiomux 	= { 0, 0x0800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll            = PLL_28,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -853,7 +873,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 3,  		.gpiomask	= 1,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 1, 0, 0, 0, 0 }, +		.gpiomux 	= { 1, 0, 0, 0 },  		.pll            = PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -869,7 +889,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.needs_tvaudio	= 0,  		.tuner_type	= 4,  		.tuner_addr	= ADDR_UNSET, @@ -883,7 +903,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xffff00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x500, 0, 0x300, 0x900, 0x900 }, +		.gpiomux 	= { 0x500, 0, 0x300, 0x900 }, +		.gpiomute 	= 0x900,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL, @@ -899,11 +920,12 @@ struct tvcard bttv_tvcards[] = {  		.muxsel		= { 2, 3, 1, 1, 0 }, /* TV, CVid, SVid, CVid over SVid connector */  	#if 0  		.gpiomask	= 0xc33000, -		.audiomux	= { 0x422000,0x1000,0x0000,0x620000,0x800000 }, +		.gpiomux 	= { 0x422000,0x1000,0x0000,0x620000,0x800000 },  	#else  		/* Alexander Varakin <avarakin@hotmail.com> [stereo version] */  		.gpiomask	= 0xb33000, -		.audiomux	= { 0x122000,0x1000,0x0000,0x620000,0x800000 }, +		.gpiomux 	= { 0x122000,0x1000,0x0000,0x620000 }, +		.gpiomute 	= 0x800000,  	#endif  		/* Audio Routing for "WinFast 2000 XP" (no tv stereo !)  			gpio23 -- hef4052:nEnable (0x800000) @@ -933,7 +955,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1800,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0x800, 0x1000, 0x1000, 0x1800 }, +		.gpiomux 	= { 0, 0x800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll		= PLL_28,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -949,7 +972,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1800,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 }, +		.gpiomux 	= { 0, 0x800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll		= PLL_28,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -964,7 +988,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xff,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x21, 0x20, 0x24, 0x2c, 0x29, 0x29 }, +		.gpiomux 	= { 0x21, 0x20, 0x24, 0x2c }, +		.gpiomute 	= 0x29,  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -979,7 +1004,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x551e00,  		.muxsel		= { 2, 3, 1, 0 }, -		.audiomux	= { 0x551400, 0x551200, 0, 0, 0x551c00, 0x551200 }, +		.gpiomux 	= { 0x551400, 0x551200, 0, 0 }, +		.gpiomute 	= 0x551c00,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= 1, @@ -995,7 +1021,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x03000F,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 2, 0xd0001, 0, 0, 1 }, +		.gpiomux 	= { 2, 0xd0001, 0, 0 }, +		.gpiomute 	= 1,  		.needs_tvaudio	= 0,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -1012,7 +1039,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 7,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 4, 0, 2, 3, 1 }, +		.gpiomux 	= { 4, 0, 2, 3 }, +		.gpiomute 	= 1,  		.no_msp34xx	= 1,  		.needs_tvaudio	= 1,  		.tuner_type     = TUNER_PHILIPS_NTSC, @@ -1029,7 +1057,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 13, 4, 11, 7, 0, 0 }, +		.gpiomux 	= { 13, 4, 11, 7 },  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -1046,7 +1074,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 1}, -		.audiomux	= { 0, 0, 0, 0, 0}, +		.gpiomux 	= { 0, 0, 0, 0},  		.needs_tvaudio	= 1,  		.no_msp34xx	= 1,  		.pll		= PLL_28, @@ -1062,7 +1090,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xe00b,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0xff9ff6, 0xff9ff6, 0xff1ff7, 0, 0xff3ffc }, +		.gpiomux 	= { 0xff9ff6, 0xff9ff6, 0xff1ff7, 0 }, +		.gpiomute 	= 0xff3ffc,  		.no_msp34xx	= 1,  		.tuner_type	= -1,  		.tuner_addr	= ADDR_UNSET, @@ -1078,7 +1107,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= -1,  		.gpiomask	= 3,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 1, 1, 0, 2, 3 }, +		.gpiomux 	= { 1, 1, 0, 2 }, +		.gpiomute 	= 3,  		.no_msp34xx	= 1,  		.pll		= PLL_NONE,  		.tuner_type	= -1, @@ -1093,7 +1123,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 3,  		.gpiomask	= 0,  		.muxsel		= { 2, 3, 1, 0, 0 }, -		.audiomux	= { 0 }, +		.gpiomux 	= { 0 },  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -1108,7 +1138,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xbcf03f,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0xbc803f, 0xbc903f, 0xbcb03f, 0, 0xbcb03f }, +		.gpiomux 	= { 0xbc803f, 0xbc903f, 0xbcb03f, 0 }, +		.gpiomute 	= 0xbcb03f,  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= 21, @@ -1123,7 +1154,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x70000,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x20000, 0x30000, 0x10000, 0, 0x40000, 0x20000 }, +		.gpiomux 	= { 0x20000, 0x30000, 0x10000, 0 }, +		.gpiomute 	= 0x40000,  		.needs_tvaudio	= 1,  		.no_msp34xx	= 1,  		.pll		= PLL_35, @@ -1142,7 +1174,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= {2,0,0,0,1 }, +		.gpiomux 	= {2,0,0,0 }, +		.gpiomute 	= 1,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= -1, @@ -1157,7 +1190,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x010f00,  		.muxsel		= {2, 3, 0, 0 }, -		.audiomux	= {0x10000, 0, 0x10000, 0, 0, 0 }, +		.gpiomux 	= {0x10000, 0, 0x10000, 0 },  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_ALPS_TSHC6_NTSC, @@ -1174,7 +1207,8 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask	= 0xAA0000,  		.muxsel		= { 2,3,1,1,-1 },  		.digital_mode   = DIGITAL_MODE_CAMERA, -		.audiomux	= { 0x20000, 0, 0x80000, 0x80000, 0xa8000, 0x46000  }, +		.gpiomux 	= { 0x20000, 0, 0x80000, 0x80000 }, +		.gpiomute 	= 0xa8000,  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL_I, @@ -1199,7 +1233,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 7,  		.muxsel         = { 2, 0, 1, 1 }, -		.audiomux       = { 0, 1, 2, 3, 4 }, +		.gpiomux        = { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.pll            = PLL_28,  		.tuner_type     = -1 /* TUNER_ALPS_TMDH2_NTSC */,  		.tuner_addr	= ADDR_UNSET, @@ -1216,7 +1251,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 3,  		.gpiomask       = 0x03000F,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 1, 0xd0001, 0, 0, 10 }, +		.gpiomux 	= { 1, 0xd0001, 0, 0 }, +		.gpiomute 	= 10,  				/* sound path (5 sources):  				MUX1 (mask 0x03), Enable Pin 0x08 (0=enable, 1=disable)  					0= ext. Audio IN @@ -1242,7 +1278,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x1c,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0, 0, 0x10, 8, 4 }, +		.gpiomux 	= { 0, 0, 0x10, 8 }, +		.gpiomute 	= 4,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL, @@ -1254,7 +1291,7 @@ struct tvcard bttv_tvcards[] = {  		/* Tim Röstermundt <rosterm@uni-muenster.de>  		in de.comp.os.unix.linux.hardware:  			options bttv card=0 pll=1 radio=1 gpiomask=0x18e0 -			audiomux=0x44c71f,0x44d71f,0,0x44d71f,0x44dfff +			gpiomux =0x44c71f,0x44d71f,0,0x44d71f,0x44dfff  			options tuner type=5 */  		.name		= "Lifeview FlyVideo 2000 /FlyVideo A2/ Lifetec LT 9415 TV [LR90]",  		.video_inputs	= 4, @@ -1263,7 +1300,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x18e0,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x0000,0x0800,0x1000,0x1000,0x18e0 }, +		.gpiomux 	= { 0x0000,0x0800,0x1000,0x1000 }, +		.gpiomute 	= 0x18e0,  			/* For cards with tda9820/tda9821:  				0x0000: Tuner normal stereo  				0x0080: Tuner A2 SAP (second audio program = Zweikanalton) @@ -1283,7 +1321,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0xF,  		.muxsel         = { 2, 3, 1, 0 }, -		.audiomux       = { 2, 0, 0, 0, 10 }, +		.gpiomux        = { 2, 0, 0, 0 }, +		.gpiomute 	= 10,  		.needs_tvaudio  = 0,  		.pll		= PLL_28,  		.tuner_type	= TUNER_TEMIC_PAL, @@ -1301,7 +1340,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x1800,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 }, +		.gpiomux        = { 0, 0x800, 0x1000, 0x1000 }, +		.gpiomute 	= 0x1800,  		.pll            = PLL_28,  		.tuner_type     = 5,  		.tuner_addr	= ADDR_UNSET, @@ -1318,7 +1358,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 1,  		.gpiomask       = 0,  		.muxsel         = { 3, 1 }, -		.audiomux       = { 0 }, +		.gpiomux        = { 0 },  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_35, @@ -1335,7 +1375,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0xe00,  		.muxsel         = { 2, 3, 1, 1}, -		.audiomux       = { 0x400, 0x400, 0x400, 0x400, 0x800, 0x400 }, +		.gpiomux        = { 0x400, 0x400, 0x400, 0x400 }, +		.gpiomute 	= 0x800,  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_TEMIC_4036FY5_NTSC, @@ -1351,7 +1392,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask       = 0x03000F,  		.muxsel		= { 2, 3, 1, 0 }, -		.audiomux       = { 2, 0, 0, 0, 1 }, +		.gpiomux        = { 2, 0, 0, 0 }, +		.gpiomute 	= 1,  		.pll            = PLL_28,  		.tuner_type	= 0,  		.tuner_addr	= ADDR_UNSET, @@ -1368,7 +1410,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= -1,  		.gpiomask       = 11,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 2, 0, 0, 1, 8 }, +		.gpiomux        = { 2, 0, 0, 1 }, +		.gpiomute 	= 8,  		.pll            = PLL_35,  		.tuner_type     = TUNER_TEMIC_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -1383,7 +1426,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 1,  		.gpiomask       = 0xF,  		.muxsel		= { 2, 2 }, -		.audiomux       = { }, +		.gpiomux        = { },  		.no_msp34xx     = 1,  		.needs_tvaudio  = 0,  		.pll		= PLL_28, @@ -1402,7 +1445,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0xFF,  		.muxsel         = { 2, 3, 1, 0 }, -		.audiomux       = { 1, 0, 4, 4, 9 }, +		.gpiomux        = { 1, 0, 4, 4 }, +		.gpiomute 	= 9,  		.needs_tvaudio  = 0,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL, @@ -1418,7 +1462,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xf03f,  		.muxsel		= { 2, 3, 1, 0 }, -		.audiomux	= { 0xbffe, 0, 0xbfff, 0, 0xbffe }, +		.gpiomux 	= { 0xbffe, 0, 0xbfff, 0 }, +		.gpiomute 	= 0xbffe,  		.pll		= PLL_28,  		.tuner_type	= TUNER_TEMIC_4006FN5_MULTI_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -1435,7 +1480,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= -1,  		.gpiomask	= 1,  		.muxsel		= { 2, 3, 0, 1 }, -		.audiomux	= { 0, 0, 1, 0, 0 }, +		.gpiomux 	= { 0, 0, 1, 0 },  		.no_msp34xx	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_TEMIC_4006FN5_MULTI_PAL, @@ -1454,7 +1499,8 @@ struct tvcard bttv_tvcards[] = {  				/* Radio changed from 1e80 to 0x800 to make  				FlyVideo2000S in .hu happy (gm)*/  				/* -dk-???: set mute=0x1800 for tda9874h daughterboard */ -		.audiomux	= { 0x0000,0x0800,0x1000,0x1000,0x1800, 0x1080 }, +		.gpiomux 	= { 0x0000,0x0800,0x1000,0x1000 }, +		.gpiomute 	= 0x1800,  		.audio_hook	= fv2000s_audio,  		.no_msp34xx	= 1,  		.no_tda9875	= 1, @@ -1472,7 +1518,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0xffff00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x500, 0x500, 0x300, 0x900, 0x900 }, +		.gpiomux 	= { 0x500, 0x500, 0x300, 0x900 }, +		.gpiomute 	= 0x900,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_PHILIPS_PAL, @@ -1489,7 +1536,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x010f00,  		.muxsel         = {2, 3, 0, 0 }, -		.audiomux       = {0x10000, 0, 0x10000, 0, 0, 0 }, +		.gpiomux        = {0x10000, 0, 0x10000, 0 },  		.no_msp34xx     = 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_SHARP_2U5JF5540_NTSC, @@ -1510,7 +1557,8 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask       = 0x4f8a00,  		/* 0x100000: 1=MSP enabled (0=disable again)  		* 0x010000: Connected to "S0" on tda9880 (0=Pal/BG, 1=NTSC) */ -		.audiomux       = {0x947fff, 0x987fff,0x947fff,0x947fff, 0x947fff}, +		.gpiomux        = {0x947fff, 0x987fff,0x947fff,0x947fff }, +		.gpiomute 	= 0x947fff,  		/* tvtuner, radio,   external,internal, mute,  stereo  		* tuner, Composit, SVid, Composit-on-Svid-adapter */  		.muxsel         = { 2, 3 ,0 ,1 }, @@ -1542,7 +1590,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 15,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 0, 11, 7, 13, 0 }, /* TV and Radio with same GPIO ! */ +		.gpiomux        = { 0, 0, 11, 7 }, /* TV and Radio with same GPIO ! */ +		.gpiomute 	= 13,  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = 25, @@ -1581,7 +1630,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x3f,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 0x01, 0x00, 0x03, 0x03, 0x09, 0x02 }, +		.gpiomux 	= { 0x01, 0x00, 0x03, 0x03 }, +		.gpiomute 	= 0x09,  		.needs_tvaudio  = 1,  		.no_msp34xx	= 1,  		.no_tda9875	= 1, @@ -1610,7 +1660,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 4,  		.gpiomask       = 0,  		.muxsel         = { 2, 3, 1, 0, 0 }, -		.audiomux       = { 0 }, +		.gpiomux        = { 0 },  		.needs_tvaudio  = 0,  		.tuner_type     = -1,  		.tuner_addr	= ADDR_UNSET, @@ -1642,7 +1692,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x1C800F,  /* Bit0-2: Audio select, 8-12:remote control 14:remote valid 15:remote reset */  		.muxsel         = { 2, 1, 1, }, -		.audiomux       = { 0, 1, 2, 2, 4 }, +		.gpiomux        = { 0, 1, 2, 2 }, +		.gpiomute 	= 4,  		.needs_tvaudio  = 0,  		.tuner_type     = TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -1661,7 +1712,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x140007,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 1, 2, 3, 4, 0 }, +		.gpiomux        = { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.tuner_type     = TUNER_PHILIPS_NTSC,  		.tuner_addr	= ADDR_UNSET,  		.radio_addr     = ADDR_UNSET, @@ -1675,7 +1727,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = -1,  		.gpiomask       = 0,  		.muxsel         = { 2, 3, 1, 0 }, -		.audiomux       = { 0 }, +		.gpiomux        = { 0 },  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_28, @@ -1691,13 +1743,14 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 7,  		.muxsel         = { 2, 3, 1, 1 },   /* Tuner, SVid, SVHS, SVid to SVHS connector */ -		.audiomux       = { 0 ,0 ,4, 4,4,4},/* Yes, this tuner uses the same audio output for TV and FM radio! +		.gpiomux        = { 0, 0, 4, 4 },/* Yes, this tuner uses the same audio output for TV and FM radio!  						* This card lacks external Audio In, so we mute it on Ext. & Int.  						* The PCB can take a sbx1637/sbx1673, wiring unknown.  						* This card lacks PCI subsystem ID, sigh. -						* audiomux=1: lower volume, 2+3: mute +						* gpiomux =1: lower volume, 2+3: mute  						* btwincap uses 0x80000/0x80003  						*/ +		.gpiomute 	= 4,  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_28, @@ -1744,7 +1797,7 @@ struct tvcard bttv_tvcards[] = {  		.radio_addr     = ADDR_UNSET,  		.gpiomask       = 7, -		.audiomux       = {7}, +		.gpiomux        = {7},  	},  	[BTTV_BOARD_GVBCTV5PCI] = {  		.name           = "IODATA GV-BCTV5/PCI", @@ -1754,7 +1807,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x0f0f80,  		.muxsel         = {2, 3, 1, 0 }, -		.audiomux       = {0x030000, 0x010000, 0, 0, 0x020000, 0}, +		.gpiomux        = {0x030000, 0x010000, 0, 0 }, +		.gpiomute 	= 0x020000,  		.no_msp34xx     = 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_PHILIPS_NTSC_M, @@ -1984,7 +2038,7 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask       = 2,  		/* TV, Comp1, Composite over SVID con, SVID */  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 2, 2, 0, 0, 0 }, +		.gpiomux        = { 2, 2, 0, 0 },  		.pll            = PLL_28,  		.has_radio      = 1,  		.tuner_type     = TUNER_PHILIPS_PAL, @@ -2008,7 +2062,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = -1,  		.gpiomask       = 7,  		.muxsel         = { 2, 3, 1, 1}, -		.audiomux       = { 0, 1, 2, 3, 4}, +		.gpiomux        = { 0, 1, 2, 3}, +		.gpiomute 	= 4,  		.needs_tvaudio  = 1,  		.tuner_type     = 5,  		.tuner_addr	= ADDR_UNSET, @@ -2040,7 +2095,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = -1,  		.gpiomask       = 0,  		.muxsel         = { 2, 3 }, -		.audiomux       = { 0 }, +		.gpiomux        = { 0 },  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_28, @@ -2059,7 +2114,8 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask       = 0x001e8007,  		.muxsel         = { 2, 3, 1, 0 },  		/*                  Tuner, Radio, external, internal, off,  on */ -		.audiomux       = { 0x08,  0x0f,  0x0a,     0x08,     0x0f, 0x08 }, +		.gpiomux        = { 0x08,  0x0f,  0x0a,     0x08 }, +		.gpiomute 	= 0x0f,  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_28, @@ -2176,7 +2232,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = -1,  		.gpiomask       = 0,  		.muxsel         = { 2, 3, 1, 0 }, -		.audiomux       = { 0 }, +		.gpiomux        = { 0 },  		.needs_tvaudio  = 0,  		.no_msp34xx     = 1,  		.pll            = PLL_28, @@ -2193,7 +2249,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 3,  		.gpiomask       = 0x00,  		.muxsel         = { 2, 3, 1, 0 }, -		.audiomux       = { 0, 0, 0, 0, 0, 0 }, /* card has no audio */ +		.gpiomux        = { 0, 0, 0, 0 }, /* card has no audio */  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = -1, @@ -2208,7 +2264,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 3,  		.gpiomask       = 0x00,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 0, 0, 0, 0, 0 }, /* card has no audio */ +		.gpiomux        = { 0, 0, 0, 0 }, /* card has no audio */  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = -1, @@ -2228,7 +2284,7 @@ struct tvcard bttv_tvcards[] = {  					via the upper nibble of muxsel. here: used for  					xternal video-mux */  		.muxsel         = { 0x02, 0x12, 0x22, 0x32, 0x03, 0x13, 0x23, 0x33, 0x01, 0x00 }, -		.audiomux       = { 0, 0, 0, 0, 0, 0 }, /* card has no audio */ +		.gpiomux        = { 0, 0, 0, 0 }, /* card has no audio */  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = -1, @@ -2246,7 +2302,7 @@ struct tvcard bttv_tvcards[] = {  					via the upper nibble of muxsel. here: used for  					xternal video-mux */  		.muxsel         = { 0x02, 0x12, 0x22, 0x32, 0x03, 0x13, 0x23, 0x33, 0x01, 0x01 }, -		.audiomux       = { 0, 0, 0, 0, 0, 0 }, /* card has no audio */ +		.gpiomux        = { 0, 0, 0, 0 }, /* card has no audio */  		.needs_tvaudio  = 1,  		.pll            = PLL_28,  		.tuner_type     = -1, @@ -2334,7 +2390,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 3,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 1, 1, 1, 1, 0 }, +		.gpiomux        = { 1, 1, 1, 1 },  		.needs_tvaudio  = 1,  		.tuner_type     = TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -2365,7 +2421,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x008007,  		.muxsel         = { 2, 3, 0, 0 }, -		.audiomux       = { 0, 0, 0, 0, 0x000003, 0 }, +		.gpiomux        = { 0, 0, 0, 0 }, +		.gpiomute 	= 0x000003,  		.pll            = PLL_28,  		.tuner_type     = TUNER_PHILIPS_PAL,  		.tuner_addr	= ADDR_UNSET, @@ -2401,7 +2458,7 @@ struct tvcard bttv_tvcards[] = {  		.needs_tvaudio  = 0,  		.gpiomask       = 0x68,  		.muxsel         = { 2, 3, 1 }, -		.audiomux       = { 0x68, 0x68, 0x61, 0x61, 0x00 }, +		.gpiomux        = { 0x68, 0x68, 0x61, 0x61 },  		.pll            = PLL_28,  	}, @@ -2416,7 +2473,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x008007,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 1, 2, 2, 3 }, +		.gpiomux        = { 0, 1, 2, 2 }, +		.gpiomute 	= 3,  		.needs_tvaudio  = 0,  		.pll            = PLL_28,  		.tuner_type     = TUNER_PHILIPS_PAL, @@ -2441,7 +2499,7 @@ struct tvcard bttv_tvcards[] = {  		.no_tda9875     = 1,  		.no_tda7432     = 1,  		.muxsel         = {2,2,2,2},/*878A input is always MUX0, see above.*/ -		.audiomux       = { 0, 0, 0, 0, 0, 0 }, /* card has no audio */ +		.gpiomux        = { 0, 0, 0, 0 }, /* card has no audio */  		.pll            = PLL_28,  		.needs_tvaudio  = 0,  		.muxsel_hook    = picolo_tetra_muxsel,/*Required as it doesn't follow the classic input selection policy*/ @@ -2459,7 +2517,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x0000000f,  		.muxsel         = { 2, 1, 1 }, -		.audiomux       = { 0x02, 0x00, 0x00, 0x00, 0x00 }, +		.gpiomux        = { 0x02, 0x00, 0x00, 0x00 },  		.tuner_type     = TUNER_TEMIC_PAL,  		.tuner_addr	= ADDR_UNSET,  		.radio_addr     = ADDR_UNSET, @@ -2515,7 +2573,7 @@ struct tvcard bttv_tvcards[] = {  		.muxsel           = { 2, 2, 2, 2, 2, 2, 2, 2,  				3, 3, 3, 3, 3, 3, 3, 3 },  		.muxsel_hook      = sigmaSQ_muxsel, -		.audiomux         = { 0 }, +		.gpiomux          = { 0 },  		.no_msp34xx       = 1,  		.pll              = PLL_28,  		.tuner_type       = -1, @@ -2532,7 +2590,7 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask         = 0x0,  		.muxsel           = { 2, 2, 2, 2 },  		.muxsel_hook      = sigmaSLC_muxsel, -		.audiomux         = { 0 }, +		.gpiomux          = { 0 },  		.no_msp34xx       = 1,  		.pll              = PLL_28,  		.tuner_type       = -1, @@ -2550,7 +2608,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = -1,  		.gpiomask       = 0xFF,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 2, 0, 0, 0, 10 }, +		.gpiomux        = { 2, 0, 0, 0 }, +		.gpiomute 	= 10,  		.needs_tvaudio  = 0,  		.pll            = PLL_28,  		.tuner_type     = TUNER_PHILIPS_PAL, @@ -2584,7 +2643,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x3f,  		.muxsel         = {2, 3, 1, 0 }, -		.audiomux       = {0x31, 0x31, 0x31, 0x31, 0x31, 0x31 }, +		.gpiomux        = {0x31, 0x31, 0x31, 0x31 }, +		.gpiomute 	= 0x31,  		.no_msp34xx     = 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_PHILIPS_NTSC_M, @@ -2607,7 +2667,7 @@ struct tvcard bttv_tvcards[] = {  		.tuner_addr	= ADDR_UNSET,  		.radio_addr     = ADDR_UNSET,  		.gpiomask       = 0x008007, -		.audiomux       = { 0, 0x000001,0,0, 0 }, +		.gpiomux        = { 0, 0x000001,0,0 },  		.needs_tvaudio  = 1,  		.has_radio      = 1,  	}, @@ -2717,7 +2777,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.muxsel		= { 2, 3, 1 },  		.gpiomask       = 0x00e00007, -		.audiomux       = { 0x00400005, 0, 0x00000001, 0, 0x00c00007, 0 }, +		.gpiomux        = { 0x00400005, 0, 0x00000001, 0 }, +		.gpiomute 	= 0x00c00007,  		.no_msp34xx     = 1,  		.no_tda9875     = 1,  		.no_tda7432     = 1, @@ -2733,7 +2794,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x01fe00,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux       = { 0x001e00, 0, 0x018000, 0x014000, 0x002000, 0 }, +		.gpiomux        = { 0x001e00, 0, 0x018000, 0x014000 }, +		.gpiomute 	= 0x002000,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= TUNER_YMEC_TVF66T5_B_DFF, @@ -2750,7 +2812,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x001c0007,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 1, 2, 2, 3 }, +		.gpiomux        = { 0, 1, 2, 2 }, +		.gpiomute 	= 3,  		.needs_tvaudio  = 0,  		.pll            = PLL_28,  		.tuner_type     = TUNER_TENA_9533_DI, @@ -2769,7 +2832,8 @@ struct tvcard bttv_tvcards[] = {  		.gpiomask      = 0x01fe00,  		.muxsel        = { 2,3,1,1,-1 },  		.digital_mode  = DIGITAL_MODE_CAMERA, -		.audiomux      = { 0x00400, 0x10400, 0x04400, 0x80000, 0x12400, 0x46000  }, +		.gpiomux       = { 0x00400, 0x10400, 0x04400, 0x80000 }, +		.gpiomute      = 0x12400,  		.no_msp34xx    = 1,  		.pll           = PLL_28,  		.tuner_type    = TUNER_LG_PAL_FM, @@ -2787,7 +2851,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 0x3f,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0x21, 0x20, 0x24, 0x2c, 0x29, 0x29 }, +		.gpiomux        = { 0x21, 0x20, 0x24, 0x2c }, +		.gpiomute 	= 0x29,  		.no_msp34xx     = 1,  		.pll            = PLL_28,  		.tuner_type     = TUNER_YMEC_TVF_5533MF, @@ -2821,7 +2886,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 15,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 2, 0, 0, 0, 1 }, +		.gpiomux 	= { 2, 0, 0, 0 }, +		.gpiomute 	= 1,  		.needs_tvaudio	= 1,  		.pll		= PLL_28,  		.tuner_type	= 2, @@ -2837,7 +2903,7 @@ struct tvcard bttv_tvcards[] = {  		.svhs		= 2,  		.gpiomask	= 0x108007,  		.muxsel		= { 2, 3, 1, 1 }, -		.audiomux	= { 100000, 100002, 100002, 100000 }, +		.gpiomux 	= { 100000, 100002, 100002, 100000 },  		.no_msp34xx	= 1,  		.no_tda9875     = 1,  		.no_tda7432     = 1, @@ -2877,7 +2943,8 @@ struct tvcard bttv_tvcards[] = {  		.svhs           = 2,  		.gpiomask       = 7,  		.muxsel         = { 2, 3, 1, 1 }, -		.audiomux       = { 0, 1, 2, 3, 4 }, +		.gpiomux        = { 0, 1, 2, 3 }, +		.gpiomute 	= 4,  		.tuner_type     = TUNER_TEMIC_4009FR5_PAL,  		.tuner_addr     = ADDR_UNSET,  		.radio_addr     = ADDR_UNSET, @@ -2949,20 +3016,20 @@ void __devinit bttv_idcard(struct bttv *btv)  	if (UNSET != audiomux[0]) {  		gpiobits = 0;  		for (i = 0; i < 5; i++) { -			bttv_tvcards[btv->c.type].audiomux[i] = audiomux[i]; +			bttv_tvcards[btv->c.type].gpiomux[i] = audiomux[i];  			gpiobits |= audiomux[i];  		}  	} else {  		gpiobits = audioall;  		for (i = 0; i < 5; i++) { -			bttv_tvcards[btv->c.type].audiomux[i] = audioall; +			bttv_tvcards[btv->c.type].gpiomux[i] = audioall;  		}  	}  	bttv_tvcards[btv->c.type].gpiomask = (UNSET != gpiomask) ? gpiomask : gpiobits;  	printk(KERN_INFO "bttv%d: gpio config override: mask=0x%x, mux=",  	       btv->c.nr,bttv_tvcards[btv->c.type].gpiomask);  	for (i = 0; i < 5; i++) { -		printk("%s0x%x", i ? "," : "", bttv_tvcards[btv->c.type].audiomux[i]); +		printk("%s0x%x", i ? "," : "", bttv_tvcards[btv->c.type].gpiomux[i]);  	}  	printk("\n");  } @@ -3841,18 +3908,18 @@ void bttv_tda9880_setnorm(struct bttv *btv, int norm)  {  	/* fix up our card entry */  	if(norm==VIDEO_MODE_NTSC) { -		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].audiomux[0]=0x957fff; -		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].audiomux[4]=0x957fff; +		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].gpiomux[TVAUDIO_INPUT_TUNER]=0x957fff; +		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].gpiomute=0x957fff;  		dprintk("bttv_tda9880_setnorm to NTSC\n");  	}  	else { -		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].audiomux[0]=0x947fff; -		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].audiomux[4]=0x947fff; +		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].gpiomux[TVAUDIO_INPUT_TUNER]=0x947fff; +		bttv_tvcards[BTTV_BOARD_VOODOOTV_FM].gpiomute=0x947fff;  		dprintk("bttv_tda9880_setnorm to PAL\n");  	}  	/* set GPIO according */  	gpio_bits(bttv_tvcards[btv->c.type].gpiomask, -		  bttv_tvcards[btv->c.type].audiomux[btv->audio]); +		  bttv_tvcards[btv->c.type].gpiomux[btv->audio]);  } diff --git a/linux/drivers/media/video/bt8xx/bttv-driver.c b/linux/drivers/media/video/bt8xx/bttv-driver.c index 83458f993..0e1aae5d0 100644 --- a/linux/drivers/media/video/bt8xx/bttv-driver.c +++ b/linux/drivers/media/video/bt8xx/bttv-driver.c @@ -37,6 +37,8 @@  #include <linux/kdev_t.h>  #include "bttvp.h"  #include <media/v4l2-common.h> +#include <media/tvaudio.h> +#include <media/msp3400.h>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)  #include <linux/dma-mapping.h> @@ -942,50 +944,103 @@ video_mux(struct bttv *btv, unsigned int input)  static char *audio_modes[] = {  	"audio: tuner", "audio: radio", "audio: extern", -	"audio: intern", "audio: off" +	"audio: intern", "audio: mute"  };  static int -audio_mux(struct bttv *btv, int mode) +audio_mux(struct bttv *btv, int input, int mute)  { -	int val,mux,i2c_mux,signal; +	int gpio_val, signal; +	struct v4l2_control ctrl; +	struct i2c_client *c;  	gpio_inout(bttv_tvcards[btv->c.type].gpiomask,  		   bttv_tvcards[btv->c.type].gpiomask);  	signal = btread(BT848_DSTATUS) & BT848_DSTATUS_HLOC; -	switch (mode) { -	case AUDIO_MUTE: -		btv->audio |= AUDIO_MUTE; -		break; -	case AUDIO_UNMUTE: -		btv->audio &= ~AUDIO_MUTE; -		break; -	case AUDIO_TUNER: -	case AUDIO_RADIO: -	case AUDIO_EXTERN: -	case AUDIO_INTERN: -		btv->audio &= AUDIO_MUTE; -		btv->audio |= mode; -	} -	i2c_mux = mux = (btv->audio & AUDIO_MUTE) ? AUDIO_OFF : btv->audio; -	if (btv->opt_automute && !signal && !btv->radio_user) -		mux = AUDIO_OFF; +	btv->mute = mute; +	btv->audio = input; + +	/* automute */ +	mute = mute || (btv->opt_automute && !signal && !btv->radio_user); + +	if (mute) +		gpio_val = bttv_tvcards[btv->c.type].gpiomute; +	else +		gpio_val = bttv_tvcards[btv->c.type].gpiomux[input];  #if 0 -	printk("bttv%d: amux: mode=%d audio=%d signal=%s mux=%d/%d irq=%s\n", -	       btv->c.nr, mode, btv->audio, signal ? "yes" : "no", -	       mux, i2c_mux, in_interrupt() ? "yes" : "no"); +	printk("bttv%d: amux: input=%d mute=%d signal=%s gpio_mux=%d irq=%s\n", +	       btv->c.nr, input, mute, signal ? "yes" : "no", +	       gpio_val, in_interrupt() ? "yes" : "no");  #endif -	val = bttv_tvcards[btv->c.type].audiomux[mux]; -	gpio_bits(bttv_tvcards[btv->c.type].gpiomask,val); +	gpio_bits(bttv_tvcards[btv->c.type].gpiomask, gpio_val);  	if (bttv_gpio) -		bttv_gpio_tracking(btv,audio_modes[mux]); -	if (!in_interrupt()) -		bttv_call_i2c_clients(btv,AUDC_SET_INPUT,&(i2c_mux)); +		bttv_gpio_tracking(btv, audio_modes[mute ? 4 : input]); +	if (in_interrupt()) +		return 0; + +	ctrl.id = V4L2_CID_AUDIO_MUTE; +	ctrl.value = btv->mute; +	bttv_call_i2c_clients(btv, VIDIOC_S_CTRL, &ctrl); +	c = btv->i2c_msp34xx_client; +	if (c) { +		struct v4l2_routing route; + +		/* Note: the inputs tuner/radio/extern/intern are translated +		   to msp routings. This assumes common behavior for all msp3400 +		   based TV cards. When this assumption fails, then the +		   specific MSP routing must be added to the card table. +		   For now this is sufficient. */ +		switch (input) { +		case TVAUDIO_INPUT_RADIO: +			route.input = MSP_INPUT(MSP_IN_SCART_2, MSP_IN_TUNER_1, +				    MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART); +			break; +		case TVAUDIO_INPUT_EXTERN: +			route.input = MSP_INPUT(MSP_IN_SCART_1, MSP_IN_TUNER_1, +				    MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART); +			break; +		case TVAUDIO_INPUT_INTERN: +			/* Yes, this is the same input as for RADIO. I doubt +			   if this is ever used. The only board with an INTERN +			   input is the BTTV_BOARD_AVERMEDIA98. I wonder how +			   that was tested. My guess is that the whole INTERN +			   input does not work. */ +			route.input = MSP_INPUT(MSP_IN_SCART_2, MSP_IN_TUNER_1, +				    MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART); +			break; +		case TVAUDIO_INPUT_TUNER: +		default: +			route.input = MSP_INPUT_DEFAULT; +			break; +		} +		route.output = MSP_OUTPUT_DEFAULT; +		c->driver->command(c, VIDIOC_INT_S_AUDIO_ROUTING, &route); +	} +	c = btv->i2c_tvaudio_client; +	if (c) { +		struct v4l2_routing route; + +		route.input = input; +		route.output = 0; +		c->driver->command(c, VIDIOC_INT_S_AUDIO_ROUTING, &route); +	}  	return 0;  } +static inline int +audio_mute(struct bttv *btv, int mute) +{ +	return audio_mux(btv, btv->audio, mute); +} + +static inline int +audio_input(struct bttv *btv, int input) +{ +	return audio_mux(btv, input, btv->mute); +} +  static void  i2c_vidiocschan(struct bttv *btv)  { @@ -1049,8 +1104,8 @@ set_input(struct bttv *btv, unsigned int input)  	} else {  		video_mux(btv,input);  	} -	audio_mux(btv,(input == bttv_tvcards[btv->c.type].tuner ? -		       AUDIO_TUNER : AUDIO_EXTERN)); +	audio_input(btv,(input == bttv_tvcards[btv->c.type].tuner ? +		       TVAUDIO_INPUT_TUNER : TVAUDIO_INPUT_EXTERN));  	set_tvnorm(btv,btv->tvnorm);  	i2c_vidiocschan(btv);  } @@ -1262,10 +1317,10 @@ static int set_control(struct bttv *btv, struct v4l2_control *c)  	case V4L2_CID_AUDIO_MUTE:  		if (c->value) {  			va.flags |= VIDEO_AUDIO_MUTE; -			audio_mux(btv, AUDIO_MUTE); +			audio_mute(btv, 1);  		} else {  			va.flags &= ~VIDEO_AUDIO_MUTE; -			audio_mux(btv, AUDIO_UNMUTE); +			audio_mute(btv, 0);  		}  		break; @@ -1680,7 +1735,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)  			return -EINVAL;  		mutex_lock(&btv->lock); -		audio_mux(btv, (v->flags&VIDEO_AUDIO_MUTE) ? AUDIO_MUTE : AUDIO_UNMUTE); +		audio_mute(btv, (v->flags&VIDEO_AUDIO_MUTE) ? 1 : 0);  		bttv_call_i2c_clients(btv,cmd,v);  		/* card specific hooks */ @@ -1849,7 +1904,8 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)  			bttv_call_i2c_clients(btv, VIDIOCGAUDIO, &va);  			if (t->audmode == V4L2_TUNER_MODE_MONO)  				va.mode = VIDEO_SOUND_MONO; -			else if (t->audmode == V4L2_TUNER_MODE_STEREO) +			else if (t->audmode == V4L2_TUNER_MODE_STEREO || +				 t->audmode == V4L2_TUNER_MODE_LANG1_LANG2)  				va.mode = VIDEO_SOUND_STEREO;  			else if (t->audmode == V4L2_TUNER_MODE_LANG1)  				va.mode = VIDEO_SOUND_LANG1; @@ -3191,8 +3247,8 @@ static int radio_open(struct inode *inode, struct file *file)  	file->private_data = btv; -	bttv_call_i2c_clients(btv,AUDC_SET_RADIO,&btv->tuner_type); -	audio_mux(btv,AUDIO_RADIO); +	bttv_call_i2c_clients(btv,AUDC_SET_RADIO,NULL); +	audio_input(btv,TVAUDIO_INPUT_RADIO);  	mutex_unlock(&btv->lock);  	return 0; @@ -3782,7 +3838,7 @@ static irqreturn_t bttv_irq(int irq, void *dev_id, struct pt_regs * regs)  			bttv_irq_switch_video(btv);  		if ((astat & BT848_INT_HLOCK)  &&  btv->opt_automute) -			audio_mux(btv, -1); +			audio_mute(btv, btv->mute);  /* trigger automute */  		if (astat & (BT848_INT_SCERR|BT848_INT_OCERR)) {  			printk(KERN_INFO "bttv%d: %s%s @ %08x,",btv->c.nr, @@ -4091,7 +4147,7 @@ static int __devinit bttv_probe(struct pci_dev *dev,  		bt848_contrast(btv,32768);  		bt848_hue(btv,32768);  		bt848_sat(btv,32768); -		audio_mux(btv,AUDIO_MUTE); +		audio_mute(btv, 1);  		set_input(btv,0);  	} diff --git a/linux/drivers/media/video/bt8xx/bttv-i2c.c b/linux/drivers/media/video/bt8xx/bttv-i2c.c index 87e6d867a..6576bd3b1 100644 --- a/linux/drivers/media/video/bt8xx/bttv-i2c.c +++ b/linux/drivers/media/video/bt8xx/bttv-i2c.c @@ -317,6 +317,10 @@ static int attach_inform(struct i2c_client *client)  	if (!client->driver->command)  		return 0; +	if (client->driver->id == I2C_DRIVERID_MSP3400) +		btv->i2c_msp34xx_client = client; +	if (client->driver->id == I2C_DRIVERID_TVAUDIO) +		btv->i2c_tvaudio_client = client;  	if (btv->tuner_type != UNSET) {  		struct tuner_setup tun_setup; diff --git a/linux/drivers/media/video/bt8xx/bttv.h b/linux/drivers/media/video/bt8xx/bttv.h index 4d86607f2..563b4fb61 100644 --- a/linux/drivers/media/video/bt8xx/bttv.h +++ b/linux/drivers/media/video/bt8xx/bttv.h @@ -236,7 +236,8 @@ struct tvcard  	unsigned int digital_mode; // DIGITAL_MODE_CAMERA or DIGITAL_MODE_VIDEO  	u32 gpiomask;  	u32 muxsel[16]; -	u32 audiomux[6]; /* Tuner, Radio, external, internal, mute, stereo */ +	u32 gpiomux[4];  /* Tuner, Radio, external, internal */ +	u32 gpiomute;    /* GPIO mute setting */  	u32 gpiomask2;   /* GPIO MUX mask */  	/* i2c audio flags */ diff --git a/linux/drivers/media/video/bt8xx/bttvp.h b/linux/drivers/media/video/bt8xx/bttvp.h index d5469ad2b..a6fa1511a 100644 --- a/linux/drivers/media/video/bt8xx/bttvp.h +++ b/linux/drivers/media/video/bt8xx/bttvp.h @@ -50,7 +50,6 @@  #include <linux/device.h>  #endif  #include <media/video-buf.h> -#include <media/audiochip.h>  #include <media/tuner.h>  #include <media/tveeprom.h>  #include <media/ir-common.h> @@ -314,6 +313,8 @@ struct bttv {  	int                        i2c_state, i2c_rc;  	int                        i2c_done;  	wait_queue_head_t          i2c_queue; +	struct i2c_client 	  *i2c_msp34xx_client; +	struct i2c_client 	  *i2c_tvaudio_client;  	/* video4linux (1) */  	struct video_device *video_dev; @@ -344,6 +345,7 @@ struct bttv {  	/* video state */  	unsigned int input;  	unsigned int audio; +	unsigned int mute;  	unsigned long freq;  	int tvnorm,hue,contrast,bright,saturation;  	struct v4l2_framebuffer fbuf; diff --git a/linux/drivers/media/video/cs53l32a.c b/linux/drivers/media/video/cs53l32a.c index 809b4f2b4..97ea28992 100644 --- a/linux/drivers/media/video/cs53l32a.c +++ b/linux/drivers/media/video/cs53l32a.c @@ -87,11 +87,6 @@ static int cs53l32a_command(struct i2c_client *client, unsigned int cmd,  		cs53l32a_write(client, 0x01, 0x01 + (input->index << 4));  		break; -	case VIDIOC_G_AUDIO: -		memset(input, 0, sizeof(*input)); -		input->index = (cs53l32a_read(client, 0x01) >> 4) & 3; -		break; -  	case VIDIOC_G_CTRL:  		if (ctrl->id == V4L2_CID_AUDIO_MUTE) {  			ctrl->value = (cs53l32a_read(client, 0x03) & 0xc0) != 0; diff --git a/linux/drivers/media/video/cx25840/cx25840-audio.c b/linux/drivers/media/video/cx25840/cx25840-audio.c index fff65716f..2b3ad34f0 100644 --- a/linux/drivers/media/video/cx25840/cx25840-audio.c +++ b/linux/drivers/media/video/cx25840/cx25840-audio.c @@ -19,7 +19,6 @@  #include <linux/videodev2.h>  #include <linux/i2c.h> -#include <media/audiochip.h>  #include <media/v4l2-common.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h" diff --git a/linux/drivers/media/video/cx25840/cx25840-core.c b/linux/drivers/media/video/cx25840/cx25840-core.c index ab903c3d4..84f8162a6 100644 --- a/linux/drivers/media/video/cx25840/cx25840-core.c +++ b/linux/drivers/media/video/cx25840/cx25840-core.c @@ -32,7 +32,6 @@  #include <linux/slab.h>  #include <linux/videodev2.h>  #include <linux/i2c.h> -#include <media/audiochip.h>  #include <media/v4l2-common.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h" @@ -775,16 +774,6 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,  		return set_input(client, state->vid_input, input->index);  	} -	case VIDIOC_G_AUDIO: -	{ -		struct v4l2_audio *input = arg; - -		memset(input, 0, sizeof(*input)); -		input->index = state->aud_input; -		input->capability = V4L2_AUDCAP_STEREO; -		break; -	} -  	case VIDIOC_S_FREQUENCY:  		input_change(client);  		break; @@ -832,13 +821,14 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,  			   bilingual -> lang1 */  			cx25840_and_or(client, 0x809, ~0xf, 0x00);  			break; +		case V4L2_TUNER_MODE_STEREO:  		case V4L2_TUNER_MODE_LANG1:  			/* mono      -> mono  			   stereo    -> stereo  			   bilingual -> lang1 */  			cx25840_and_or(client, 0x809, ~0xf, 0x04);  			break; -		case V4L2_TUNER_MODE_STEREO: +		case V4L2_TUNER_MODE_LANG1_LANG2:  			/* mono      -> mono  			   stereo    -> stereo  			   bilingual -> lang1/lang2 */ @@ -846,7 +836,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,  			break;  		case V4L2_TUNER_MODE_LANG2:  			/* mono      -> mono -			   stereo    ->stereo +			   stereo    -> stereo  			   bilingual -> lang2 */  			cx25840_and_or(client, 0x809, ~0xf, 0x01);  			break; diff --git a/linux/drivers/media/video/cx88/cx88-tvaudio.c b/linux/drivers/media/video/cx88/cx88-tvaudio.c index b51d1ea10..8bd458f61 100644 --- a/linux/drivers/media/video/cx88/cx88-tvaudio.c +++ b/linux/drivers/media/video/cx88/cx88-tvaudio.c @@ -889,6 +889,7 @@ void cx88_set_stereo(struct cx88_core *core, u32 mode, int manual)  			set_audio_standard_BTSC(core, 1, EN_BTSC_FORCE_SAP);  			break;  		case V4L2_TUNER_MODE_STEREO: +		case V4L2_TUNER_MODE_LANG1_LANG2:  			set_audio_standard_BTSC(core, 0, EN_BTSC_FORCE_STEREO);  			break;  		} @@ -909,6 +910,7 @@ void cx88_set_stereo(struct cx88_core *core, u32 mode, int manual)  							 EN_NICAM_FORCE_MONO2);  				break;  			case V4L2_TUNER_MODE_STEREO: +			case V4L2_TUNER_MODE_LANG1_LANG2:  				set_audio_standard_NICAM(core,  							 EN_NICAM_FORCE_STEREO);  				break; @@ -930,6 +932,7 @@ void cx88_set_stereo(struct cx88_core *core, u32 mode, int manual)  							      EN_A2_FORCE_MONO2);  					break;  				case V4L2_TUNER_MODE_STEREO: +				case V4L2_TUNER_MODE_LANG1_LANG2:  					set_audio_standard_A2(core,  							      EN_A2_FORCE_STEREO);  					break; diff --git a/linux/drivers/media/video/cx88/cx88.h b/linux/drivers/media/video/cx88/cx88.h index 889ca7c61..a8a0ccd4e 100644 --- a/linux/drivers/media/video/cx88/cx88.h +++ b/linux/drivers/media/video/cx88/cx88.h @@ -28,7 +28,6 @@  #include <media/tuner.h>  #include <media/tveeprom.h> -#include <media/audiochip.h>  #include <media/video-buf.h>  #ifdef HAVE_VIDEO_BUF_DVB  #include <media/video-buf-dvb.h> diff --git a/linux/drivers/media/video/em28xx/em28xx-cards.c b/linux/drivers/media/video/em28xx/em28xx-cards.c index de6d61d3c..3622019e3 100644 --- a/linux/drivers/media/video/em28xx/em28xx-cards.c +++ b/linux/drivers/media/video/em28xx/em28xx-cards.c @@ -29,10 +29,10 @@  #include <linux/usb.h>  #include "compat.h"  #include <media/tuner.h> -#include <media/audiochip.h> +#include <media/msp3400.h>  #include <media/tveeprom.h> +#include <media/audiochip.h>  #include <media/v4l2-common.h> -#include "msp3400.h"  #include "em28xx.h" @@ -148,11 +148,12 @@ struct em28xx_board em28xx_boards[] = {  		.input          = {{  			.type     = EM28XX_VMUX_TELEVISION,  			.vmux     = 0, -			.amux     = 6, +			.amux     = MSP_INPUT_DEFAULT,  		},{  			.type     = EM28XX_VMUX_SVIDEO,  			.vmux     = 2, -			.amux     = 1, +			.amux     = MSP_INPUT(MSP_IN_SCART_1, MSP_IN_TUNER_1, +					MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART),  		}},  	},  #ifdef CONFIG_XC3028 diff --git a/linux/drivers/media/video/em28xx/em28xx-video.c b/linux/drivers/media/video/em28xx/em28xx-video.c index 64d395472..748fd6200 100644 --- a/linux/drivers/media/video/em28xx/em28xx-video.c +++ b/linux/drivers/media/video/em28xx/em28xx-video.c @@ -41,6 +41,7 @@  #include "em28xx.h"  #include <media/tuner.h>  #include <media/v4l2-common.h> +#include <media/msp3400.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h"  #include <linux/moduleparam.h> @@ -241,9 +242,14 @@ static void video_mux(struct em28xx *dev, int index)  	em28xx_videodbg("Setting input index=%d, vmux=%d, amux=%d\n",index,input,dev->ctl_ainput);  	if (dev->has_msp34xx) { +		struct v4l2_routing route; +  		if (dev->i2s_speed)  			em28xx_i2c_call_clients(dev, VIDIOC_INT_I2S_CLOCK_FREQ, &dev->i2s_speed); -		em28xx_i2c_call_clients(dev, VIDIOC_S_AUDIO, &dev->ctl_ainput); +		route.input = dev->ctl_ainput; +		route.output = MSP_OUTPUT(MSP_OUT_SCART1_DA); +		/* Note: this is msp3400 specific */ +		em28xx_i2c_call_clients(dev, VIDIOC_INT_S_AUDIO_ROUTING, &route);  		ainput = EM28XX_AUDIO_SRC_TUNER;  		em28xx_audio_source(dev, ainput);  	} else { diff --git a/linux/drivers/media/video/msp3400-driver.c b/linux/drivers/media/video/msp3400-driver.c index 32d37c7a1..65c99edd8 100644 --- a/linux/drivers/media/video/msp3400-driver.c +++ b/linux/drivers/media/video/msp3400-driver.c @@ -54,7 +54,8 @@  #include <linux/videodev.h>  #include <linux/videodev2.h>  #include <media/v4l2-common.h> -#include <media/audiochip.h> +#include <media/tvaudio.h> +#include <media/msp3400.h>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)  #include <linux/kthread.h>  #include <linux/suspend.h> @@ -62,7 +63,7 @@  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h"  #endif -#include "msp3400.h" +#include "msp3400-driver.h"  /* ---------------------------------------------------------------------- */ @@ -264,31 +265,31 @@ int msp_write_dsp(struct i2c_client *client, int addr, int val)   * ----------------------------------------------------------------------- */  static int scarts[3][9] = { -	/* MASK    IN1     IN2     IN1_DA  IN2_DA  IN3     IN4     MONO    MUTE   */ +       /* MASK   IN1     IN2     IN3     IN4     IN1_DA  IN2_DA  MONO    MUTE   */  	/* SCART DSP Input select */ -	{ 0x0320, 0x0000, 0x0200, -1,     -1,     0x0300, 0x0020, 0x0100, 0x0320 }, +       { 0x0320, 0x0000, 0x0200, 0x0300, 0x0020, -1,     -1,     0x0100, 0x0320 },  	/* SCART1 Output select */ -	{ 0x0c40, 0x0440, 0x0400, 0x0c00, 0x0040, 0x0000, 0x0840, 0x0800, 0x0c40 }, +       { 0x0c40, 0x0440, 0x0400, 0x0000, 0x0840, 0x0c00, 0x0040, 0x0800, 0x0c40 },  	/* SCART2 Output select */ -	{ 0x3080, 0x1000, 0x1080, 0x0000, 0x0080, 0x2080, 0x3080, 0x2000, 0x3000 }, +       { 0x3080, 0x1000, 0x1080, 0x2080, 0x3080, 0x0000, 0x0080, 0x2000, 0x3000 },  };  static char *scart_names[] = { -	"mask", "in1", "in2", "in1 da", "in2 da", "in3", "in4", "mono", "mute" +       "in1", "in2", "in3", "in4", "in1 da", "in2 da", "mono", "mute"  };  void msp_set_scart(struct i2c_client *client, int in, int out)  {  	struct msp_state *state = i2c_get_clientdata(client); -	state->in_scart=in; +	state->in_scart = in; -	if (in >= 1 && in <= 8 && out >= 0 && out <= 2) { -		if (-1 == scarts[out][in]) +	if (in >= 0 && in <= 7 && out >= 0 && out <= 2) { +		if (-1 == scarts[out][in + 1])  			return; -		state->acb &= ~scarts[out][SCART_MASK]; -		state->acb |=  scarts[out][in]; +		state->acb &= ~scarts[out][0]; +		state->acb |=  scarts[out][in + 1];  	} else  		state->acb = 0xf60; /* Mute Input and SCART 1 Output */ @@ -355,37 +356,6 @@ void msp_set_audio(struct i2c_client *client)  	msp_write_dsp(client, 0x0033, loudness);  } -int msp_modus(struct i2c_client *client) -{ -	struct msp_state *state = i2c_get_clientdata(client); - -	if (state->radio) { -		v4l_dbg(1, msp_debug, client, "video mode selected to Radio\n"); -		return 0x0003; -	} - -	if (state->v4l2_std & V4L2_STD_PAL) { -		v4l_dbg(1, msp_debug, client, "video mode selected to PAL\n"); - -#if 1 /* KEEP */ -		/* experimental: not sure this works with all chip versions */ -		return 0x7003; -#else -		/* previous value, try this if it breaks ... */ -		return 0x1003; -#endif -	} -	if (state->v4l2_std & V4L2_STD_NTSC) { -		v4l_dbg(1, msp_debug, client, "video mode selected to NTSC\n"); -		return 0x2003; -	} -	if (state->v4l2_std & V4L2_STD_SECAM) { -		v4l_dbg(1, msp_debug, client, "video mode selected to SECAM\n"); -		return 0x0003; -	} -	return 0x0003; -} -  /* ------------------------------------------------------------------------ */  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) @@ -637,51 +607,11 @@ static int msp_set_ctrl(struct i2c_client *client, struct v4l2_control *ctrl)  static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  {  	struct msp_state *state = i2c_get_clientdata(client); -	u16 *sarg = arg; -	int scart = 0;  	if (msp_debug >= 2)  		v4l_i2c_print_ioctl(client, cmd);  	switch (cmd) { -	case AUDC_SET_INPUT: -		if (*sarg == state->input) -			break; -		state->input = *sarg; -		switch (*sarg) { -		case AUDIO_RADIO: -			/* Hauppauge uses IN2 for the radio */ -			state->mode = MSP_MODE_FM_RADIO; -			scart       = SCART_IN2; -			break; -		case AUDIO_EXTERN_1: -			/* IN1 is often used for external input ... */ -			state->mode = MSP_MODE_EXTERN; -			scart       = SCART_IN1; -			break; -		case AUDIO_EXTERN_2: -			/* ... sometimes it is IN2 through ;) */ -			state->mode = MSP_MODE_EXTERN; -			scart       = SCART_IN2; -			break; -		case AUDIO_TUNER: -			state->mode = -1; -			break; -		default: -			if (*sarg & AUDIO_MUTE) -				msp_set_scart(client, SCART_MUTE, 0); -			break; -		} -		if (scart) { -			state->rxsubchans = V4L2_TUNER_SUB_STEREO; -			msp_set_scart(client, scart, 0); -			msp_write_dsp(client, 0x000d, 0x1900); -			if (state->opmode != OPMODE_AUTOSELECT) -				msp_set_audmode(client); -		} -		msp_wake_thread(client); -		break; -  	case AUDC_SET_RADIO:  		if (state->radio)  			return 0; @@ -744,6 +674,7 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  		if (va->mode != 0 && state->radio == 0) {  			state->audmode = msp_mode_v4l1_to_v4l2(va->mode); +			msp_set_audmode(client);  		}  		break;  	} @@ -780,15 +711,6 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  		break;  	} -	/* msp34xx specific */ -	case MSP_SET_MATRIX: -	{ -		struct msp_matrix *mspm = arg; - -		msp_set_scart(client, mspm->input, mspm->output); -		break; -	} -  	/* --- v4l2 ioctls --- */  	case VIDIOC_S_STD:  	{ @@ -802,90 +724,34 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  		return 0;  	} -	case VIDIOC_ENUMINPUT: -	{ -		struct v4l2_input *i = arg; - -		if (i->index != 0) -			return -EINVAL; - -		i->type = V4L2_INPUT_TYPE_TUNER; -		switch (i->index) { -		case AUDIO_RADIO: -			strcpy(i->name, "Radio"); -			break; -		case AUDIO_EXTERN_1: -			strcpy(i->name, "Extern 1"); -			break; -		case AUDIO_EXTERN_2: -			strcpy(i->name, "Extern 2"); -			break; -		case AUDIO_TUNER: -			strcpy(i->name, "Television"); -			break; -		default: -			return -EINVAL; -		} -		return 0; -	} - -	case VIDIOC_G_AUDIO: +	case VIDIOC_INT_G_AUDIO_ROUTING:  	{ -		struct v4l2_audio *a = arg; - -		memset(a, 0, sizeof(*a)); +		struct v4l2_routing *rt = arg; -		switch (a->index) { -		case AUDIO_RADIO: -			strcpy(a->name, "Radio"); -			break; -		case AUDIO_EXTERN_1: -			strcpy(a->name, "Extern 1"); -			break; -		case AUDIO_EXTERN_2: -			strcpy(a->name, "Extern 2"); -			break; -		case AUDIO_TUNER: -			strcpy(a->name, "Television"); -			break; -		default: -			return -EINVAL; -		} - -		a->capability = V4L2_AUDCAP_STEREO; -		a->mode = 0;  /* TODO: add support for AVL */ +		*rt = state->routing;  		break;  	} -	case VIDIOC_S_AUDIO: +	case VIDIOC_INT_S_AUDIO_ROUTING:  	{ -		struct v4l2_audio *sarg = arg; - -		switch (sarg->index) { -		case AUDIO_RADIO: -			/* Hauppauge uses IN2 for the radio */ -			state->mode = MSP_MODE_FM_RADIO; -			scart       = SCART_IN2; -			break; -		case AUDIO_EXTERN_1: -			/* IN1 is often used for external input ... */ -			state->mode = MSP_MODE_EXTERN; -			scart       = SCART_IN1; -			break; -		case AUDIO_EXTERN_2: -			/* ... sometimes it is IN2 through ;) */ -			state->mode = MSP_MODE_EXTERN; -			scart       = SCART_IN2; -			break; -		case AUDIO_TUNER: -			state->mode = -1; -			break; -		} -		if (scart) { -			state->rxsubchans = V4L2_TUNER_SUB_STEREO; -			msp_set_scart(client, scart, 0); -			msp_write_dsp(client, 0x000d, 0x1900); +		struct v4l2_routing *rt = arg; +		int tuner = (rt->input >> 3) & 1; +		int sc_in = rt->input & 0x7; +		int sc1_out = rt->output & 0xf; +		int sc2_out = (rt->output >> 4) & 0xf; +		u16 val; + +		state->routing = *rt; +		if (state->opmode == OPMODE_AUTOSELECT) { +			val = msp_read_dem(client, 0x30) & ~0x100; +			msp_write_dem(client, 0x30, val | (tuner ? 0x100 : 0)); +		} else { +			val = msp_read_dem(client, 0xbb) & ~0x100; +			msp_write_dem(client, 0xbb, val | (tuner ? 0x100 : 0));  		} +		msp_set_scart(client, sc_in, 0); +		msp_set_scart(client, sc1_out, 1); +		msp_set_scart(client, sc2_out, 2);  		msp_set_audmode(client);  		msp_wake_thread(client);  		break; @@ -918,42 +784,6 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  		break;  	} -	case VIDIOC_G_AUDOUT: -	{ -		struct v4l2_audioout *a = (struct v4l2_audioout *)arg; -		int idx = a->index; - -		memset(a, 0, sizeof(*a)); - -		switch (idx) { -		case 0: -			strcpy(a->name, "Scart1 Out"); -			break; -		case 1: -			strcpy(a->name, "Scart2 Out"); -			break; -		case 2: -			strcpy(a->name, "I2S Out"); -			break; -		default: -			return -EINVAL; -		} -		break; -	} - -	case VIDIOC_S_AUDOUT: -	{ -		struct v4l2_audioout *a = (struct v4l2_audioout *)arg; - -		if (a->index < 0 || a->index > 2) -			return -EINVAL; - -		v4l_dbg(1, msp_debug, client, "Setting audio out on msp34xx to input %i\n", a->index); -		msp_set_scart(client, state->in_scart, a->index + 1); - -		break; -	} -  	case VIDIOC_INT_I2S_CLOCK_FREQ:  	{  		u32 *a = (u32 *)arg; @@ -1031,12 +861,16 @@ static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg)  				(state->rxsubchans & V4L2_TUNER_SUB_STEREO) ? "stereo" : "mono",  				(state->rxsubchans & V4L2_TUNER_SUB_LANG2) ? ", dual" : "");  		} else { -			v4l_info(client, "Mode:     %s\n", p); +			if (state->opmode == OPMODE_AUTODETECT) +				v4l_info(client, "Mode:     %s\n", p);  			v4l_info(client, "Standard: %s (%s%s)\n",  				msp_standard_std_name(state->std),  				(state->rxsubchans & V4L2_TUNER_SUB_STEREO) ? "stereo" : "mono",  				(state->rxsubchans & V4L2_TUNER_SUB_LANG2) ? ", dual" : "");  		} +		v4l_info(client, "Audmode:  0x%04x\n", state->audmode); +		v4l_info(client, "Routing:  0x%08x (input) 0x%08x (output)\n", +				state->routing.input, state->routing.output);  		v4l_info(client, "ACB:      0x%04x\n", state->acb);  		break;  	} @@ -1137,6 +971,9 @@ static int msp_attach(struct i2c_adapter *adapter, int address, int kind)  	state->muted = 0;  	state->i2s_mode = 0;  	init_waitqueue_head(&state->wq); +	/* These are the reset input/output positions */ +	state->routing.input = MSP_INPUT_DEFAULT; +	state->routing.output = MSP_OUTPUT_DEFAULT;  	state->rev1 = msp_read_dsp(client, 0x1e);  	if (state->rev1 != -1) diff --git a/linux/drivers/media/video/msp3400.h b/linux/drivers/media/video/msp3400-driver.h index 5bb277609..1b03cc5a9 100644 --- a/linux/drivers/media/video/msp3400.h +++ b/linux/drivers/media/video/msp3400-driver.h @@ -2,8 +2,10 @@   * $Id: msp3400.h,v 1.11 2006/01/22 13:08:51 hverkuil Exp $   */ -#ifndef MSP3400_H -#define MSP3400_H +#ifndef MSP3400_DRIVER_H +#define MSP3400_DRIVER_H + +#include <media/msp3400.h>  /* ---------------------------------------------------------------------- */ @@ -21,15 +23,14 @@  #define MSP_MODE_BTSC        8  #define MSP_MODE_EXTERN      9 -#define SCART_MASK    0 -#define SCART_IN1     1 -#define SCART_IN2     2 -#define SCART_IN1_DA  3 -#define SCART_IN2_DA  4 -#define SCART_IN3     5 -#define SCART_IN4     6 -#define SCART_MONO    7 -#define SCART_MUTE    8 +#define SCART_IN1     0 +#define SCART_IN2     1 +#define SCART_IN3     2 +#define SCART_IN4     3 +#define SCART_IN1_DA  4 +#define SCART_IN2_DA  5 +#define SCART_MONO    6 +#define SCART_MUTE    7  #define SCART_DSP_IN  0  #define SCART1_OUT    1 @@ -74,7 +75,7 @@ struct msp_state {  	int i2s_mode;  	int main, second;	/* sound carrier */  	int input; -	int source;             /* see msp34xxg_set_source */ +	struct v4l2_routing routing;  	/* v4l2 */  	int audmode; @@ -104,17 +105,16 @@ int msp_reset(struct i2c_client *client);  void msp_set_scart(struct i2c_client *client, int in, int out);  void msp_set_mute(struct i2c_client *client);  void msp_set_audio(struct i2c_client *client); -int msp_modus(struct i2c_client *client);  int msp_sleep(struct msp_state *state, int timeout);  /* msp3400-kthreads.c */  const char *msp_standard_std_name(int std);  void msp_set_audmode(struct i2c_client *client); -void msp_detect_stereo(struct i2c_client *client); +int msp_detect_stereo(struct i2c_client *client);  int msp3400c_thread(void *data);  int msp3410d_thread(void *data);  int msp34xxg_thread(void *data);  void msp3400c_set_mode(struct i2c_client *client, int mode);  void msp3400c_set_carrier(struct i2c_client *client, int cdo1, int cdo2); -#endif /* MSP3400_H */ +#endif /* MSP3400_DRIVER_H */ diff --git a/linux/drivers/media/video/msp3400-kthreads.c b/linux/drivers/media/video/msp3400-kthreads.c index dd8dc256d..0a9b4a2ba 100644 --- a/linux/drivers/media/video/msp3400-kthreads.c +++ b/linux/drivers/media/video/msp3400-kthreads.c @@ -27,7 +27,7 @@  #include <linux/videodev.h>  #include <linux/videodev2.h>  #include <media/v4l2-common.h> -#include <media/audiochip.h> +#include <media/msp3400.h>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)  #include <linux/kthread.h>  #include <linux/suspend.h> @@ -35,7 +35,7 @@  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h"  #endif -#include "msp3400.h" +#include "msp3400-driver.h"  /* this one uses the automatic sound standard detection of newer msp34xx     chip versions */ @@ -51,11 +51,13 @@ static struct {  	{ 0x0004, MSP_CARRIER(6.5), MSP_CARRIER(6.2578125), "6.5/6.25  D/K1 Dual FM-Stereo" },  	{ 0x0005, MSP_CARRIER(6.5), MSP_CARRIER(6.7421875), "6.5/6.74  D/K2 Dual FM-Stereo" },  	{ 0x0006, MSP_CARRIER(6.5), MSP_CARRIER(6.5), "6.5  D/K FM-Mono (HDEV3)" }, +	{ 0x0007, MSP_CARRIER(6.5), MSP_CARRIER(5.7421875), "6.5/5.74  D/K3 Dual FM-Stereo" },  	{ 0x0008, MSP_CARRIER(5.5), MSP_CARRIER(5.85), "5.5/5.85  B/G NICAM FM" },  	{ 0x0009, MSP_CARRIER(6.5), MSP_CARRIER(5.85), "6.5/5.85  L NICAM AM" },  	{ 0x000a, MSP_CARRIER(6.0), MSP_CARRIER(6.55), "6.0/6.55  I NICAM FM" },  	{ 0x000b, MSP_CARRIER(6.5), MSP_CARRIER(5.85), "6.5/5.85  D/K NICAM FM" },  	{ 0x000c, MSP_CARRIER(6.5), MSP_CARRIER(5.85), "6.5/5.85  D/K NICAM FM (HDEV2)" }, +	{ 0x000d, MSP_CARRIER(6.5), MSP_CARRIER(5.85), "6.5/5.85  D/K NICAM FM (HDEV3)" },  	{ 0x0020, MSP_CARRIER(4.5), MSP_CARRIER(4.5), "4.5  M BTSC-Stereo" },  	{ 0x0021, MSP_CARRIER(4.5), MSP_CARRIER(4.5), "4.5  M BTSC-Mono + SAP" },  	{ 0x0030, MSP_CARRIER(4.5), MSP_CARRIER(4.5), "4.5  M EIA-J Japan Stereo" }, @@ -191,13 +193,14 @@ void msp3400c_set_mode(struct i2c_client *client, int mode)  {  	struct msp_state *state = i2c_get_clientdata(client);  	struct msp3400c_init_data_dem *data = &msp3400c_init_data[mode]; +	int tuner = (state->routing.input >> 3) & 1;  	int i;  	v4l_dbg(1, msp_debug, client, "set_mode: %d\n", mode);  	state->mode = mode;  	state->rxsubchans = V4L2_TUNER_SUB_MONO; -	msp_write_dem(client, 0x00bb, data->ad_cv); +	msp_write_dem(client, 0x00bb, data->ad_cv | (tuner ? 0x100 : 0));  	for (i = 5; i >= 0; i--)               /* fir 1 */  		msp_write_dem(client, 0x0001, data->fir1[i]); @@ -213,21 +216,22 @@ void msp3400c_set_mode(struct i2c_client *client, int mode)  	msp3400c_set_carrier(client, data->cdo1, data->cdo2);  	msp_set_source(client, data->dsp_src); -	msp_write_dsp(client, 0x000e, data->dsp_matrix); +	/* set prescales */ -	if (state->has_nicam) { -		/* nicam prescale */ -		msp_write_dsp(client, 0x0010, 0x5a00); /* was: 0x3000 */ -	} +	/* volume prescale for SCART (AM mono input) */ +	msp_write_dsp(client, 0x000d, 0x1900); +	msp_write_dsp(client, 0x000e, data->dsp_matrix); +	if (state->has_nicam) /* nicam prescale */ +		msp_write_dsp(client, 0x0010, 0x5a00);  }  /* Set audio mode. Note that the pre-'G' models do not support BTSC+SAP,     nor do they support stereo BTSC. */  static void msp3400c_set_audmode(struct i2c_client *client)  { -	static char *strmode[] = { "mono", "stereo", "lang2", "lang1" }; +	static char *strmode[] = { "mono", "stereo", "lang2", "lang1", "lang1+lang2" };  	struct msp_state *state = i2c_get_clientdata(client); -	char *modestr = (state->audmode >= 0 && state->audmode < 4) ? +	char *modestr = (state->audmode >= 0 && state->audmode < 5) ?  		strmode[state->audmode] : "unknown";  	int src = 0;	/* channel source: FM/AM, nicam or SCART */ @@ -252,6 +256,7 @@ static void msp3400c_set_audmode(struct i2c_client *client)  		case V4L2_TUNER_MODE_MONO:  		case V4L2_TUNER_MODE_LANG1:  		case V4L2_TUNER_MODE_LANG2: +		case V4L2_TUNER_MODE_LANG1_LANG2:  			msp_write_dsp(client, 0x000e, 0x3000);  			break;  		} @@ -263,6 +268,7 @@ static void msp3400c_set_audmode(struct i2c_client *client)  			msp3400c_set_carrier(client, MSP_CARRIER(6.5), MSP_CARRIER(6.5));  			break;  		case V4L2_TUNER_MODE_STEREO: +		case V4L2_TUNER_MODE_LANG1_LANG2:  			msp3400c_set_carrier(client, MSP_CARRIER(7.2), MSP_CARRIER(7.02));  			break;  		case V4L2_TUNER_MODE_LANG1: @@ -277,7 +283,6 @@ static void msp3400c_set_audmode(struct i2c_client *client)  	case MSP_MODE_FM_NICAM2:  	case MSP_MODE_AM_NICAM:  		v4l_dbg(1, msp_debug, client, "NICAM set_audmode: %s\n",modestr); -		msp3400c_set_carrier(client, state->second, state->main);  		if (state->nicam_on)  			src = 0x0100;  /* NICAM */  		break; @@ -299,6 +304,7 @@ static void msp3400c_set_audmode(struct i2c_client *client)  	/* switch audio */  	switch (state->audmode) {  	case V4L2_TUNER_MODE_STEREO: +	case V4L2_TUNER_MODE_LANG1_LANG2:  		src |= 0x0020;  		break;  	case V4L2_TUNER_MODE_MONO: @@ -433,8 +439,8 @@ static void watch_stereo(struct i2c_client *client)  {  	struct msp_state *state = i2c_get_clientdata(client); -	if (msp3400c_detect_stereo(client)) { -		msp3400c_set_audmode(client); +	if (msp_detect_stereo(client)) { +		msp_set_audmode(client);  	}  	if (msp_once) @@ -477,7 +483,7 @@ int msp3400c_thread(void *data)  		/* mute */  		msp_set_mute(client); -		msp3400c_set_mode(client, MSP_MODE_AM_DETECT /* +1 */ ); +		msp3400c_set_mode(client, MSP_MODE_AM_DETECT);  		val1 = val2 = 0;  		max1 = max2 = -1;  		state->watch_stereo = 0; @@ -585,8 +591,6 @@ int msp3400c_thread(void *data)  				state->second = msp3400c_carrier_detect_65[max2].cdo;  				msp3400c_set_mode(client, MSP_MODE_AM_NICAM);  				msp3400c_set_carrier(client, state->second, state->main); -				/* volume prescale for SCART (AM mono input) */ -				msp_write_dsp(client, 0x000d, 0x1900);  				state->watch_stereo = 1;  			} else if (max2 == 0 && state->has_nicam) {  				/* D/K NICAM */ @@ -677,7 +681,8 @@ int msp3410d_thread(void *data)  		if (msp_sleep(state,200))  			goto restart; -		/* start autodetect */ +		/* start autodetect. Note: autodetect is not supported for +		   NTSC-M and radio, hence we force the standard in those cases. */  		if (state->radio)  			std = 0x40;  		else @@ -721,23 +726,19 @@ int msp3410d_thread(void *data)  			v4l_dbg(1, msp_debug, client, "autodetection failed,"  				" switching to backup standard: %s (0x%04x)\n",  				msp_stdlist[8].name ? msp_stdlist[8].name : "unknown",val); -			val = 0x0009; +			state->std = val = 0x0009;  			msp_write_dem(client, 0x20, val);  		} -		/* set various prescales */ -		msp_write_dsp(client, 0x0d, 0x1900); /* scart */ -		msp_write_dsp(client, 0x0e, 0x2403); /* FM */ -		msp_write_dsp(client, 0x10, 0x5a00); /* nicam */ -  		/* set stereo */  		switch (val) {  		case 0x0008: /* B/G NICAM */  		case 0x000a: /* I NICAM */ -			if (val == 0x0008) -				state->mode = MSP_MODE_FM_NICAM1; -			else +		case 0x000b: /* D/K NICAM */ +			if (val == 0x000a)  				state->mode = MSP_MODE_FM_NICAM2; +			else +				state->mode = MSP_MODE_FM_NICAM1;  			/* just turn on stereo */  			state->rxsubchans = V4L2_TUNER_SUB_STEREO;  			state->nicam_on = 1; @@ -765,6 +766,7 @@ int msp3410d_thread(void *data)  			/* scart routing (this doesn't belong here I think) */  			msp_set_scart(client,SCART_IN2,0);  			break; +		case 0x0002:  		case 0x0003:  		case 0x0004:  		case 0x0005: @@ -774,12 +776,19 @@ int msp3410d_thread(void *data)  			break;  		} -		/* unmute, restore misc registers */ -		msp_set_audio(client); -		msp_write_dsp(client, 0x13, state->acb); +		/* set various prescales */ +		msp_write_dsp(client, 0x0d, 0x1900); /* scart */ +		msp_write_dsp(client, 0x0e, 0x3000); /* FM */ +		if (state->has_nicam) +			msp_write_dsp(client, 0x10, 0x5a00); /* nicam */ +  		if (state->has_i2s_conf)  			msp_write_dem(client, 0x40, state->i2s_mode); +		/* unmute, restore misc registers */ +		msp_set_audio(client); + +		msp_write_dsp(client, 0x13, state->acb);  		msp3400c_set_audmode(client);  		/* monitor tv audio mode, the first time don't wait @@ -804,100 +813,157 @@ int msp3410d_thread(void *data)  /* ----------------------------------------------------------------------- */ -/* msp34xxG + (autoselect no-thread)                                       */ -/* this one uses both automatic standard detection and automatic sound     */ -/* select which are available in the newer G versions                      */ -/* struct msp: only norm, acb and source are really used in this mode      */ - -/* set the same 'source' for the loudspeaker, scart and quasi-peak detector - * the value for source is the same as bit 15:8 of DSP registers 0x08, - * 0x0a and 0x0c: 0=mono, 1=stereo or A|B, 2=SCART, 3=stereo or A, 4=stereo or B - * - * this function replaces msp3400c_set_audmode +/* msp34xxG + (autoselect no-thread) + * this one uses both automatic standard detection and automatic sound + * select which are available in the newer G versions + * struct msp: only norm, acb and source are really used in this mode   */ -static void msp34xxg_set_source(struct i2c_client *client, int source) + +static int msp34xxg_modus(struct i2c_client *client)  {  	struct msp_state *state = i2c_get_clientdata(client); -	/* fix matrix mode to stereo and let the msp choose what -	 * to output according to 'source', as recommended -	 * for MONO (source==0) downmixing set bit[7:0] to 0x30 -	 */ -	int value = (source & 0x07) << 8 | (source == 0 ? 0x30 : 0x20); +	if (state->radio) { +		v4l_dbg(1, msp_debug, client, "selected radio modus\n"); +		return 0x0001; +	} -	v4l_dbg(1, msp_debug, client, "set source to %d (0x%x)\n", source, value); -	msp_set_source(client, value); -	/* -	 * set identification threshold. Personally, I -	 * I set it to a higher value that the default -	 * of 0x190 to ignore noisy stereo signals. -	 * this needs tuning. (recommended range 0x00a0-0x03c0) -	 * 0x7f0 = forced mono mode -	 */ -	/* a2 threshold for stereo/bilingual */ -	msp_write_dem(client, 0x22, msp_stereo_thresh); -	state->source = source; +	if (state->v4l2_std & V4L2_STD_PAL) { +		v4l_dbg(1, msp_debug, client, "selected PAL modus\n"); +		return 0x7001; +	} +	if (state->v4l2_std == V4L2_STD_NTSC_M_JP) { +		v4l_dbg(1, msp_debug, client, "selected M (EIA-J) modus\n"); +		return 0x4001; +	} +	if (state->v4l2_std == V4L2_STD_NTSC_M_KR) { +		v4l_dbg(1, msp_debug, client, "selected M (A2) modus\n"); +		return 0x0001; +	} +	if (state->v4l2_std & V4L2_STD_MN) { +		v4l_dbg(1, msp_debug, client, "selected M (BTSC) modus\n"); +		return 0x2001; +	} +	if (state->v4l2_std & V4L2_STD_SECAM) { +		v4l_dbg(1, msp_debug, client, "selected SECAM modus\n"); +		return 0x6001; +	} +	return 0x0001;  } -/* (re-)initialize the msp34xxg, according to the current norm in state->norm - * return 0 if it worked, -1 if it failed - */ -static int msp34xxg_reset(struct i2c_client *client) +static void msp34xxg_set_source(struct i2c_client *client, u16 reg, int in) + { +	struct msp_state *state = i2c_get_clientdata(client); +	int source, matrix; + +	switch (state->audmode) { +	case V4L2_TUNER_MODE_MONO: +		source = 0; /* mono only */ +		matrix = 0x30; +		break; +	case V4L2_TUNER_MODE_LANG1: +		source = 3; /* stereo or A */ +		matrix = 0x00; +		break; +	case V4L2_TUNER_MODE_LANG2: +		source = 4; /* stereo or B */ +		matrix = 0x10; +		break; +	case V4L2_TUNER_MODE_STEREO: +	case V4L2_TUNER_MODE_LANG1_LANG2: +	default: +		source = 1; /* stereo or A|B */ +		matrix = 0x20; +		break; +	} + +	if (in == MSP_DSP_OUT_TUNER) +		source = (source << 8) | 0x20; +	/* the msp34x2g puts the MAIN_AVC, MAIN and AUX sources in 12, 13, 14 +	   instead of 11, 12, 13. So we add one for that msp version. */ +	else if (in >= MSP_DSP_OUT_MAIN_AVC && state->has_dolby_pro_logic) +		source = ((in + 1) << 8) | matrix; +	else +		source = (in << 8) | matrix; + +	v4l_dbg(1, msp_debug, client, "set source to %d (0x%x) for output %02x\n", +			in, source, reg); +	msp_write_dsp(client, reg, source); +} + +static void msp34xxg_set_sources(struct i2c_client *client) +{ +	struct msp_state *state = i2c_get_clientdata(client); +	u32 in = state->routing.input; + +	msp34xxg_set_source(client, 0x0008, (in >> 4) & 0xf); +	/* quasi-peak detector is set to same input as the loudspeaker (MAIN) */ +	msp34xxg_set_source(client, 0x000c, (in >> 4) & 0xf); +	msp34xxg_set_source(client, 0x0009, (in >> 8) & 0xf); +	msp34xxg_set_source(client, 0x000a, (in >> 12) & 0xf); +	if (state->has_scart23_in_scart2_out) +		msp34xxg_set_source(client, 0x0041, (in >> 16) & 0xf); +	msp34xxg_set_source(client, 0x000b, (in >> 20) & 0xf); +} + +/* (re-)initialize the msp34xxg */ +static void msp34xxg_reset(struct i2c_client *client)  {  	struct msp_state *state = i2c_get_clientdata(client); -	int modus, std; +	int tuner = (state->routing.input >> 3) & 1; +	int modus; + +	/* initialize std to 1 (autodetect) to signal that no standard is +	   selected yet. */ +	state->std = 1; -	if (msp_reset(client)) -		return -1; +	msp_reset(client);  	/* make sure that input/output is muted (paranoid mode) */  	/* ACB, mute DSP input, mute SCART 1 */ -	if (msp_write_dsp(client, 0x13, 0x0f20)) -		return -1; +	msp_write_dsp(client, 0x13, 0x0f20);  	if (state->has_i2s_conf)  		msp_write_dem(client, 0x40, state->i2s_mode);  	/* step-by-step initialisation, as described in the manual */ -	modus = msp_modus(client); -	if (state->radio) -		std = 0x40; -	else -		std = (state->v4l2_std & V4L2_STD_NTSC) ? 0x20 : 1; -	modus &= ~0x03; /* STATUS_CHANGE = 0 */ -	modus |= 0x01;  /* AUTOMATIC_SOUND_DETECTION = 1 */ -	if (msp_write_dem(client, 0x30, modus)) -		return -1; -	if (msp_write_dem(client, 0x20, std)) -		return -1; +	modus = msp34xxg_modus(client); +	modus |= tuner ? 0x100 : 0; +	msp_write_dem(client, 0x30, modus);  	/* write the dsps that may have an influence on  	   standard/audio autodetection right now */ -	msp34xxg_set_source(client, state->source); - -	/* AM/FM Prescale [15:8] 75khz deviation */ -	if (msp_write_dsp(client, 0x0e, 0x3000)) -		return -1; +	msp34xxg_set_sources(client); -	/* NICAM Prescale 9db gain (as recommended) */ -	if (msp_write_dsp(client, 0x10, 0x5a00)) -		return -1; +	msp_write_dsp(client, 0x0d, 0x1900); /* scart */ +	msp_write_dsp(client, 0x0e, 0x3000); /* FM */ +	if (state->has_nicam) +		msp_write_dsp(client, 0x10, 0x5a00); /* nicam */ -	return 0; +	/* set identification threshold. Personally, I +	 * I set it to a higher value than the default +	 * of 0x190 to ignore noisy stereo signals. +	 * this needs tuning. (recommended range 0x00a0-0x03c0) +	 * 0x7f0 = forced mono mode +	 * +	 * a2 threshold for stereo/bilingual. +	 * Note: this register is part of the Manual/Compatibility mode. +	 * It is supported by all 'G'-family chips. +	 */ +	msp_write_dem(client, 0x22, msp_stereo_thresh);  }  int msp34xxg_thread(void *data)  {  	struct i2c_client *client = data;  	struct msp_state *state = i2c_get_clientdata(client); -	int val, std, i; +	int val, i;  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  	msp_setup_thread(state);  #endif  	v4l_dbg(1, msp_debug, client, "msp34xxg daemon started\n"); -	state->source = 1; /* default */  	for (;;) {  		v4l_dbg(2, msp_debug, client, "msp34xxg thread: sleep\n");  		msp_sleep(state, -1); @@ -915,12 +981,14 @@ int msp34xxg_thread(void *data)  		/* setup the chip*/  		msp34xxg_reset(client); -		std = msp_standard; -		if (std != 0x01) +		state->std = state->radio ? 0x40 : msp_standard; +		if (state->std != 1)  			goto unmute; +		/* start autodetect */ +		msp_write_dem(client, 0x20, state->std);  		/* watch autodetect */ -		v4l_dbg(1, msp_debug, client, "triggered autodetect, waiting for result\n"); +		v4l_dbg(1, msp_debug, client, "started autodetect, waiting for result\n");  		for (i = 0; i < 10; i++) {  			if (msp_sleep(state, 100))  				goto restart; @@ -928,20 +996,19 @@ int msp34xxg_thread(void *data)  			/* check results */  			val = msp_read_dem(client, 0x7e);  			if (val < 0x07ff) { -				std = val; +				state->std = val;  				break;  			}  			v4l_dbg(2, msp_debug, client, "detection still in progress\n");  		} -		if (std == 1) { +		if (state->std == 1) {  			v4l_dbg(1, msp_debug, client, "detection still in progress after 10 tries. giving up.\n");  			continue;  		}  	unmute: -		state->std = std; -		v4l_dbg(1, msp_debug, client, "current standard: %s (0x%04x)\n", -			msp_standard_std_name(std), std); +		v4l_dbg(1, msp_debug, client, "detected standard: %s (0x%04x)\n", +			msp_standard_std_name(state->std), state->std);  		/* unmute: dispatch sound to scart output, set scart volume */  		msp_set_audio(client); @@ -950,8 +1017,21 @@ int msp34xxg_thread(void *data)  		if (msp_write_dsp(client, 0x13, state->acb))  			return -1; -		if (state->has_i2s_conf) -			msp_write_dem(client, 0x40, state->i2s_mode); +		/* the periodic stereo/SAP check is only relevant for +		   the 0x20 standard (BTSC) */ +		if (state->std != 0x20) +			continue; + +		state->watch_stereo = 1; + +		/* monitor tv audio mode, the first time don't wait +		   in order to get a quick stereo/SAP update */ +		watch_stereo(client); +		while (state->watch_stereo) { +			watch_stereo(client); +			if (msp_sleep(state, 5000)) +				goto restart; +		}  	}  	v4l_dbg(1, msp_debug, client, "thread: exit\n");  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) @@ -963,13 +1043,13 @@ int msp34xxg_thread(void *data)  	return 0;  } -static void msp34xxg_detect_stereo(struct i2c_client *client) +static int msp34xxg_detect_stereo(struct i2c_client *client)  {  	struct msp_state *state = i2c_get_clientdata(client); -  	int status = msp_read_dem(client, 0x0200);  	int is_bilingual = status & 0x100;  	int is_stereo = status & 0x40; +	int oldrx = state->rxsubchans;  	state->rxsubchans = 0;  	if (is_stereo) @@ -977,42 +1057,31 @@ static void msp34xxg_detect_stereo(struct i2c_client *client)  	else  		state->rxsubchans = V4L2_TUNER_SUB_MONO;  	if (is_bilingual) { -		state->rxsubchans = V4L2_TUNER_SUB_LANG1 | V4L2_TUNER_SUB_LANG2; -		/* I'm supposed to check whether it's SAP or not -		 * and set only LANG2/SAP in this case. Yet, the MSP -		 * does a lot of work to hide this and handle everything -		 * the same way. I don't want to work around it so unless -		 * this is a problem, I'll handle SAP just like lang1/lang2. -		 */ +		if (state->std == 0x20) +			state->rxsubchans |= V4L2_TUNER_SUB_SAP; +		else +			state->rxsubchans = V4L2_TUNER_SUB_LANG1 | V4L2_TUNER_SUB_LANG2;  	}  	v4l_dbg(1, msp_debug, client, "status=0x%x, stereo=%d, bilingual=%d -> rxsubchans=%d\n",  		status, is_stereo, is_bilingual, state->rxsubchans); +	return (oldrx != state->rxsubchans);  }  static void msp34xxg_set_audmode(struct i2c_client *client)  {  	struct msp_state *state = i2c_get_clientdata(client); -	int source; -	switch (state->audmode) { -	case V4L2_TUNER_MODE_MONO: -		source = 0; /* mono only */ -		break; -	case V4L2_TUNER_MODE_STEREO: -		source = 1; /* stereo or A|B, see comment in msp34xxg_get_v4l2_stereo() */ -		/* problem: that could also mean 2 (scart input) */ -		break; -	case V4L2_TUNER_MODE_LANG1: -		source = 3; /* stereo or A */ -		break; -	case V4L2_TUNER_MODE_LANG2: -		source = 4; /* stereo or B */ -		break; -	default: -		source  = 1; -		break; +	if (state->std == 0x20) { +	       if ((state->rxsubchans & V4L2_TUNER_SUB_SAP) && +		   (state->audmode == V4L2_TUNER_MODE_LANG1_LANG2 || +		    state->audmode == V4L2_TUNER_MODE_LANG2)) { +			msp_write_dem(client, 0x20, 0x21); +	       } else { +			msp_write_dem(client, 0x20, 0x20); +	       }  	} -	msp34xxg_set_source(client, source); + +	msp34xxg_set_sources(client);  }  void msp_set_audmode(struct i2c_client *client) @@ -1022,7 +1091,6 @@ void msp_set_audmode(struct i2c_client *client)  	switch (state->opmode) {  	case OPMODE_MANUAL:  	case OPMODE_AUTODETECT: -		state->watch_stereo = 0;  		msp3400c_set_audmode(client);  		break;  	case OPMODE_AUTOSELECT: @@ -1031,18 +1099,17 @@ void msp_set_audmode(struct i2c_client *client)  	}  } -void msp_detect_stereo(struct i2c_client *client) +int msp_detect_stereo(struct i2c_client *client)  {  	struct msp_state *state  = i2c_get_clientdata(client);  	switch (state->opmode) {  	case OPMODE_MANUAL:  	case OPMODE_AUTODETECT: -		msp3400c_detect_stereo(client); -		break; +		return msp3400c_detect_stereo(client);  	case OPMODE_AUTOSELECT: -		msp34xxg_detect_stereo(client); -		break; +		return msp34xxg_detect_stereo(client);  	} +	return 0;  } diff --git a/linux/drivers/media/video/mxb.c b/linux/drivers/media/video/mxb.c index ac1c22ef7..615cc0a1d 100644 --- a/linux/drivers/media/video/mxb.c +++ b/linux/drivers/media/video/mxb.c @@ -792,6 +792,12 @@ static int mxb_ioctl(struct saa7146_fh *fh, unsigned int cmd, void *arg)  				DEB_D(("VIDIOC_S_TUNER: V4L2_TUNER_MODE_STEREO\n"));  				break;  			} +			case V4L2_TUNER_MODE_LANG1_LANG2: { +				mxb->cur_mode = V4L2_TUNER_MODE_LANG1_LANG2; +				byte = TDA9840_SET_BOTH; +				DEB_D(("VIDIOC_S_TUNER: V4L2_TUNER_MODE_LANG1_LANG2\n")); +				break; +			}  			case V4L2_TUNER_MODE_LANG1: {  				mxb->cur_mode = V4L2_TUNER_MODE_LANG1;  				byte = TDA9840_SET_LANG1; diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-audio.c b/linux/drivers/media/video/pvrusb2/pvrusb2-audio.c index c43b98897..79395d540 100644 --- a/linux/drivers/media/video/pvrusb2/pvrusb2-audio.c +++ b/linux/drivers/media/video/pvrusb2/pvrusb2-audio.c @@ -24,9 +24,8 @@  #include "pvrusb2-audio.h"  #include "pvrusb2-hdw-internal.h"  #include "pvrusb2-debug.h" -#include "msp3400.h"  #include <linux/videodev.h> -#include <media/audiochip.h> +#include <media/msp3400.h>  #include <media/v4l2-common.h>  struct pvr2_msp3400_handler { @@ -51,6 +50,8 @@ static int xlat_audiomode_to_v4l2(int id)  		return V4L2_TUNER_MODE_LANG1;  	case PVR2_CVAL_AUDIOMODE_LANG2:  		return V4L2_TUNER_MODE_LANG2; +	case PVR2_CVAL_AUDIOMODE_LANG1_LANG2: +		return V4L2_TUNER_MODE_LANG1_LANG2;  	}  	return V4L2_TUNER_MODE_STEREO;  } @@ -60,8 +61,7 @@ static int xlat_audiomode_to_v4l2(int id)  static void set_stereo(struct pvr2_msp3400_handler *ctxt)  {  	struct pvr2_hdw *hdw = ctxt->hdw; -	struct v4l2_audio ac; -	struct msp_matrix mspm; +	struct v4l2_routing route;  	pvr2_trace(PVR2_TRACE_CHIPS,"i2c msp3400 v4l2 set_stereo"); @@ -73,37 +73,27 @@ static void set_stereo(struct pvr2_msp3400_handler *ctxt)  		pvr2_i2c_client_cmd(ctxt->client,VIDIOC_S_TUNER,&vt);  	} -	memset(&ac,0,sizeof(ac)); -	ac.index = AUDIO_TUNER; +	route.input = MSP_INPUT_DEFAULT; +	route.output = MSP_OUTPUT(MSP_OUT_SCART1_DA);  	switch (hdw->controls[PVR2_CID_INPUT].value) {  	case PVR2_CVAL_INPUT_TV: -		ac.index = AUDIO_TUNER;  		break;  	case PVR2_CVAL_INPUT_RADIO: -		ac.index = AUDIO_RADIO; +		/* Assume that msp34xx also handle FM decoding, in which case +		   we're still using the tuner. */ +		/* HV: actually it is more likely to be the SCART2 input if +		   the ivtv experience is any indication. */ +		route.input = MSP_INPUT(MSP_IN_SCART_2, MSP_IN_TUNER_1, +				    MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART);  		break;  	case PVR2_CVAL_INPUT_SVIDEO:  	case PVR2_CVAL_INPUT_COMPOSITE: -		ac.index = AUDIO_EXTERN_1; +		/* SCART 1 input */ +		route.input = MSP_INPUT(MSP_IN_SCART_1, MSP_IN_TUNER_1, +				    MSP_DSP_OUT_SCART, MSP_DSP_OUT_SCART);  		break;  	} -	pvr2_i2c_client_cmd(ctxt->client,VIDIOC_S_AUDIO,&ac); - -	mspm.input = SCART_IN1_DA; -	switch (hdw->controls[PVR2_CID_INPUT].value) { -	case PVR2_CVAL_INPUT_SVIDEO: -	case PVR2_CVAL_INPUT_COMPOSITE: -		/* Bypass the DSP and just use IN1.  In theory we -		   should be able to permanently just use IN1_DA, but -		   to do that msp3400.ko should be adjusting the DSP -		   input SCART routing correctly when doing video in. -		   Unfortunately that appears not to be the case.  I -		   really hate that module. */ -		mspm.input = SCART_IN1; -		break; -	} -	mspm.output = 1; -	pvr2_i2c_client_cmd(ctxt->client,MSP_SET_MATRIX,&mspm); +	pvr2_i2c_client_cmd(ctxt->client,VIDIOC_INT_S_AUDIO_ROUTING,&route);  } diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.c b/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.c index b87651e5a..539456b44 100644 --- a/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.c +++ b/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.c @@ -158,6 +158,7 @@ static const char *control_values_audiomode[] = {  	[PVR2_CVAL_AUDIOMODE_SAP]    = "SAP",  	[PVR2_CVAL_AUDIOMODE_LANG1]  = "Lang1",  	[PVR2_CVAL_AUDIOMODE_LANG2]  = "Lang2", +	[PVR2_CVAL_AUDIOMODE_LANG1_LANG2] = "Lang1+Lang2",  }; diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.h b/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.h index 667c95a27..085afe566 100644 --- a/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.h +++ b/linux/drivers/media/video/pvrusb2/pvrusb2-hdw.h @@ -119,8 +119,9 @@  #define PVR2_CVAL_AUDIOMODE_SAP 2  #define PVR2_CVAL_AUDIOMODE_LANG1 3  #define PVR2_CVAL_AUDIOMODE_LANG2 4 +#define PVR2_CVAL_AUDIOMODE_LANG1_LANG2 5  #define PVR2_CVAL_AUDIOMODE_MIN PVR2_CVAL_AUDIOMODE_MONO -#define PVR2_CVAL_AUDIOMODE_MAX PVR2_CVAL_AUDIOMODE_LANG2 +#define PVR2_CVAL_AUDIOMODE_MAX PVR2_CVAL_AUDIOMODE_LANG1_LANG2  /* Values that pvr2_hdw_get_signal_status() returns */  #define PVR2_SIGNAL_OK     0x0001 diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-i2c-cmd-v4l2.c b/linux/drivers/media/video/pvrusb2/pvrusb2-i2c-cmd-v4l2.c index 69864782b..7d137a25f 100644 --- a/linux/drivers/media/video/pvrusb2/pvrusb2-i2c-cmd-v4l2.c +++ b/linux/drivers/media/video/pvrusb2/pvrusb2-i2c-cmd-v4l2.c @@ -24,7 +24,6 @@  #include "pvrusb2-hdw-internal.h"  #include "pvrusb2-debug.h"  #include <linux/videodev.h> -#include <media/audiochip.h>  static void set_standard(struct pvr2_hdw *hdw) diff --git a/linux/drivers/media/video/pvrusb2/pvrusb2-v4l2.c b/linux/drivers/media/video/pvrusb2/pvrusb2-v4l2.c index 017d30ad0..e208c4862 100644 --- a/linux/drivers/media/video/pvrusb2/pvrusb2-v4l2.c +++ b/linux/drivers/media/video/pvrusb2/pvrusb2-v4l2.c @@ -593,6 +593,9 @@ static int pvr2_v4l2_do_ioctl(struct inode *inode, struct file *file,  		case PVR2_CVAL_AUDIOMODE_LANG2:  			vt->audmode = V4L2_TUNER_MODE_LANG2;  			break; +		case PVR2_CVAL_AUDIOMODE_LANG1_LANG2: +			vt->audmode = V4L2_TUNER_MODE_LANG1_LANG2; +			break;  		case PVR2_CVAL_AUDIOMODE_SAP:  			vt->audmode = V4L2_TUNER_MODE_SAP;  			break; @@ -620,6 +623,9 @@ static int pvr2_v4l2_do_ioctl(struct inode *inode, struct file *file,  		case V4L2_TUNER_MODE_LANG1:  			val = PVR2_CVAL_AUDIOMODE_LANG1;  			break; +		case V4L2_TUNER_MODE_LANG1_LANG2: +			val = PVR2_CVAL_AUDIOMODE_LANG1_LANG2; +			break;  		case V4L2_TUNER_MODE_SAP: // Also LANG2  			val = PVR2_CVAL_AUDIOMODE_SAP;  			break; diff --git a/linux/drivers/media/video/saa7115.c b/linux/drivers/media/video/saa7115.c index 4f70190ca..4ca5ef008 100644 --- a/linux/drivers/media/video/saa7115.c +++ b/linux/drivers/media/video/saa7115.c @@ -41,7 +41,6 @@  #include <linux/i2c.h>  #include <linux/videodev2.h>  #include <media/v4l2-common.h> -#include <media/audiochip.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h"  #endif diff --git a/linux/drivers/media/video/saa7134/saa7134-tvaudio.c b/linux/drivers/media/video/saa7134/saa7134-tvaudio.c index ccf3ea2b3..c750866b9 100644 --- a/linux/drivers/media/video/saa7134/saa7134-tvaudio.c +++ b/linux/drivers/media/video/saa7134/saa7134-tvaudio.c @@ -506,12 +506,14 @@ static int tvaudio_setstereo(struct saa7134_dev *dev, struct saa7134_tvaudio *au  		[ V4L2_TUNER_MODE_STEREO ] = "stereo",  		[ V4L2_TUNER_MODE_LANG1  ] = "lang1",  		[ V4L2_TUNER_MODE_LANG2  ] = "lang2", +		[ V4L2_TUNER_MODE_LANG1_LANG2  ] = "lang1+lang2",  	};  	static u32 fm[] = {  		[ V4L2_TUNER_MODE_MONO   ] = 0x00,  /* ch1  */  		[ V4L2_TUNER_MODE_STEREO ] = 0x80,  /* auto */  		[ V4L2_TUNER_MODE_LANG1  ] = 0x00,  /* ch1  */  		[ V4L2_TUNER_MODE_LANG2  ] = 0x01,  /* ch2  */ +		[ V4L2_TUNER_MODE_LANG1_LANG2 ] = 0x80,  /* auto */  	};  	u32 reg; diff --git a/linux/drivers/media/video/saa7134/saa7134.h b/linux/drivers/media/video/saa7134/saa7134.h index 85f18e61e..cbcf9adf7 100644 --- a/linux/drivers/media/video/saa7134/saa7134.h +++ b/linux/drivers/media/video/saa7134/saa7134.h @@ -38,7 +38,6 @@  #include "compat.h"  #include <media/tuner.h> -#include <media/audiochip.h>  #include <media/ir-common.h>  #include <media/ir-kbd-i2c.h>  #include <media/video-buf.h> diff --git a/linux/drivers/media/video/tda7432.c b/linux/drivers/media/video/tda7432.c index 5f6bb19d0..78a56f7ef 100644 --- a/linux/drivers/media/video/tda7432.c +++ b/linux/drivers/media/video/tda7432.c @@ -53,7 +53,6 @@  #include "i2c-compat.h"  #else  #endif -#include <media/audiochip.h>  #include <media/v4l2-common.h>  #include <media/i2c-addr.h> diff --git a/linux/drivers/media/video/tda9875.c b/linux/drivers/media/video/tda9875.c index d5f6d4c5a..e97d2b59d 100644 --- a/linux/drivers/media/video/tda9875.c +++ b/linux/drivers/media/video/tda9875.c @@ -32,11 +32,8 @@  #include <linux/init.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) -#include "audiochip.h"  #include "id.h"  #include "i2c-compat.h" -#else -#include <media/audiochip.h>  #endif  #include <media/i2c-addr.h> @@ -57,7 +54,6 @@ I2C_CLIENT_INSMOD;  /* This is a superset of the TDA9875 */  struct tda9875 { -	int mode;  	int rvol, lvol;  	int bass, treble;  	struct i2c_client c; @@ -220,7 +216,6 @@ static void do_tda9875_init(struct i2c_client *client)  	tda9875_write(client, TDA9875_MUT, 0xcc );   /* General mute  */ -	t->mode=AUDIO_UNMUTE;  	t->lvol=t->rvol =0;  	/* 0dB */  	t->bass=0; 			/* 0dB */  	t->treble=0;  		/* 0dB */ diff --git a/linux/drivers/media/video/tuner-core.c b/linux/drivers/media/video/tuner-core.c index d9ddb140a..46fb394d8 100644 --- a/linux/drivers/media/video/tuner-core.c +++ b/linux/drivers/media/video/tuner-core.c @@ -23,7 +23,6 @@  #include <media/tuner.h>  #include <media/v4l2-common.h> -#include <media/audiochip.h>  #if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)  #include "i2c-compat.h"  #endif diff --git a/linux/drivers/media/video/tvaudio.c b/linux/drivers/media/video/tvaudio.c index d204e1348..15c3cc595 100644 --- a/linux/drivers/media/video/tvaudio.c +++ b/linux/drivers/media/video/tvaudio.c @@ -35,7 +35,7 @@  #include "i2c-compat.h"  #else  #endif -#include <media/audiochip.h> +#include <media/tvaudio.h>  #include <media/v4l2-common.h>  #include <media/i2c-addr.h> @@ -107,7 +107,7 @@ struct CHIPDESC {  	/* input switch register + values for v4l inputs */  	int  inputreg; -	int  inputmap[8]; +	int  inputmap[4];  	int  inputmute;  	int  inputmask;  }; @@ -124,9 +124,10 @@ struct CHIPSTATE {  	audiocmd   shadow;  	/* current settings */ -	__u16 left,right,treble,bass,mode; +	__u16 left,right,treble,bass,muted,mode;  	int prevmode;  	int radio; +	int input;  	/* thread */  	pid_t                tpid; @@ -1120,9 +1121,8 @@ static int tda8425_shift12(int val) { return (val >> 12) | 0xf0; }  static int tda8425_initialize(struct CHIPSTATE *chip)  {  	struct CHIPDESC *desc = chiplist + chip->type; -	int inputmap[8] = { /* tuner	*/ TDA8425_S1_CH2, /* radio  */ TDA8425_S1_CH1, -			    /* extern	*/ TDA8425_S1_CH1, /* intern */ TDA8425_S1_OFF, -			    /* off	*/ TDA8425_S1_OFF, /* on     */ TDA8425_S1_CH2}; +	int inputmap[4] = { /* tuner	*/ TDA8425_S1_CH2, /* radio  */ TDA8425_S1_CH1, +			    /* extern	*/ TDA8425_S1_CH1, /* intern */ TDA8425_S1_OFF};  	if (chip->c.adapter->id == I2C_HW_B_RIVA) {  		memcpy (desc->inputmap, inputmap, sizeof (inputmap)); @@ -1317,7 +1317,7 @@ static struct CHIPDESC chiplist[] = {  		.init       = { 4, { TDA9873_SW, 0xa4, 0x06, 0x03 } },  		.inputreg   = TDA9873_SW,  		.inputmute  = TDA9873_MUTE | TDA9873_AUTOMUTE, -		.inputmap   = {0xa0, 0xa2, 0xa0, 0xa0, 0xc0}, +		.inputmap   = {0xa0, 0xa2, 0xa0, 0xa0},  		.inputmask  = TDA9873_INP_MASK|TDA9873_MUTE|TDA9873_AUTOMUTE,  	}, @@ -1465,8 +1465,7 @@ static struct CHIPDESC chiplist[] = {  		.inputmap   = {PIC16C54_MISC_SND_NOTMUTE|PIC16C54_MISC_SWITCH_TUNER,  			     PIC16C54_MISC_SND_NOTMUTE|PIC16C54_MISC_SWITCH_LINE,  			     PIC16C54_MISC_SND_NOTMUTE|PIC16C54_MISC_SWITCH_LINE, -			     PIC16C54_MISC_SND_MUTE,PIC16C54_MISC_SND_MUTE, -			     PIC16C54_MISC_SND_NOTMUTE}, +			     PIC16C54_MISC_SND_MUTE},  		.inputmute  = PIC16C54_MISC_SND_MUTE,  	},  	{ @@ -1624,28 +1623,40 @@ static int chip_detach(struct i2c_client *client)  	return 0;  } +static int tvaudio_set_ctrl(struct CHIPSTATE *chip, struct v4l2_control *ctrl) +{ +	struct CHIPDESC *desc = chiplist + chip->type; + +	switch (ctrl->id) { +	case V4L2_CID_AUDIO_MUTE: +		if (ctrl->value < 0 || ctrl->value >= 2) +			return -ERANGE; +		chip->muted = ctrl->value; +		if (chip->muted) +			chip_write_masked(chip,desc->inputreg,desc->inputmute,desc->inputmask); +		else +			chip_write_masked(chip,desc->inputreg, +					desc->inputmap[chip->input],desc->inputmask); +		break; +	default: +		return -EINVAL; +	} +	return 0; +} + +  /* ---------------------------------------------------------------------- */  /* video4linux interface                                                  */  static int chip_command(struct i2c_client *client,  			unsigned int cmd, void *arg)  { -	__u16 *sarg = arg;  	struct CHIPSTATE *chip = i2c_get_clientdata(client);  	struct CHIPDESC  *desc = chiplist + chip->type;  	v4l_dbg(1, debug, &chip->c, "%s: chip_command 0x%x\n", chip->c.name, cmd);  	switch (cmd) { -	case AUDC_SET_INPUT: -		if (desc->flags & CHIP_HAS_INPUTSEL) { -			if (*sarg & 0x80) -				chip_write_masked(chip,desc->inputreg,desc->inputmute,desc->inputmask); -			else -				chip_write_masked(chip,desc->inputreg,desc->inputmap[*sarg],desc->inputmask); -		} -		break; -  	case AUDC_SET_RADIO:  		chip->radio = 1;  		chip->watch_stereo = 0; @@ -1709,6 +1720,48 @@ static int chip_command(struct i2c_client *client,  		break;  	} +	case VIDIOC_S_CTRL: +		return tvaudio_set_ctrl(chip, arg); + +	case VIDIOC_INT_G_AUDIO_ROUTING: +	{ +		struct v4l2_routing *rt = arg; + +		rt->input = chip->input; +		rt->output = 0; +		break; +	} + +	case VIDIOC_INT_S_AUDIO_ROUTING: +	{ +		struct v4l2_routing *rt = arg; + +		if (!(desc->flags & CHIP_HAS_INPUTSEL) || rt->input >= 4) +				return -EINVAL; +		/* There are four inputs: tuner, radio, extern and intern. */ +		chip->input = rt->input; +		if (chip->muted) +			break; +		chip_write_masked(chip, desc->inputreg, +				desc->inputmap[chip->input], desc->inputmask); +		break; +	} + +	case VIDIOC_S_AUDIO: +	{ +		struct v4l2_audio *sarg = arg; + +		if (!(desc->flags & CHIP_HAS_INPUTSEL) || sarg->index >= 4) +				return -EINVAL; +		/* There are four inputs: tuner, radio, extern and intern. */ +		chip->input = sarg->index; +		if (chip->muted) +			break; +		chip_write_masked(chip, desc->inputreg, +				desc->inputmap[chip->input], desc->inputmask); +		break; +	} +  	case VIDIOC_S_TUNER:  	{  		struct v4l2_tuner *vt = arg; @@ -1721,6 +1774,7 @@ static int chip_command(struct i2c_client *client,  			mode = VIDEO_SOUND_MONO;  			break;  		case V4L2_TUNER_MODE_STEREO: +		case V4L2_TUNER_MODE_LANG1_LANG2:  			mode = VIDEO_SOUND_STEREO;  			break;  		case V4L2_TUNER_MODE_LANG1: diff --git a/linux/drivers/media/video/tveeprom.c b/linux/drivers/media/video/tveeprom.c index b819ba0c8..d82cb967c 100644 --- a/linux/drivers/media/video/tveeprom.c +++ b/linux/drivers/media/video/tveeprom.c @@ -252,32 +252,32 @@ audioIC[] =  	{AUDIO_CHIP_MSP34XX,  "MSP3410D"},  	{AUDIO_CHIP_MSP34XX,  "MSP3415"},  	{AUDIO_CHIP_MSP34XX,  "MSP3430"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP3438"}, +	{AUDIO_CHIP_MSP34XX,  "MSP3438"},  	{AUDIO_CHIP_UNKNOWN,  "CS5331"},  	/* 10-14 */  	{AUDIO_CHIP_MSP34XX,  "MSP3435"},  	{AUDIO_CHIP_MSP34XX,  "MSP3440"},  	{AUDIO_CHIP_MSP34XX,  "MSP3445"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP3411"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP3416"}, +	{AUDIO_CHIP_MSP34XX,  "MSP3411"}, +	{AUDIO_CHIP_MSP34XX,  "MSP3416"},  	/* 15-19 */  	{AUDIO_CHIP_MSP34XX,  "MSP3425"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP3451"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP3418"}, +	{AUDIO_CHIP_MSP34XX,  "MSP3451"}, +	{AUDIO_CHIP_MSP34XX,  "MSP3418"},  	{AUDIO_CHIP_UNKNOWN,  "Type 0x12"},  	{AUDIO_CHIP_UNKNOWN,  "OKI7716"},  	/* 20-24 */ -	{AUDIO_CHIP_UNKNOWN,  "MSP4410"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4420"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4440"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4450"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4408"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4410"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4420"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4440"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4450"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4408"},  	/* 25-29 */ -	{AUDIO_CHIP_UNKNOWN,  "MSP4418"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4428"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4448"}, -	{AUDIO_CHIP_UNKNOWN,  "MSP4458"}, -	{AUDIO_CHIP_UNKNOWN,  "Type 0x1d"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4418"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4428"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4448"}, +	{AUDIO_CHIP_MSP34XX,  "MSP4458"}, +	{AUDIO_CHIP_MSP34XX,  "Type 0x1d"},  	/* 30-34 */  	{AUDIO_CHIP_INTERNAL, "CX880"},  	{AUDIO_CHIP_INTERNAL, "CX881"}, diff --git a/linux/drivers/media/video/v4l2-common.c b/linux/drivers/media/video/v4l2-common.c index b9c56e5e5..e6f23d7b5 100644 --- a/linux/drivers/media/video/v4l2-common.c +++ b/linux/drivers/media/video/v4l2-common.c @@ -332,8 +332,6 @@ static const char *v4l2_int_ioctls[] = {  	[_IOC_NR(DECODER_DUMP)]                = "DECODER_DUMP",  #endif  	[_IOC_NR(AUDC_SET_RADIO)]              = "AUDC_SET_RADIO", -	[_IOC_NR(AUDC_SET_INPUT)]              = "AUDC_SET_INPUT", -	[_IOC_NR(MSP_SET_MATRIX)]              = "MSP_SET_MATRIX",  	[_IOC_NR(TUNER_SET_TYPE_ADDR)]         = "TUNER_SET_TYPE_ADDR",  	[_IOC_NR(TUNER_SET_STANDBY)]           = "TUNER_SET_STANDBY", @@ -439,7 +437,6 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)  	case TUNER_SET_TYPE_ADDR:  	case TUNER_SET_STANDBY:  	case TDA9887_SET_CONFIG: -	case AUDC_SET_INPUT:  	case VIDIOC_OVERLAY_OLD:  	case VIDIOC_STREAMOFF:  	case VIDIOC_G_OUTPUT: @@ -453,12 +450,6 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)  		printk ("%s: value=%d\n", s, *p);  		break;  	} -	case MSP_SET_MATRIX: -	{ -		struct msp_matrix *p=arg; -		printk ("%s: input=%d, output=%d\n", s, p->input, p->output); -		break; -	}  	case VIDIOC_G_AUDIO:  	case VIDIOC_S_AUDIO:  	case VIDIOC_ENUMAUDIO: @@ -487,7 +478,7 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)  		struct v4l2_buffer *p=arg;  		struct v4l2_timecode *tc=&p->timecode;  		printk ("%s: %02ld:%02d:%02d.%08ld index=%d, type=%s, " -			"bytesused=%d, flags=0x%08d, " +			"bytesused=%d, flags=0x%08x, "  			"field=%0d, sequence=%d, memory=%s, offset/userptr=0x%08lx\n",  				s,  				(p->timestamp.tv_sec/3600), @@ -501,7 +492,7 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)  				prt_names(p->memory,v4l2_memory_names),  				p->m.userptr);  		printk ("%s: timecode= %02d:%02d:%02d type=%d, " -			"flags=0x%08d, frames=%d, userbits=0x%08x\n", +			"flags=0x%08x, frames=%d, userbits=0x%08x\n",  				s,tc->hours,tc->minutes,tc->seconds,  				tc->type, tc->flags, tc->frames, (__u32) tc->userbits);  		break; @@ -696,7 +687,7 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)  	case VIDIOC_INT_G_VIDEO_ROUTING:  	{  		struct v4l2_routing  *p=arg; -		printk ("%s: input=%d, output=%d\n", s, p->input, p->output); +		printk ("%s: input=0x%x, output=0x%x\n", s, p->input, p->output);  		break;  	}  	case VIDIOC_G_SLICED_VBI_CAP: diff --git a/linux/drivers/media/video/wm8775.c b/linux/drivers/media/video/wm8775.c index 1e696133e..e94706257 100644 --- a/linux/drivers/media/video/wm8775.c +++ b/linux/drivers/media/video/wm8775.c @@ -110,11 +110,6 @@ static int wm8775_command(struct i2c_client *client, unsigned int cmd,  		wm8775_write(client, R21, 0x100 + state->input);  		break; -	case VIDIOC_G_AUDIO: -		memset(input, 0, sizeof(*input)); -		input->index = state->input; -		break; -  	case VIDIOC_G_CTRL:  		if (ctrl->id != V4L2_CID_AUDIO_MUTE)  			return -EINVAL; | 
