diff options
Diffstat (limited to 'linux/drivers/media/video')
32 files changed, 282 insertions, 554 deletions
| diff --git a/linux/drivers/media/video/Kconfig b/linux/drivers/media/video/Kconfig index 134af1cad..2ed46e87e 100644 --- a/linux/drivers/media/video/Kconfig +++ b/linux/drivers/media/video/Kconfig @@ -312,17 +312,6 @@ config VIDEO_HEXIUM_GEMINI  source "drivers/media/video/cx88/Kconfig" -config VIDEO_OVCAMCHIP -	tristate "OmniVision Camera Chip support" -	depends on I2C && VIDEO_V4L1 -	---help--- -	  Support for the OmniVision OV6xxx and OV7xxx series of camera chips. -	  This driver is intended to be used with the ov511 and w9968cf USB -	  camera drivers. - -	  To compile this driver as a module, choose M here: the -	  module will be called ovcamchip. -  config VIDEO_M32R_AR  	tristate "AR devices"  	depends on M32R && VIDEO_V4L1 @@ -395,10 +384,10 @@ config VIDEO_WM8739  source "drivers/media/video/cx25840/Kconfig"  config VIDEO_SAA711X -	tristate "Philips SAA7113/4/5 video decoders (OBSOLETED)" -	depends on VIDEO_V4L1 && I2C && EXPERIMENTAL +	tristate "Philips SAA7113/4/5 video decoders" +	depends on VIDEO_DEV && I2C && EXPERIMENTAL  	---help--- -	  Old support for the Philips SAA7113/4 video decoders. +	  Support for the Philips SAA7113/4/5 video decoders.  	  To compile this driver as a module, choose M here: the  	  module will be called saa7115. @@ -464,6 +453,35 @@ source "drivers/media/video/usbvideo/Kconfig"  source "drivers/media/video/et61x251/Kconfig" +config VIDEO_OVCAMCHIP +	tristate "OmniVision Camera Chip support" +	depends on I2C && VIDEO_V4L1 +	---help--- +	  Support for the OmniVision OV6xxx and OV7xxx series of camera chips. +	  This driver is intended to be used with the ov511 and w9968cf USB +	  camera drivers. + +	  To compile this driver as a module, choose M here: the +	  module will be called ovcamchip. + +config USB_W9968CF +	tristate "USB W996[87]CF JPEG Dual Mode Camera support" +	depends on USB && VIDEO_V4L1 && I2C +	select VIDEO_OVCAMCHIP +	---help--- +	  Say Y here if you want support for cameras based on OV681 or +	  Winbond W9967CF/W9968CF JPEG USB Dual Mode Camera Chips. + +	  This driver has an optional plugin, which is distributed as a +	  separate module only (released under GPL). It allows to use higher +	  resolutions and framerates, but cannot be included in the official +	  Linux kernel for performance purposes. + +	  See <file:Documentation/video4linux/w9968cf.txt> for more info. + +	  To compile this driver as a module, choose M here: the +	  module will be called w9968cf. +  config USB_OV511  	tristate "USB OV511 Camera support"  	depends on USB && VIDEO_V4L1 @@ -500,24 +518,6 @@ config USB_STV680  	  To compile this driver as a module, choose M here: the  	  module will be called stv680. -config USB_W9968CF -	tristate "USB W996[87]CF JPEG Dual Mode Camera support" -	depends on USB && VIDEO_V4L1 && I2C -	select VIDEO_OVCAMCHIP -	---help--- -	  Say Y here if you want support for cameras based on OV681 or -	  Winbond W9967CF/W9968CF JPEG USB Dual Mode Camera Chips. - -	  This driver has an optional plugin, which is distributed as a -	  separate module only (released under GPL). It allows to use higher -	  resolutions and framerates, but cannot be included in the official -	  Linux kernel for performance purposes. - -	  See <file:Documentation/video4linux/w9968cf.txt> for more info. - -	  To compile this driver as a module, choose M here: the -	  module will be called w9968cf. -  source "drivers/media/video/zc0301/Kconfig"  source "drivers/media/video/pwc/Kconfig" diff --git a/linux/drivers/media/video/Makefile b/linux/drivers/media/video/Makefile index 572e84835..353d61cfa 100644 --- a/linux/drivers/media/video/Makefile +++ b/linux/drivers/media/video/Makefile @@ -6,7 +6,7 @@ zoran-objs      :=	zr36120.o zr36120_i2c.o zr36120_mem.o  zr36067-objs	:=	zoran_procfs.o zoran_device.o \  			zoran_driver.o zoran_card.o  tuner-objs	:=	tuner-core.o tuner-types.o tuner-simple.o \ -			mt20xx.o tda8290.o tea5767.o +			mt20xx.o tda8290.o tea5767.o tda9887.o  msp3400-objs	:=	msp3400-driver.o msp3400-kthreads.o @@ -61,7 +61,7 @@ obj-$(CONFIG_VIDEO_HEXIUM_GEMINI) += hexium_gemini.o  obj-$(CONFIG_VIDEO_DPC) += saa7111.o dpc7146.o  obj-$(CONFIG_TUNER_3036) += tuner-3036.o -obj-$(CONFIG_VIDEO_TUNER) += tuner.o tda9887.o +obj-$(CONFIG_VIDEO_TUNER) += tuner.o  obj-$(CONFIG_VIDEO_BUF)   += video-buf.o  obj-$(CONFIG_VIDEO_BUF_DVB) += video-buf-dvb.o  obj-$(CONFIG_VIDEO_BTCX)  += btcx-risc.o diff --git a/linux/drivers/media/video/arv.c b/linux/drivers/media/video/arv.c index 6c82b2fef..24c0ddc33 100644 --- a/linux/drivers/media/video/arv.c +++ b/linux/drivers/media/video/arv.c @@ -214,7 +214,7 @@ void init_iic(void)  	ar_outl(0x0300, PLDI2CMOD); 	/* I2CMOD ACK/8b-data/7b-addr/auto */  	ar_outl(0x1, PLDI2CACK);	/* I2CACK ACK                      */ -    	/* I2C CLK */ +	/* I2C CLK */  	/* 50MH-100k */  	if (freq == 75) {  		ar_outl(369, PLDI2CFREQ);	/* BCLK = 75MHz */ diff --git a/linux/drivers/media/video/bt8xx/bttv-cards.c b/linux/drivers/media/video/bt8xx/bttv-cards.c index 8dab6b9b1..584d91f1c 100644 --- a/linux/drivers/media/video/bt8xx/bttv-cards.c +++ b/linux/drivers/media/video/bt8xx/bttv-cards.c @@ -292,7 +292,7 @@ static struct CARD {  	{ 0x41a0a051, BTTV_BOARD_FLYVIDEO_98FM, "Lifeview FlyVideo 98 LR50 Rev Q" },  	{ 0x18501f7f, BTTV_BOARD_FLYVIDEO_98,   "Lifeview Flyvideo 98" }, -    	{ 0x010115cb, BTTV_BOARD_GMV1,          "AG GMV1" }, +	{ 0x010115cb, BTTV_BOARD_GMV1,          "AG GMV1" },  	{ 0x010114c7, BTTV_BOARD_MODTEC_205,    "Modular Technology MM201/MM202/MM205/MM210/MM215 PCTV" },  	{ 0x10b42636, BTTV_BOARD_HAUPPAUGE878,  "STB ???" }, @@ -332,6 +332,7 @@ static struct CARD {  	{ 0x07611461, BTTV_BOARD_AVDVBT_761,    "AverMedia AverTV DVB-T 761" },  	{ 0xdb1018ac, BTTV_BOARD_DVICO_DVBT_LITE,    "DViCO FusionHDTV DVB-T Lite" },  	{ 0xd50018ac, BTTV_BOARD_DVICO_FUSIONHDTV_5_LITE,    "DViCO FusionHDTV 5 Lite" }, +	{ 0x00261822, BTTV_BOARD_TWINHAN_DST,	"DNTV Live! Mini "},  	{ 0, -1, NULL }  }; diff --git a/linux/drivers/media/video/bt8xx/bttv-input.c b/linux/drivers/media/video/bt8xx/bttv-input.c index bab7cb123..ce5ce470a 100644 --- a/linux/drivers/media/video/bt8xx/bttv-input.c +++ b/linux/drivers/media/video/bt8xx/bttv-input.c @@ -356,7 +356,7 @@ int bttv_input_init(struct bttv *btv)  	if (ir->rc5_gpio) {  		u32 gpio; -	    	/* enable remote irq */ +		/* enable remote irq */  		bttv_gpio_inout(&btv->c, (1 << 4), 1 << 4);  		gpio = bttv_gpio_read(&btv->c);  		bttv_gpio_write(&btv->c, gpio & ~(1 << 4)); diff --git a/linux/drivers/media/video/bw-qcam.c b/linux/drivers/media/video/bw-qcam.c index 108612e1f..497fc3418 100644 --- a/linux/drivers/media/video/bw-qcam.c +++ b/linux/drivers/media/video/bw-qcam.c @@ -763,7 +763,7 @@ static int qcam_do_ioctl(struct inode *inode, struct file *file,  		{  			struct video_picture *p = arg;  			if(p->palette!=VIDEO_PALETTE_GREY) -			    	return -EINVAL; +				return -EINVAL;  			if(p->depth!=4 && p->depth!=6)  				return -EINVAL; diff --git a/linux/drivers/media/video/cpia2/cpia2_v4l.c b/linux/drivers/media/video/cpia2/cpia2_v4l.c index 481e178ef..d129db57f 100644 --- a/linux/drivers/media/video/cpia2/cpia2_v4l.c +++ b/linux/drivers/media/video/cpia2/cpia2_v4l.c @@ -343,7 +343,9 @@ static int cpia2_close(struct inode *inode, struct file *file)  		cpia2_free_buffers(cam);  		if (!cam->present) {  			video_unregister_device(dev); +			mutex_unlock(&cam->busy_lock);  			kfree(cam); +			return 0;  		}  	} @@ -1167,9 +1169,9 @@ static int ioctl_g_ctrl(void *arg,struct camera_data *cam)  		} else {  		    if(cam->params.flicker_control.cam_register &  		       CPIA2_VP_FLICKER_MODES_50HZ) { -		    	mode = FLICKER_50; +			mode = FLICKER_50;  		    } else { -		    	mode = FLICKER_60; +			mode = FLICKER_60;  		    }  		}  		for(i=0; i<NUM_FLICKER_CONTROLS; i++) { diff --git a/linux/drivers/media/video/cx88/cx88-alsa.c b/linux/drivers/media/video/cx88/cx88-alsa.c index 69d3c3c8f..7085192bc 100644 --- a/linux/drivers/media/video/cx88/cx88-alsa.c +++ b/linux/drivers/media/video/cx88/cx88-alsa.c @@ -799,7 +799,6 @@ static int __devinit snd_cx88_create(struct snd_card *card,  	chip->irq = -1;  	spin_lock_init(&chip->reg_lock); -	cx88_reset(core);  	chip->core = core;  	/* get irq */ diff --git a/linux/drivers/media/video/cx88/cx88-cards.c b/linux/drivers/media/video/cx88/cx88-cards.c index 5431d591e..9de27a929 100644 --- a/linux/drivers/media/video/cx88/cx88-cards.c +++ b/linux/drivers/media/video/cx88/cx88-cards.c @@ -1468,6 +1468,10 @@ struct cx88_subid cx88_subids[] = {  		.subvendor = 0x107d,  		.subdevice = 0x665e,  		.card      = CX88_BOARD_WINFAST_DTV2000H, +	},{ +		.subvendor = 0x18ac, +		.subdevice = 0xd800, /* FusionHDTV 3 Gold (original revision) */ +		.card      = CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_Q,  	},  };  const unsigned int cx88_idcount = ARRAY_SIZE(cx88_subids); diff --git a/linux/drivers/media/video/cx88/cx88-dvb.c b/linux/drivers/media/video/cx88/cx88-dvb.c index d4674cac2..fb17c1e66 100644 --- a/linux/drivers/media/video/cx88/cx88-dvb.c +++ b/linux/drivers/media/video/cx88/cx88-dvb.c @@ -359,7 +359,7 @@ static struct or51132_config pchdtv_hd3000 = {  #ifdef HAVE_LGDT330X  static int lgdt3302_tuner_set_params(struct dvb_frontend* fe, -			    	     struct dvb_frontend_parameters* params) +				     struct dvb_frontend_parameters* params)  {  	/* FIXME make this routine use the tuner-simple code.  	 * It could probably be shared with a number of ATSC diff --git a/linux/drivers/media/video/cx88/cx88-input.c b/linux/drivers/media/video/cx88/cx88-input.c index 9283be42d..0a98940f3 100644 --- a/linux/drivers/media/video/cx88/cx88-input.c +++ b/linux/drivers/media/video/cx88/cx88-input.c @@ -90,7 +90,7 @@ static void cx88_ir_handle_key(struct cx88_IR *ir)  		auxgpio = cx_read(MO_GP1_IO);  		/* Take out the parity part */ -		gpio+=(auxgpio & 0xef); +		gpio+=(gpio & 0x7fd) + (auxgpio & 0xef);  	} else  		auxgpio = gpio; diff --git a/linux/drivers/media/video/cx88/cx88-tvaudio.c b/linux/drivers/media/video/cx88/cx88-tvaudio.c index efd8d231c..9a42e9a6b 100644 --- a/linux/drivers/media/video/cx88/cx88-tvaudio.c +++ b/linux/drivers/media/video/cx88/cx88-tvaudio.c @@ -52,6 +52,7 @@  #include <linux/init.h>  #include <linux/smp_lock.h>  #include <linux/delay.h> +#include <linux/config.h>  #include "compat.h"  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)  #include <linux/kthread.h> @@ -140,12 +141,12 @@ static void set_audio_finish(struct cx88_core *core, u32 ctl)  {  	u32 volume; -#ifndef USING_CX88_ALSA +#ifndef CONFIG_VIDEO_CX88_ALSA  	/* restart dma; This avoids buzz in NICAM and is good in others  */  	cx88_stop_audio_dma(core);  #endif  	cx_write(AUD_RATE_THRES_DMD, 0x000000C0); -#ifndef USING_CX88_ALSA +#ifndef CONFIG_VIDEO_CX88_ALSA  	cx88_start_audio_dma(core);  #endif @@ -156,6 +157,7 @@ static void set_audio_finish(struct cx88_core *core, u32 ctl)  		case CX88_BOARD_KWORLD_MCE200_DELUXE:  		case CX88_BOARD_KWORLD_HARDWARE_MPEG_TV_XPERT:  		case CX88_BOARD_PIXELVIEW_PLAYTV_P7000: +		case CX88_BOARD_ASUS_PVR_416:  			cx_clear(AUD_CTL, EN_I2SIN_ENABLE);  			break;  		default: diff --git a/linux/drivers/media/video/em28xx/em28xx-i2c.c b/linux/drivers/media/video/em28xx/em28xx-i2c.c index c077c39c2..4ee4cea10 100644 --- a/linux/drivers/media/video/em28xx/em28xx-i2c.c +++ b/linux/drivers/media/video/em28xx/em28xx-i2c.c @@ -436,9 +436,19 @@ static int attach_inform(struct i2c_client *client)  	struct em28xx *dev = client->adapter->algo_data;  	switch (client->addr << 1) { -		case 0x86: +		case 0x43: +		case 0x4b: +		{ +			struct tuner_setup tun_setup; + +			tun_setup.mode_mask = T_ANALOG_TV | T_RADIO; +			tun_setup.type = TUNER_TDA9887; +			tun_setup.addr = client->addr; + +			em28xx_i2c_call_clients(dev, TUNER_SET_TYPE_ADDR, &tun_setup);  			em28xx_i2c_call_clients(dev, TDA9887_SET_CONFIG, &dev->tda9887_conf);  			break; +		}  		case 0x42:  			dprintk1(1,"attach_inform: saa7114 detected.\n");  			break; @@ -464,6 +474,7 @@ static int attach_inform(struct i2c_client *client)  		case 0xba:  			dprintk1(1,"attach_inform: tvp5150 detected.\n");  			break; +  		default:  			dprintk1(1,"attach inform: detected I2C address %x\n", client->addr << 1);  			dev->tuner_addr = client->addr; diff --git a/linux/drivers/media/video/ov511.c b/linux/drivers/media/video/ov511.c index 564a88293..5d2899c80 100644 --- a/linux/drivers/media/video/ov511.c +++ b/linux/drivers/media/video/ov511.c @@ -3239,7 +3239,7 @@ ov511_move_data(struct usb_ov511 *ov, unsigned char *in, int n)  		RESTRICT_TO_RANGE(frame->bytes_recvd, 8, max_raw);  		if (frame->scanstate == STATE_LINES) { -	    		int nextf; +			int nextf;  			frame->grabstate = FRAME_DONE;  			wake_up_interruptible(&frame->wq); @@ -3405,7 +3405,7 @@ eof:  	RESTRICT_TO_RANGE(frame->bytes_recvd, 8, max_raw);  	if (frame->scanstate == STATE_LINES) { -    		int nextf; +		int nextf;  		frame->grabstate = FRAME_DONE;  		wake_up_interruptible(&frame->wq); diff --git a/linux/drivers/media/video/pms.c b/linux/drivers/media/video/pms.c index d129072a9..e13a7f8b8 100644 --- a/linux/drivers/media/video/pms.c +++ b/linux/drivers/media/video/pms.c @@ -812,7 +812,7 @@ static int pms_do_ioctl(struct inode *inode, struct file *file,  			struct video_picture *p = arg;  			if(!((p->palette==VIDEO_PALETTE_RGB565 && p->depth==16)  			    ||(p->palette==VIDEO_PALETTE_RGB555 && p->depth==15))) -			    	return -EINVAL; +				return -EINVAL;  			pd->picture= *p;  			/* diff --git a/linux/drivers/media/video/pwc/pwc-ctrl.c b/linux/drivers/media/video/pwc/pwc-ctrl.c index c64f498f1..acd8d4af1 100644 --- a/linux/drivers/media/video/pwc/pwc-ctrl.c +++ b/linux/drivers/media/video/pwc/pwc-ctrl.c @@ -925,7 +925,7 @@ int pwc_set_leds(struct pwc_device *pdev, int on_value, int off_value)  	return SendControlMsg(SET_STATUS_CTL, LED_FORMATTER, 2);  } -int pwc_get_leds(struct pwc_device *pdev, int *on_value, int *off_value) +static int pwc_get_leds(struct pwc_device *pdev, int *on_value, int *off_value)  {  	unsigned char buf[2];  	int ret; @@ -1404,7 +1404,7 @@ int pwc_ioctl(struct pwc_device *pdev, unsigned int cmd, void *arg)  		ARG_IN(leds)  		ret = pwc_set_leds(pdev, ARGR(leds).led_on, ARGR(leds).led_off); -	    	break; +		break;  	} diff --git a/linux/drivers/media/video/pwc/pwc-dec23.c b/linux/drivers/media/video/pwc/pwc-dec23.c index 39eaf5839..9e2d91f26 100644 --- a/linux/drivers/media/video/pwc/pwc-dec23.c +++ b/linux/drivers/media/video/pwc/pwc-dec23.c @@ -105,7 +105,7 @@ static void build_bit_powermask_table(struct pwc_dec23_private *pdec)  static void build_table_color(const unsigned int romtable[16][8], -    			      unsigned char p0004[16][1024], +			      unsigned char p0004[16][1024],  			      unsigned char p8004[16][256])  {  	int compression_mode, j, k, bit, pw; @@ -787,7 +787,7 @@ static void DecompressBand23(struct pwc_dec23_private *pdec,   *   */  static void DecompressBandBayer(struct pwc_dec23_private *pdec, -    				const unsigned char *rawyuv, +				const unsigned char *rawyuv,  				unsigned char *rgbbayer,  				unsigned int   compressed_image_width,  				unsigned int   real_image_width) diff --git a/linux/drivers/media/video/pwc/pwc-if.c b/linux/drivers/media/video/pwc/pwc-if.c index fbe7ae2a9..a241a3060 100644 --- a/linux/drivers/media/video/pwc/pwc-if.c +++ b/linux/drivers/media/video/pwc/pwc-if.c @@ -133,7 +133,7 @@ static int default_fbufs = 3;   /* Default number of frame buffers */  #endif  static int power_save = 0;  static int led_on = 100, led_off = 0; /* defaults to LED that is on while in use */ -       int pwc_preferred_compression = 1; /* 0..3 = uncompressed..high */ +static int pwc_preferred_compression = 1; /* 0..3 = uncompressed..high */  static struct {  	int type;  	char serial_number[30]; @@ -1097,7 +1097,7 @@ static const char *pwc_sensor_type_to_string(unsigned int sensor_type)  		case 0x101:  			return "PAL MR sensor";  		default: -		    	return "unknown type of sensor"; +			return "unknown type of sensor";  	}  }  #endif @@ -1744,10 +1744,10 @@ static int usb_pwc_probe(struct usb_interface *intf, const struct usb_device_id  		     (device_hint[hint].pdev == NULL)) {  			/* so far, so good... try serial number */  			if ((device_hint[hint].serial_number[0] == '*') || !strcmp(device_hint[hint].serial_number, serial_number)) { -			    	/* match! */ -			    	video_nr = device_hint[hint].device_node; -			    	PWC_DEBUG_PROBE("Found hint, will try to register as /dev/video%d\n", video_nr); -			    	break; +				/* match! */ +				video_nr = device_hint[hint].device_node; +				PWC_DEBUG_PROBE("Found hint, will try to register as /dev/video%d\n", video_nr); +				break;  			}  		}  	} diff --git a/linux/drivers/media/video/pwc/pwc-v4l.c b/linux/drivers/media/video/pwc/pwc-v4l.c index 86faadd48..bd918b87c 100644 --- a/linux/drivers/media/video/pwc/pwc-v4l.c +++ b/linux/drivers/media/video/pwc/pwc-v4l.c @@ -678,9 +678,9 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  			break;  		} -	    	/* V4L2 Layer */ -	    	case VIDIOC_QUERYCAP: -	    	{ +		/* V4L2 Layer */ +		case VIDIOC_QUERYCAP: +		{  		    struct v4l2_capability *cap = arg;  		    PWC_DEBUG_IOCTL("ioctl(VIDIOC_QUERYCAP) This application "\ @@ -696,8 +696,8 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  		    return 0;  		} -	    	case VIDIOC_ENUMINPUT: -	    	{ +		case VIDIOC_ENUMINPUT: +		{  		    struct v4l2_input *i = arg;  		    if ( i->index )	/* Only one INPUT is supported */ @@ -708,14 +708,14 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  		    return 0;  		} -	    	case VIDIOC_G_INPUT: +		case VIDIOC_G_INPUT:  		{  		    int *i = arg;  		    *i = 0;	/* Only one INPUT is supported */  		    return 0;  		} -	    	case VIDIOC_S_INPUT: -	    	{ +		case VIDIOC_S_INPUT: +		{  			int *i = arg;  			if ( *i ) {	/* Only one INPUT is supported */ @@ -727,7 +727,7 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  		}  		/* TODO: */ -	    	case VIDIOC_QUERYCTRL: +		case VIDIOC_QUERYCTRL:  		{  			struct v4l2_queryctrl *c = arg;  			int i; @@ -965,13 +965,13 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  		case VIDIOC_ENUM_FMT:  		{ -		    	struct v4l2_fmtdesc *f = arg; +			struct v4l2_fmtdesc *f = arg;  			int index;  			if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)  			      return -EINVAL; -		    	/* We only support two format: the raw format, and YUV */ +			/* We only support two format: the raw format, and YUV */  			index = f->index;  			memset(f,0,sizeof(struct v4l2_fmtdesc));  			f->type = V4L2_BUF_TYPE_VIDEO_CAPTURE; @@ -980,23 +980,23 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  			{  				case 0:  					/* RAW format */ -			    		f->pixelformat = pdev->type<=646?V4L2_PIX_FMT_PWC1:V4L2_PIX_FMT_PWC2; +					f->pixelformat = pdev->type<=646?V4L2_PIX_FMT_PWC1:V4L2_PIX_FMT_PWC2;  					f->flags = V4L2_FMT_FLAG_COMPRESSED; -			    		strlcpy(f->description,"Raw Philips Webcam",sizeof(f->description)); +					strlcpy(f->description,"Raw Philips Webcam",sizeof(f->description));  					break;  				case 1: -			    		f->pixelformat = V4L2_PIX_FMT_YUV420; -			    		strlcpy(f->description,"4:2:0, planar, Y-Cb-Cr",sizeof(f->description)); +					f->pixelformat = V4L2_PIX_FMT_YUV420; +					strlcpy(f->description,"4:2:0, planar, Y-Cb-Cr",sizeof(f->description));  					break; -			    	default: +				default:  					return -EINVAL;  			}  			return 0;  		} -	    	case VIDIOC_G_FMT: +		case VIDIOC_G_FMT:  		{ -		    	struct v4l2_format *f = arg; +			struct v4l2_format *f = arg;  			PWC_DEBUG_IOCTL("ioctl(VIDIOC_G_FMT) return size %dx%d\n",pdev->image.x,pdev->image.y);  			if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) @@ -1010,7 +1010,7 @@ int pwc_video_do_ioctl(struct inode *inode, struct file *file,  		case VIDIOC_TRY_FMT:  			return pwc_vidioc_try_fmt(pdev, arg); -	    	case VIDIOC_S_FMT: +		case VIDIOC_S_FMT:  			return pwc_vidioc_set_fmt(pdev, arg);  		case VIDIOC_G_STD: diff --git a/linux/drivers/media/video/pwc/pwc.h b/linux/drivers/media/video/pwc/pwc.h index a087108d0..629f79e44 100644 --- a/linux/drivers/media/video/pwc/pwc.h +++ b/linux/drivers/media/video/pwc/pwc.h @@ -274,7 +274,6 @@ extern "C" {  #if CONFIG_PWC_DEBUG  extern int pwc_trace;  #endif -extern int pwc_preferred_compression;  extern int pwc_mbufs;  /** functions in pwc-if.c */ @@ -308,7 +307,6 @@ extern int pwc_set_gamma(struct pwc_device *pdev, int value);  extern int pwc_get_saturation(struct pwc_device *pdev, int *value);  extern int pwc_set_saturation(struct pwc_device *pdev, int value);  extern int pwc_set_leds(struct pwc_device *pdev, int on_value, int off_value); -extern int pwc_get_leds(struct pwc_device *pdev, int *on_value, int *off_value);  extern int pwc_get_cmos_sensor(struct pwc_device *pdev, int *sensor);  extern int pwc_restore_user(struct pwc_device *pdev);  extern int pwc_save_user(struct pwc_device *pdev); diff --git a/linux/drivers/media/video/saa7134/saa6752hs.c b/linux/drivers/media/video/saa7134/saa6752hs.c index 1ea68207a..0422e10e6 100644 --- a/linux/drivers/media/video/saa7134/saa6752hs.c +++ b/linux/drivers/media/video/saa7134/saa6752hs.c @@ -87,11 +87,11 @@ struct saa6752hs_state {  enum saa6752hs_command {  	SAA6752HS_COMMAND_RESET = 0, -    	SAA6752HS_COMMAND_STOP = 1, -    	SAA6752HS_COMMAND_START = 2, -    	SAA6752HS_COMMAND_PAUSE = 3, -    	SAA6752HS_COMMAND_RECONFIGURE = 4, -    	SAA6752HS_COMMAND_SLEEP = 5, +	SAA6752HS_COMMAND_STOP = 1, +	SAA6752HS_COMMAND_START = 2, +	SAA6752HS_COMMAND_PAUSE = 3, +	SAA6752HS_COMMAND_RECONFIGURE = 4, +	SAA6752HS_COMMAND_SLEEP = 5,  	SAA6752HS_COMMAND_RECONFIGURE_FORCE = 6,  	SAA6752HS_COMMAND_MAX @@ -286,20 +286,20 @@ static int saa6752hs_set_bitrate(struct i2c_client* client,  	if (params->vi_bitrate_mode == V4L2_MPEG_VIDEO_BITRATE_MODE_VBR) {  		/* set the target bitrate */  		buf[0] = 0x80; -	    	buf[1] = params->vi_bitrate >> 8; +		buf[1] = params->vi_bitrate >> 8;  		buf[2] = params->vi_bitrate & 0xff;  		i2c_master_send(client, buf, 3);  		/* set the max bitrate */  		buf[0] = 0x81; -	    	buf[1] = params->vi_bitrate_peak >> 8; +		buf[1] = params->vi_bitrate_peak >> 8;  		buf[2] = params->vi_bitrate_peak & 0xff;  		i2c_master_send(client, buf, 3);  		tot_bitrate = params->vi_bitrate_peak;  	} else {  		/* set the target bitrate (no max bitrate for CBR) */  		buf[0] = 0x81; -	    	buf[1] = params->vi_bitrate >> 8; +		buf[1] = params->vi_bitrate >> 8;  		buf[2] = params->vi_bitrate & 0xff;  		i2c_master_send(client, buf, 3);  		tot_bitrate = params->vi_bitrate; @@ -589,22 +589,22 @@ static int saa6752hs_init(struct i2c_client* client)  	buf[2] = 0x0D;  	i2c_master_send(client,buf,3); -    	/* Set minimum Q-scale {4} */ +	/* Set minimum Q-scale {4} */  	buf[0] = 0x82;  	buf[1] = 0x04;  	i2c_master_send(client,buf,2); -    	/* Set maximum Q-scale {12} */ +	/* Set maximum Q-scale {12} */  	buf[0] = 0x83;  	buf[1] = 0x0C;  	i2c_master_send(client,buf,2); -    	/* Set Output Protocol */ +	/* Set Output Protocol */  	buf[0] = 0xD0;  	buf[1] = 0x81;  	i2c_master_send(client,buf,2); -    	/* Set video output stream format {TS} */ +	/* Set video output stream format {TS} */  	buf[0] = 0xB0;  	buf[1] = 0x05;  	i2c_master_send(client,buf,2); @@ -635,7 +635,7 @@ static int saa6752hs_init(struct i2c_client* client)  	localPMT[sizeof(PMT) - 2] = (crc >> 8) & 0xFF;  	localPMT[sizeof(PMT) - 1] = crc & 0xFF; -    	/* Set Audio PID */ +	/* Set Audio PID */  	buf[0] = 0xC1;  	buf[1] = (h->params.ts_pid_audio >> 8) & 0xFF;  	buf[2] = h->params.ts_pid_audio & 0xFF; diff --git a/linux/drivers/media/video/saa7134/saa7134-alsa.c b/linux/drivers/media/video/saa7134/saa7134-alsa.c index fefcce8f6..7807397a5 100644 --- a/linux/drivers/media/video/saa7134/saa7134-alsa.c +++ b/linux/drivers/media/video/saa7134/saa7134-alsa.c @@ -926,7 +926,7 @@ static int snd_saa7134_capsrc_put(struct snd_kcontrol * kcontrol,  				break;  		} -	    	/* output xbar always main channel */ +		/* output xbar always main channel */  		saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL1, 0xbbbb10);  		if (left || right) { // We've got data, turn the input on diff --git a/linux/drivers/media/video/saa7134/saa7134-cards.c b/linux/drivers/media/video/saa7134/saa7134-cards.c index 04812f5f8..389f05b3c 100644 --- a/linux/drivers/media/video/saa7134/saa7134-cards.c +++ b/linux/drivers/media/video/saa7134/saa7134-cards.c @@ -2161,7 +2161,7 @@ struct saa7134_board saa7134_boards[] = {  		.radio = {  			  .name = name_radio,  			  .amux = LINE2, -    		}, +		},  	},  	[SAA7134_BOARD_GOTVIEW_7135] = {  		/* Mike Baikov <mike@baikov.com> */ @@ -2882,6 +2882,55 @@ struct saa7134_board saa7134_boards[] = {  			.gpio = 0x000000,	/* GPIO21=Low for FM radio antenna */  		},  	}, +	[SAA7134_BOARD_FLYVIDEO3000_NTSC] = { +		/* "Zac Bowling" <zac@zacbowling.com> */ +		.name           = "LifeView FlyVIDEO3000 (NTSC)", +		.audio_clock    = 0x00200000, +		.tuner_type     = TUNER_PHILIPS_NTSC, +		.radio_type     = UNSET, +		.tuner_addr     = ADDR_UNSET, +		.radio_addr     = ADDR_UNSET, + +		.gpiomask       = 0xe000, +		.inputs         = {{ +			.name = name_tv, +			.vmux = 1, +			.amux = TV, +			.gpio = 0x8000, +			.tv   = 1, +		},{ +			.name = name_tv_mono, +			.vmux = 1, +			.amux = LINE2, +			.gpio = 0x0000, +			.tv   = 1, +		},{ +			.name = name_comp1, +			.vmux = 0, +			.amux = LINE2, +			.gpio = 0x4000, +		},{ +			.name = name_comp2, +			.vmux = 3, +			.amux = LINE2, +			.gpio = 0x4000, +		},{ +			.name = name_svideo, +			.vmux = 8, +			.amux = LINE2, +			.gpio = 0x4000, +		}}, +		.radio = { +			.name = name_radio, +			.amux = LINE2, +			.gpio = 0x2000, +		}, +			.mute = { +			.name = name_mute, +			.amux = TV, +			.gpio = 0x8000, +		}, +	},  };  const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards); @@ -2941,6 +2990,12 @@ struct pci_device_id saa7134_pci_tbl[] = {  	},{  		.vendor       = PCI_VENDOR_ID_PHILIPS,  		.device       = PCI_DEVICE_ID_PHILIPS_SAA7134, +		.subvendor    = 0x5169, +		.subdevice    = 0x0138, +		.driver_data  = SAA7134_BOARD_FLYVIDEO3000_NTSC, +	},{ +		.vendor       = PCI_VENDOR_ID_PHILIPS, +		.device       = PCI_DEVICE_ID_PHILIPS_SAA7134,  		.subvendor    = 0x5168,  		.subdevice    = 0x0138,  		.driver_data  = SAA7134_BOARD_FLYVIDEO3000, @@ -3536,6 +3591,7 @@ int saa7134_board_init1(struct saa7134_dev *dev)  	switch (dev->board) {  	case SAA7134_BOARD_FLYVIDEO2000:  	case SAA7134_BOARD_FLYVIDEO3000: +	case SAA7134_BOARD_FLYVIDEO3000_NTSC:  		dev->has_remote = SAA7134_REMOTE_GPIO;  		board_flyvideo(dev);  		break; diff --git a/linux/drivers/media/video/saa7134/saa7134.h b/linux/drivers/media/video/saa7134/saa7134.h index c30d512c7..672a980cb 100644 --- a/linux/drivers/media/video/saa7134/saa7134.h +++ b/linux/drivers/media/video/saa7134/saa7134.h @@ -231,6 +231,7 @@ struct saa7134_format {  #define SAA7134_BOARD_AVERMEDIA_A169_B1 92  #define SAA7134_BOARD_MD7134_BRIDGE_2     93  #define SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS 94 +#define SAA7134_BOARD_FLYVIDEO3000_NTSC 95  #define SAA7134_MAXBOARDS 8  #define SAA7134_INPUT_MAX 8 diff --git a/linux/drivers/media/video/tda9875.c b/linux/drivers/media/video/tda9875.c index 42f28e6b0..279f1ecd7 100644 --- a/linux/drivers/media/video/tda9875.c +++ b/linux/drivers/media/video/tda9875.c @@ -185,7 +185,7 @@ static void do_tda9875_init(struct i2c_client *client)  	struct tda9875 *t = i2c_get_clientdata(client);  	dprintk("In tda9875_init\n");  	tda9875_write(client, TDA9875_CFG, 0xd0 ); /*reg de config 0 (reset)*/ -    	tda9875_write(client, TDA9875_MSR, 0x03 );    /* Monitor 0b00000XXX*/ +	tda9875_write(client, TDA9875_MSR, 0x03 );    /* Monitor 0b00000XXX*/  	tda9875_write(client, TDA9875_C1MSB, 0x00 );  /*Car1(FM) MSB XMHz*/  	tda9875_write(client, TDA9875_C1MIB, 0x00 );  /*Car1(FM) MIB XMHz*/  	tda9875_write(client, TDA9875_C1LSB, 0x00 );  /*Car1(FM) LSB XMHz*/ diff --git a/linux/drivers/media/video/tda9887.c b/linux/drivers/media/video/tda9887.c index ab134a8c0..ba9488594 100644 --- a/linux/drivers/media/video/tda9887.c +++ b/linux/drivers/media/video/tda9887.c @@ -22,52 +22,21 @@     TDA9886 (PAL, SECAM, NTSC)     TDA9887 (PAL, SECAM, NTSC, FM Radio) -   found on: -   - Pinnacle PCTV (Jul.2002 Version with MT2032, bttv) -      TDA9887 (world), TDA9885 (USA) -      Note: OP2 of tda988x must be set to 1, else MT2032 is disabled! -   - KNC One TV-Station RDS (saa7134) -   - Hauppauge PVR-150/500 (possibly more) +   Used as part of several tuners  */ +#define tda9887_info(fmt, arg...) do {\ +	printk(KERN_INFO "%s %d-%04x (tda9887): " fmt, t->i2c.name, \ +			i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0) +#define tda9887_dbg(fmt, arg...) do {\ +	if (tuner_debug) \ +		printk(KERN_INFO "%s %d-%04x (tda9887): " fmt, t->i2c.name, \ +			i2c_adapter_id(t->i2c.adapter), t->i2c.addr , ##arg); } while (0) -/* Addresses to scan */ -static unsigned short normal_i2c[] = { -	0x84 >>1, -	0x86 >>1, -	0x96 >>1, -	I2C_CLIENT_END, -}; -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,13) -static unsigned short normal_i2c_range[] = { I2C_CLIENT_END }; -#endif -I2C_CLIENT_INSMOD; - -/* insmod options */ -static unsigned int debug = 0; -module_param(debug, int, 0644); -MODULE_LICENSE("GPL");  /* ---------------------------------------------------------------------- */  #define UNSET       (-1U) -#define tda9887_info(fmt, arg...) do {\ -	printk(KERN_INFO "%s %d-%04x: " fmt, t->client.name, \ -			i2c_adapter_id(t->client.adapter), t->client.addr , ##arg); } while (0) -#define tda9887_dbg(fmt, arg...) do {\ -	if (debug) \ -		printk(KERN_INFO "%s %d-%04x: " fmt, t->client.name, \ -			i2c_adapter_id(t->client.adapter), t->client.addr , ##arg); } while (0) - -struct tda9887 { -	struct i2c_client  client; -	v4l2_std_id        std; -	enum tuner_mode    mode; -	unsigned int       config; -	unsigned int       using_v4l2; -	unsigned int 	   radio_mode; -	unsigned char 	   data[4]; -};  struct tvnorm {  	v4l2_std_id       std; @@ -77,9 +46,6 @@ struct tvnorm {  	unsigned char     e;  }; -static struct i2c_driver driver; -static struct i2c_client client_template; -  /* ---------------------------------------------------------------------- */  // @@ -288,7 +254,7 @@ static struct tvnorm radio_mono = {  /* ---------------------------------------------------------------------- */ -static void dump_read_message(struct tda9887 *t, unsigned char *buf) +static void dump_read_message(struct tuner *t, unsigned char *buf)  {  	static char *afc[16] = {  		"- 12.5 kHz", @@ -316,7 +282,7 @@ static void dump_read_message(struct tda9887 *t, unsigned char *buf)  	tda9887_info("  vfi level      : %s\n", (buf[0] & 0x80) ? "high" : "low");  } -static void dump_write_message(struct tda9887 *t, unsigned char *buf) +static void dump_write_message(struct tuner *t, unsigned char *buf)  {  	static char *sound[4] = {  		"AM/TV", @@ -412,13 +378,13 @@ static void dump_write_message(struct tda9887 *t, unsigned char *buf)  /* ---------------------------------------------------------------------- */ -static int tda9887_set_tvnorm(struct tda9887 *t, char *buf) +static int tda9887_set_tvnorm(struct tuner *t, char *buf)  {  	struct tvnorm *norm = NULL;  	int i; -	if (t->mode == T_RADIO) { -		if (t->radio_mode == V4L2_TUNER_MODE_MONO) +	if (t->mode == V4L2_TUNER_RADIO) { +		if (t->audmode == V4L2_TUNER_MODE_MONO)  			norm = &radio_mono;  		else  			norm = &radio_stereo; @@ -459,7 +425,7 @@ module_param(qss, int, 0644);  module_param(adjust, int, 0644);  #endif -static int tda9887_set_insmod(struct tda9887 *t, char *buf) +static int tda9887_set_insmod(struct tuner *t, char *buf)  {  	if (UNSET != port1) {  		if (port1) @@ -488,27 +454,27 @@ static int tda9887_set_insmod(struct tda9887 *t, char *buf)  	return 0;  } -static int tda9887_set_config(struct tda9887 *t, char *buf) +static int tda9887_set_config(struct tuner *t, char *buf)  { -	if (t->config & TDA9887_PORT1_ACTIVE) +	if (t->tda9887_config & TDA9887_PORT1_ACTIVE)  		buf[1] &= ~cOutputPort1Inactive; -	if (t->config & TDA9887_PORT1_INACTIVE) +	if (t->tda9887_config & TDA9887_PORT1_INACTIVE)  		buf[1] |= cOutputPort1Inactive; -	if (t->config & TDA9887_PORT2_ACTIVE) +	if (t->tda9887_config & TDA9887_PORT2_ACTIVE)  		buf[1] &= ~cOutputPort2Inactive; -	if (t->config & TDA9887_PORT2_INACTIVE) +	if (t->tda9887_config & TDA9887_PORT2_INACTIVE)  		buf[1] |= cOutputPort2Inactive; -	if (t->config & TDA9887_QSS) +	if (t->tda9887_config & TDA9887_QSS)  		buf[1] |= cQSS; -	if (t->config & TDA9887_INTERCARRIER) +	if (t->tda9887_config & TDA9887_INTERCARRIER)  		buf[1] &= ~cQSS; -	if (t->config & TDA9887_AUTOMUTE) +	if (t->tda9887_config & TDA9887_AUTOMUTE)  		buf[1] |= cAutoMuteFmActive; -	if (t->config & TDA9887_DEEMPHASIS_MASK) { +	if (t->tda9887_config & TDA9887_DEEMPHASIS_MASK) {  		buf[2] &= ~0x60; -		switch (t->config & TDA9887_DEEMPHASIS_MASK) { +		switch (t->tda9887_config & TDA9887_DEEMPHASIS_MASK) {  		case TDA9887_DEEMPHASIS_NONE:  			buf[2] |= cDeemphasisOFF;  			break; @@ -520,159 +486,36 @@ static int tda9887_set_config(struct tda9887 *t, char *buf)  			break;  		}  	} -	if (t->config & TDA9887_TOP_SET) { +	if (t->tda9887_config & TDA9887_TOP_SET) {  		buf[2] &= ~cTopMask; -		buf[2] |= (t->config >> 8) & cTopMask; +		buf[2] |= (t->tda9887_config >> 8) & cTopMask;  	} -	if ((t->config & TDA9887_INTERCARRIER_NTSC) && (t->std & V4L2_STD_NTSC)) +	if ((t->tda9887_config & TDA9887_INTERCARRIER_NTSC) && (t->std & V4L2_STD_NTSC))  		buf[1] &= ~cQSS;  	return 0;  }  /* ---------------------------------------------------------------------- */ -static char pal[] = "--"; -static char secam[] = "--"; -static char ntsc[] = "-"; - -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) -MODULE_PARM(pal,"s"); -MODULE_PARM(secam,"s"); -MODULE_PARM(ntsc,"s"); -#else -module_param_string(pal, pal, sizeof(pal), 0644); -module_param_string(secam, secam, sizeof(secam), 0644); -module_param_string(ntsc, ntsc, sizeof(ntsc), 0644); -#endif - -static int tda9887_fixup_std(struct tda9887 *t) -{ -	/* get more precise norm info from insmod option */ -	if ((t->std & V4L2_STD_PAL) == V4L2_STD_PAL) { -		switch (pal[0]) { -		case 'b': -		case 'B': -		case 'g': -		case 'G': -		case 'h': -		case 'H': -		case 'n': -		case 'N': -			if (pal[1] == 'c' || pal[1] == 'C') { -				tda9887_dbg("insmod fixup: PAL => PAL-Nc\n"); -				t->std = V4L2_STD_PAL_Nc; -			} else { -				tda9887_dbg("insmod fixup: PAL => PAL-BGHN\n"); -				t->std = V4L2_STD_PAL_BG | V4L2_STD_PAL_H | V4L2_STD_PAL_N; -			} -			break; -		case 'i': -		case 'I': -			tda9887_dbg("insmod fixup: PAL => PAL-I\n"); -			t->std = V4L2_STD_PAL_I; -			break; -		case 'd': -		case 'D': -		case 'k': -		case 'K': -			tda9887_dbg("insmod fixup: PAL => PAL-DK\n"); -			t->std = V4L2_STD_PAL_DK; -			break; -		case 'm': -		case 'M': -			tda9887_dbg("insmod fixup: PAL => PAL-M\n"); -			t->std = V4L2_STD_PAL_M; -			break; -		case '-': -			/* default parameter, do nothing */ -			break; -		default: -			tda9887_info("pal= argument not recognised\n"); -			break; -		} -	} -	if ((t->std & V4L2_STD_SECAM) == V4L2_STD_SECAM) { -		switch (secam[0]) { -		case 'b': -		case 'B': -		case 'g': -		case 'G': -		case 'h': -		case 'H': -			tda9887_dbg("insmod fixup: SECAM => SECAM-BGH\n"); -			t->std = V4L2_STD_SECAM_B | V4L2_STD_SECAM_G | V4L2_STD_SECAM_H; -			break; -		case 'd': -		case 'D': -		case 'k': -		case 'K': -			tda9887_dbg("insmod fixup: SECAM => SECAM-DK\n"); -			t->std = V4L2_STD_SECAM_DK; -			break; -		case 'l': -		case 'L': -			if (secam[1] == 'c' || secam[1] == 'C') { -				tda9887_dbg("insmod fixup: SECAM => SECAM-L'\n"); -				t->std = V4L2_STD_SECAM_LC; -			} else { -				tda9887_dbg("insmod fixup: SECAM => SECAM-L\n"); -				t->std = V4L2_STD_SECAM_L; -			} -			break; -		case '-': -			/* default parameter, do nothing */ -			break; -		default: -			tda9887_info("secam= argument not recognised\n"); -			break; -		} -	} -	if ((t->std & V4L2_STD_NTSC) == V4L2_STD_NTSC) { -		switch (ntsc[0]) { -		case 'm': -		case 'M': -			tda9887_dbg("insmod fixup: NTSC => NTSC-M\n"); -			t->std = V4L2_STD_NTSC_M; -			break; -		case 'j': -		case 'J': -			tda9887_dbg("insmod fixup: NTSC => NTSC_M_JP\n"); -			t->std = V4L2_STD_NTSC_M_JP; -			break; -		case 'k': -		case 'K': -			tda9887_dbg("insmod fixup: NTSC => NTSC_M_KR\n"); -			t->std = V4L2_STD_NTSC_M_KR; -			break; -		case '-': -			/* default parameter, do nothing */ -			break; -		default: -			tda9887_info("ntsc= argument not recognised\n"); -			break; -		} -	} -	return 0; -} - -static int tda9887_status(struct tda9887 *t) +static int tda9887_status(struct tuner *t)  {  	unsigned char buf[1];  	int rc;  	memset(buf,0,sizeof(buf)); -	if (1 != (rc = i2c_master_recv(&t->client,buf,1))) +	if (1 != (rc = i2c_master_recv(&t->i2c,buf,1)))  		tda9887_info("i2c i/o error: rc == %d (should be 1)\n",rc);  	dump_read_message(t, buf);  	return 0;  } -static int tda9887_configure(struct tda9887 *t) +static void tda9887_configure(struct i2c_client *client)  { +	struct tuner *t = i2c_get_clientdata(client);  	int rc; -	memset(t->data,0,sizeof(t->data)); -	tda9887_set_tvnorm(t,t->data); +	memset(t->tda9887_data,0,sizeof(t->tda9887_data)); +	tda9887_set_tvnorm(t,t->tda9887_data);  	/* A note on the port settings:  	   These settings tend to depend on the specifics of the board. @@ -687,300 +530,84 @@ static int tda9887_configure(struct tda9887 *t)  	   the ports should be set to active (0), but, again, that may  	   differ depending on the precise hardware configuration.  	 */ -	t->data[1] |= cOutputPort1Inactive; -	t->data[1] |= cOutputPort2Inactive; +	t->tda9887_data[1] |= cOutputPort1Inactive; +	t->tda9887_data[1] |= cOutputPort2Inactive; -	tda9887_set_config(t,t->data); -	tda9887_set_insmod(t,t->data); +	tda9887_set_config(t,t->tda9887_data); +	tda9887_set_insmod(t,t->tda9887_data);  	if (t->mode == T_STANDBY) { -		t->data[1] |= cForcedMuteAudioON; +		t->tda9887_data[1] |= cForcedMuteAudioON;  	}  	tda9887_dbg("writing: b=0x%02x c=0x%02x e=0x%02x\n", -		t->data[1],t->data[2],t->data[3]); -	if (debug > 1) -		dump_write_message(t, t->data); +		t->tda9887_data[1],t->tda9887_data[2],t->tda9887_data[3]); +	if (tuner_debug > 1) +		dump_write_message(t, t->tda9887_data); -	if (4 != (rc = i2c_master_send(&t->client,t->data,4))) +	if (4 != (rc = i2c_master_send(&t->i2c,t->tda9887_data,4)))  		tda9887_info("i2c i/o error: rc == %d (should be 4)\n",rc); -	if (debug > 2) { +	if (tuner_debug > 2) {  		msleep_interruptible(1000);  		tda9887_status(t);  	} -	return 0;  }  /* ---------------------------------------------------------------------- */ -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) -static int tda9887_attach(struct i2c_adapter *adap, int addr, int kind) -#else -static int tda9887_attach(struct i2c_adapter *adap, int addr, -			  unsigned short flags, int kind) -#endif +static void tda9887_tuner_status(struct i2c_client *client)  { -	struct tda9887 *t; - -	client_template.adapter = adap; -	client_template.addr    = addr; - -	if (NULL == (t = kzalloc(sizeof(*t), GFP_KERNEL))) -		return -ENOMEM; - -	t->client      = client_template; -	t->std         = 0; -	t->radio_mode = V4L2_TUNER_MODE_STEREO; - -	tda9887_info("chip found @ 0x%x (%s)\n", addr<<1, adap->name); - -	i2c_set_clientdata(&t->client, t); -	i2c_attach_client(&t->client); - -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) -	MOD_INC_USE_COUNT; -#endif -	return 0; +	struct tuner *t = i2c_get_clientdata(client); +	tda9887_info("Data bytes: b=0x%02x c=0x%02x e=0x%02x\n", t->tda9887_data[1], t->tda9887_data[2], t->tda9887_data[3]);  } -static int tda9887_probe(struct i2c_adapter *adap) +static int tda9887_get_afc(struct i2c_client *client)  { -#ifdef I2C_CLASS_TV_ANALOG -	if (adap->class & I2C_CLASS_TV_ANALOG) -		return i2c_probe(adap, &addr_data, tda9887_attach); -#else -	switch (adap->id) { -	case I2C_HW_B_BT848: -	case I2C_HW_B_RIVA: -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) -	case I2C_HW_SAA7134: -#endif -		return i2c_probe(adap, &addr_data, tda9887_attach); -		break; -	} -#endif -	return 0; -} +	struct tuner *t = i2c_get_clientdata(client); +	static int AFC_BITS_2_kHz[] = { +		-12500,  -37500,  -62500,  -97500, +		-112500, -137500, -162500, -187500, +		187500,  162500,  137500,  112500, +		97500 ,  62500,   37500 ,  12500 +	}; +	int afc=0; +	__u8 reg = 0; -static int tda9887_detach(struct i2c_client *client) -{ -	struct tda9887 *t = i2c_get_clientdata(client); +	if (1 == i2c_master_recv(&t->i2c,®,1)) +		afc = AFC_BITS_2_kHz[(reg>>1)&0x0f]; -	i2c_detach_client(client); -	kfree(t); -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0) -	MOD_DEC_USE_COUNT; -#endif -	return 0; +	return afc;  } -#define SWITCH_V4L2	if (!t->using_v4l2 && debug) \ -			  tda9887_info("switching to v4l2\n"); \ -			  t->using_v4l2 = 1; -#define CHECK_V4L2	if (t->using_v4l2) { if (debug) \ -			  tda9887_info("ignore v4l1 call\n"); \ -			  return 0; } - -static int -tda9887_command(struct i2c_client *client, unsigned int cmd, void *arg) +static void tda9887_standby(struct i2c_client *client)  { -	struct tda9887 *t = i2c_get_clientdata(client); - -	switch (cmd) { - -	/* --- configuration --- */ -	case AUDC_SET_RADIO: -	{ -		t->mode = T_RADIO; -		tda9887_configure(t); -		break; -	} -	case TUNER_SET_STANDBY: -	{ -		t->mode = T_STANDBY; -		tda9887_configure(t); -		break; -	} -	case TDA9887_SET_CONFIG: -	{ -		int *i = arg; - -		t->config = *i; -		tda9887_configure(t); -		break; -	} -	/* --- v4l ioctls --- */ -	/* take care: bttv does userspace copying, we'll get a -	   kernel pointer here... */ -	case VIDIOCSCHAN: -	{ -		static const v4l2_std_id map[] = { -			[ VIDEO_MODE_PAL   ] = V4L2_STD_PAL, -			[ VIDEO_MODE_NTSC  ] = V4L2_STD_NTSC_M, -			[ VIDEO_MODE_SECAM ] = V4L2_STD_SECAM, -			[ 4 /* bttv */     ] = V4L2_STD_PAL_M, -			[ 5 /* bttv */     ] = V4L2_STD_PAL_N, -			[ 6 /* bttv */     ] = V4L2_STD_NTSC_M_JP, -		}; -		struct video_channel *vc = arg; - -		CHECK_V4L2; -		t->mode = T_ANALOG_TV; -		if (vc->norm < ARRAY_SIZE(map)) -			t->std = map[vc->norm]; -		tda9887_fixup_std(t); -		tda9887_configure(t); -		break; -	} -	case VIDIOC_S_STD: -	{ -		v4l2_std_id *id = arg; - -		SWITCH_V4L2; -		t->mode = T_ANALOG_TV; -		t->std   = *id; -		tda9887_fixup_std(t); -		tda9887_configure(t); -		break; -	} -	case VIDIOC_S_FREQUENCY: -	{ -		struct v4l2_frequency *f = arg; - -		SWITCH_V4L2; -		if (V4L2_TUNER_ANALOG_TV == f->type) { -			if (t->mode == T_ANALOG_TV) -				return 0; -			t->mode = T_ANALOG_TV; -		} -		if (V4L2_TUNER_RADIO == f->type) { -			if (t->mode == T_RADIO) -				return 0; -			t->mode = T_RADIO; -		} -		tda9887_configure(t); -		break; -	} -	case VIDIOC_G_TUNER: -	{ -		static int AFC_BITS_2_kHz[] = { -			-12500,  -37500,  -62500,  -97500, -			-112500, -137500, -162500, -187500, -			187500,  162500,  137500,  112500, -			97500 ,  62500,   37500 ,  12500 -		}; -		struct v4l2_tuner* tuner = arg; - -		if (t->mode == T_RADIO) { -			__u8 reg = 0; -			tuner->afc=0; -			if (1 == i2c_master_recv(&t->client,®,1)) -				tuner->afc = AFC_BITS_2_kHz[(reg>>1)&0x0f]; -		} -		break; -	} -	case VIDIOC_S_TUNER: -	{ -		struct v4l2_tuner* tuner = arg; - -		if (t->mode == T_RADIO) { -			t->radio_mode = tuner->audmode; -			tda9887_configure (t); -		} -		break; -	} -	case VIDIOC_LOG_STATUS: -	{ -		tda9887_info("Data bytes: b=0x%02x c=0x%02x e=0x%02x\n", t->data[1], t->data[2], t->data[3]); -		break; -	} -	default: -		/* nothing */ -		break; -	} -	return 0; +	tda9887_configure(client);  } -#if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0) -#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,14) -static int tda9887_suspend(struct device * dev, pm_message_t state) -#else -#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,13) -static int tda9887_suspend(struct device * dev, pm_message_t state, u32 level) -#else -static int tda9887_suspend(struct device * dev, u32 state, u32 level) -#endif -#endif +static void tda9887_set_freq(struct i2c_client *client, unsigned int freq)  { -	struct i2c_client *c = container_of(dev, struct i2c_client, dev); -	struct tda9887 *t = i2c_get_clientdata(c); - -	tda9887_dbg("suspend\n"); -	return 0; +	tda9887_configure(client);  } -#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,14) -static int tda9887_resume(struct device * dev) -#else -static int tda9887_resume(struct device * dev, u32 level) -#endif +int tda9887_tuner_init(struct i2c_client *c)  { -	struct i2c_client *c = container_of(dev, struct i2c_client, dev); -	struct tda9887 *t = i2c_get_clientdata(c); - -	tda9887_dbg("resume\n"); -	tda9887_configure(t); -	return 0; -} -#endif +	struct tuner *t = i2c_get_clientdata(c); -/* ----------------------------------------------------------------------- */ +	strlcpy(c->name, "tda9887", sizeof(c->name)); -static struct i2c_driver driver = { -#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0))&&(LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,15)) -	.owner          = THIS_MODULE, -#endif -#if LINUX_VERSION_CODE <=  KERNEL_VERSION(2,6,15) -	.name           = "tda9887", -	.flags          = I2C_DF_NOTIFY, -#endif -	.id             = I2C_DRIVERID_TDA9887, -	.attach_adapter = tda9887_probe, -	.detach_client  = tda9887_detach, -	.command        = tda9887_command, -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) -	.driver = { -#if LINUX_VERSION_CODE > KERNEL_VERSION(2,6,15) -		.name    = "tda9887", -#endif -		.suspend = tda9887_suspend, -		.resume  = tda9887_resume, -	}, -#endif -}; -static struct i2c_client client_template = -{ -	.name      = "tda9887", -#if LINUX_VERSION_CODE <=  KERNEL_VERSION(2,6,15) -	.flags     = I2C_CLIENT_ALLOW_USE, -#endif -	.driver    = &driver, -}; +	tda9887_info("tda988[5/6/7] found @ 0x%x (%s)\n", t->i2c.addr, +						t->i2c.driver->driver.name); -static int __init tda9887_init_module(void) -{ -	return i2c_add_driver(&driver); -} +	t->set_tv_freq = tda9887_set_freq; +	t->set_radio_freq = tda9887_set_freq; +	t->standby = tda9887_standby; +	t->tuner_status=tda9887_tuner_status; +	t->get_afc=tda9887_get_afc; -static void __exit tda9887_cleanup_module(void) -{ -	i2c_del_driver(&driver); +	return 0;  } -module_init(tda9887_init_module); -module_exit(tda9887_cleanup_module); -  /*   * Overrides for Emacs so that we follow Linus's tabbing style.   * --------------------------------------------------------------------------- diff --git a/linux/drivers/media/video/tuner-core.c b/linux/drivers/media/video/tuner-core.c index 21bc09dda..be47ad3b3 100644 --- a/linux/drivers/media/video/tuner-core.c +++ b/linux/drivers/media/video/tuner-core.c @@ -243,6 +243,9 @@ static void set_type(struct i2c_client *c, unsigned int type,  		i2c_master_send(c,buffer,4);  		default_tuner_init(c);  		break; +	case TUNER_TDA9887: +		tda9887_tuner_init(c); +		break;  #ifdef CONFIG_XC3028  	case TUNER_XCEIVE_XC3028:  		xc3028_init(c); @@ -280,6 +283,8 @@ static void set_addr(struct i2c_client *c, struct tuner_setup *tun_setup)  {  	struct tuner *t = i2c_get_clientdata(c); +	tuner_dbg("set addr for type %i\n", t->type); +  	if ( t->type == UNSET && ((tun_setup->addr == ADDR_UNSET &&  		(t->mode_mask & tun_setup->mode_mask)) ||  		tun_setup->addr == c->addr)) { @@ -483,6 +488,7 @@ static int tuner_attach(struct i2c_adapter *adap, int addr,  	t->radio_if2 = 10700 * 1000;	/* 10.7MHz - FM radio */  	t->audmode = V4L2_TUNER_MODE_STEREO;  	t->mode_mask = T_UNINITIALIZED; +	t->tuner_status = tuner_status;  	if (tuner_debug_old) {  		tuner_debug = tuner_debug_old;  		printk(KERN_ERR "tuner: tuner_debug is deprecated and will be removed in 2.6.17.\n"); @@ -509,10 +515,14 @@ static int tuner_attach(struct i2c_adapter *adap, int addr,  		case 0x4b:  			/* If chip is not tda8290, don't register.  			   since it can be tda9887*/ -			if (tda8290_probe(&t->i2c) != 0) { -				tuner_dbg("chip at addr %x is not a tda8290\n", addr); -				kfree(t); -				return 0; +			if (tda8290_probe(&t->i2c) == 0) { +				tuner_dbg("chip at addr %x is a tda8290\n", addr); +			} else { +				/* Default is being tda9887 */ +				t->type = TUNER_TDA9887; +				t->mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV; +				t->mode = T_STANDBY; +				goto register_client;  			}  			break;  		case 0x60: @@ -656,6 +666,7 @@ static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)  	case TUNER_SET_STANDBY:  		if (check_mode(t, "TUNER_SET_STANDBY") == EINVAL)  			return 0; +		t->mode = T_STANDBY;  		if (t->standby)  			t->standby (client);  		break; @@ -668,6 +679,14 @@ static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)  		/* Should be implemented, since bttv calls it */  		tuner_dbg("VIDIOCSAUDIO not implemented.\n");  		break; +	case TDA9887_SET_CONFIG: +	{ +		int *i = arg; + +		t->tda9887_config = *i; +		set_freq(client, t->tv_freq); +		break; +	}  	/* --- v4l ioctls --- */  	/* take care: bttv does userspace copying, we'll get a  	   kernel pointer here... */ @@ -808,6 +827,8 @@ static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)  			switch_v4l2();  			tuner->type = t->mode; +			if (t->get_afc) +				tuner->afc=t->get_afc(client);  			if (t->mode == V4L2_TUNER_ANALOG_TV)  				tuner->capability |= V4L2_TUNER_CAP_NORM;  			if (t->mode != V4L2_TUNER_RADIO) { @@ -851,7 +872,8 @@ static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)  			break;  		}  	case VIDIOC_LOG_STATUS: -		tuner_status(client); +		if (t->tuner_status) +			t->tuner_status(client);  		break;  	} diff --git a/linux/drivers/media/video/tuner-simple.c b/linux/drivers/media/video/tuner-simple.c index 0b82156ed..f3cbe151d 100644 --- a/linux/drivers/media/video/tuner-simple.c +++ b/linux/drivers/media/video/tuner-simple.c @@ -114,7 +114,7 @@ static int tuner_stereo(struct i2c_client *c)  	switch (t->type) {  		case TUNER_PHILIPS_FM1216ME_MK3: -    		case TUNER_PHILIPS_FM1236_MK3: +		case TUNER_PHILIPS_FM1236_MK3:  		case TUNER_PHILIPS_FM1256_IH3:  			stereo = ((status & TUNER_SIGNAL) == TUNER_STEREO_MK3);  			break; diff --git a/linux/drivers/media/video/tuner-types.c b/linux/drivers/media/video/tuner-types.c index 4657df313..a87683a49 100644 --- a/linux/drivers/media/video/tuner-types.c +++ b/linux/drivers/media/video/tuner-types.c @@ -1469,6 +1469,11 @@ struct tunertype tuners[] = {  		.params = tuner_samsung_tcpg_6121p30a_params,  		.count  = ARRAY_SIZE(tuner_samsung_tcpg_6121p30a_params),  	}, +	[TUNER_TDA9887] = { /* Philips TDA 9887 IF PLL Demodulator.  +				This chip is part of some modern tuners */ +		.name   = "Philips TDA988[5,6,7] IF PLL Demodulator", +		/* see tda9887.c for details */ +	},  };  unsigned const int tuner_count = ARRAY_SIZE(tuners); diff --git a/linux/drivers/media/video/v4l2-common.c b/linux/drivers/media/video/v4l2-common.c index c04216147..f722ab390 100644 --- a/linux/drivers/media/video/v4l2-common.c +++ b/linux/drivers/media/video/v4l2-common.c @@ -509,9 +509,9 @@ 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%08x, frames=%d, userbits=0x%p\n", +			"flags=0x%08x, frames=%d, userbits=0x%08x\n",  				s,tc->hours,tc->minutes,tc->seconds, -				tc->type, tc->flags, tc->frames, tc->userbits); +				tc->type, tc->flags, tc->frames, *(__u32 *) tc->userbits);  		break;  	}  	case VIDIOC_QUERYCAP: diff --git a/linux/drivers/media/video/videodev.c b/linux/drivers/media/video/videodev.c index 342ccf3ff..c12f88fe3 100644 --- a/linux/drivers/media/video/videodev.c +++ b/linux/drivers/media/video/videodev.c @@ -375,7 +375,7 @@ static void dbgbuf(unsigned int cmd, struct video_device *vfd,  	dbgarg2 ("timecode= %02d:%02d:%02d type=%d, "  		"flags=0x%08d, frames=%d, userbits=0x%08x\n",  			tc->hours,tc->minutes,tc->seconds, -			tc->type, tc->flags, tc->frames, (__u32) tc->userbits); +			tc->type, tc->flags, tc->frames, *(__u32 *) tc->userbits);  }  static inline void dbgrect(struct video_device *vfd, char *s, diff --git a/linux/drivers/media/video/vivi.c b/linux/drivers/media/video/vivi.c index 5fd42153f..614cdc60e 100644 --- a/linux/drivers/media/video/vivi.c +++ b/linux/drivers/media/video/vivi.c @@ -1092,7 +1092,7 @@ static int vidiocgmbuf (struct file *file, void *priv, struct video_mbuf *mbuf)  }  #endif -int vidioc_streamon (struct file *file, void *priv, enum v4l2_buf_type i) +static int vidioc_streamon(struct file *file, void *priv, enum v4l2_buf_type i)  {  	struct vivi_fh  *fh=priv;  	struct vivi_dev *dev    = fh->dev; @@ -1107,7 +1107,7 @@ int vidioc_streamon (struct file *file, void *priv, enum v4l2_buf_type i)  	return (videobuf_streamon(&fh->vb_vidq));  } -int vidioc_streamoff (struct file *file, void *priv, enum v4l2_buf_type i) +static int vidioc_streamoff(struct file *file, void *priv, enum v4l2_buf_type i)  {  	struct vivi_fh  *fh=priv;  	struct vivi_dev *dev    = fh->dev; | 
