mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	V4L/DVB: saa7146: fix regression of the av7110/budget-av driver
An earlier regression fix for the mxb driver (V4L/DVB: saa7146_vv: fix regression where v4l2_device was registered too late) caused a new regression in the av7110 driver. Reverted the old fix and fixed the problem in the mxb driver instead. Tested on mxb and budget-av cards. The real problem is that the saa7146 framework has separate probe() and attach() driver callbacks which should be rolled into one. This is now done for the mxb driver, but others should do the same. Lack of hardware makes this hard to do, though. I hope to get hold of some hexium cards and then I can try to improve the framework to prevent this from happening again. Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
		
							parent
							
								
									d2f2d6d0a1
								
							
						
					
					
						commit
						03b1930efd
					
				| @ -423,15 +423,14 @@ static void vv_callback(struct saa7146_dev *dev, unsigned long status) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int saa7146_vv_devinit(struct saa7146_dev *dev) |  | ||||||
| { |  | ||||||
| 	return v4l2_device_register(&dev->pci->dev, &dev->v4l2_dev); |  | ||||||
| } |  | ||||||
| EXPORT_SYMBOL_GPL(saa7146_vv_devinit); |  | ||||||
| 
 |  | ||||||
| int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv) | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv) | ||||||
| { | { | ||||||
| 	struct saa7146_vv *vv; | 	struct saa7146_vv *vv; | ||||||
|  | 	int err; | ||||||
|  | 
 | ||||||
|  | 	err = v4l2_device_register(&dev->pci->dev, &dev->v4l2_dev); | ||||||
|  | 	if (err) | ||||||
|  | 		return err; | ||||||
| 
 | 
 | ||||||
| 	vv = kzalloc(sizeof(struct saa7146_vv), GFP_KERNEL); | 	vv = kzalloc(sizeof(struct saa7146_vv), GFP_KERNEL); | ||||||
| 	if (vv == NULL) { | 	if (vv == NULL) { | ||||||
|  | |||||||
| @ -356,9 +356,6 @@ static int hexium_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_d | |||||||
| 
 | 
 | ||||||
| 	DEB_EE((".\n")); | 	DEB_EE((".\n")); | ||||||
| 
 | 
 | ||||||
| 	ret = saa7146_vv_devinit(dev); |  | ||||||
| 	if (ret) |  | ||||||
| 		return ret; |  | ||||||
| 	hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | 	hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | ||||||
| 	if (NULL == hexium) { | 	if (NULL == hexium) { | ||||||
| 		printk("hexium_gemini: not enough kernel memory in hexium_attach().\n"); | 		printk("hexium_gemini: not enough kernel memory in hexium_attach().\n"); | ||||||
|  | |||||||
| @ -216,10 +216,6 @@ static int hexium_probe(struct saa7146_dev *dev) | |||||||
| 		return -EFAULT; | 		return -EFAULT; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	err = saa7146_vv_devinit(dev); |  | ||||||
| 	if (err) |  | ||||||
| 		return err; |  | ||||||
| 
 |  | ||||||
| 	hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | 	hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | ||||||
| 	if (NULL == hexium) { | 	if (NULL == hexium) { | ||||||
| 		printk("hexium_orion: hexium_probe: not enough kernel memory.\n"); | 		printk("hexium_orion: hexium_probe: not enough kernel memory.\n"); | ||||||
|  | |||||||
| @ -169,11 +169,7 @@ static struct saa7146_extension extension; | |||||||
| static int mxb_probe(struct saa7146_dev *dev) | static int mxb_probe(struct saa7146_dev *dev) | ||||||
| { | { | ||||||
| 	struct mxb *mxb = NULL; | 	struct mxb *mxb = NULL; | ||||||
| 	int err; |  | ||||||
| 
 | 
 | ||||||
| 	err = saa7146_vv_devinit(dev); |  | ||||||
| 	if (err) |  | ||||||
| 		return err; |  | ||||||
| 	mxb = kzalloc(sizeof(struct mxb), GFP_KERNEL); | 	mxb = kzalloc(sizeof(struct mxb), GFP_KERNEL); | ||||||
| 	if (mxb == NULL) { | 	if (mxb == NULL) { | ||||||
| 		DEB_D(("not enough kernel memory.\n")); | 		DEB_D(("not enough kernel memory.\n")); | ||||||
| @ -699,14 +695,17 @@ static struct saa7146_ext_vv vv_data; | |||||||
| /* this function only gets called when the probing was successful */ | /* this function only gets called when the probing was successful */ | ||||||
| static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data *info) | static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data *info) | ||||||
| { | { | ||||||
| 	struct mxb *mxb = (struct mxb *)dev->ext_priv; | 	struct mxb *mxb; | ||||||
| 
 | 
 | ||||||
| 	DEB_EE(("dev:%p\n", dev)); | 	DEB_EE(("dev:%p\n", dev)); | ||||||
| 
 | 
 | ||||||
| 	/* checking for i2c-devices can be omitted here, because we
 |  | ||||||
| 	   already did this in "mxb_vl42_probe" */ |  | ||||||
| 
 |  | ||||||
| 	saa7146_vv_init(dev, &vv_data); | 	saa7146_vv_init(dev, &vv_data); | ||||||
|  | 	if (mxb_probe(dev)) { | ||||||
|  | 		saa7146_vv_release(dev); | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  | 	mxb = (struct mxb *)dev->ext_priv; | ||||||
|  | 
 | ||||||
| 	vv_data.ops.vidioc_queryctrl = vidioc_queryctrl; | 	vv_data.ops.vidioc_queryctrl = vidioc_queryctrl; | ||||||
| 	vv_data.ops.vidioc_g_ctrl = vidioc_g_ctrl; | 	vv_data.ops.vidioc_g_ctrl = vidioc_g_ctrl; | ||||||
| 	vv_data.ops.vidioc_s_ctrl = vidioc_s_ctrl; | 	vv_data.ops.vidioc_s_ctrl = vidioc_s_ctrl; | ||||||
| @ -726,6 +725,7 @@ static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data | |||||||
| 	vv_data.ops.vidioc_default = vidioc_default; | 	vv_data.ops.vidioc_default = vidioc_default; | ||||||
| 	if (saa7146_register_device(&mxb->video_dev, dev, "mxb", VFL_TYPE_GRABBER)) { | 	if (saa7146_register_device(&mxb->video_dev, dev, "mxb", VFL_TYPE_GRABBER)) { | ||||||
| 		ERR(("cannot register capture v4l2 device. skipping.\n")); | 		ERR(("cannot register capture v4l2 device. skipping.\n")); | ||||||
|  | 		saa7146_vv_release(dev); | ||||||
| 		return -1; | 		return -1; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -846,7 +846,6 @@ static struct saa7146_extension extension = { | |||||||
| 	.pci_tbl	= &pci_tbl[0], | 	.pci_tbl	= &pci_tbl[0], | ||||||
| 	.module		= THIS_MODULE, | 	.module		= THIS_MODULE, | ||||||
| 
 | 
 | ||||||
| 	.probe		= mxb_probe, |  | ||||||
| 	.attach		= mxb_attach, | 	.attach		= mxb_attach, | ||||||
| 	.detach		= mxb_detach, | 	.detach		= mxb_detach, | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -188,7 +188,6 @@ void saa7146_buffer_timeout(unsigned long data); | |||||||
| void saa7146_dma_free(struct saa7146_dev* dev,struct videobuf_queue *q, | void saa7146_dma_free(struct saa7146_dev* dev,struct videobuf_queue *q, | ||||||
| 						struct saa7146_buf *buf); | 						struct saa7146_buf *buf); | ||||||
| 
 | 
 | ||||||
| int saa7146_vv_devinit(struct saa7146_dev *dev); |  | ||||||
| int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv); | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv); | ||||||
| int saa7146_vv_release(struct saa7146_dev* dev); | int saa7146_vv_release(struct saa7146_dev* dev); | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Hans Verkuil
						Hans Verkuil