aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHans Verkuil <hverkuil@xs4all.nl>2009-02-07 05:23:40 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2009-03-30 11:42:41 -0400
commitef77a26be1883366bb78741d1808e5c86a14ec76 (patch)
treec2230ea68d7615fc47894bbd15ec1403e5b8fd56
parent80b36e0fcfe7520ee92f648148d091ad880ae711 (diff)
V4L/DVB (10496): saa7146: implement v4l2_device support.
Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/common/saa7146_core.c17
-rw-r--r--include/media/saa7146.h3
2 files changed, 13 insertions, 7 deletions
diff --git a/drivers/media/common/saa7146_core.c b/drivers/media/common/saa7146_core.c
index d599d360da3f..961ad16e1d6f 100644
--- a/drivers/media/common/saa7146_core.c
+++ b/drivers/media/common/saa7146_core.c
@@ -363,13 +363,16 @@ static int saa7146_init_one(struct pci_dev *pci, const struct pci_device_id *ent
363 ERR(("out of memory.\n")); 363 ERR(("out of memory.\n"));
364 goto out; 364 goto out;
365 } 365 }
366 err = v4l2_device_register(&pci->dev, &dev->v4l2_dev);
367 if (err)
368 goto err_free;
366 369
367 DEB_EE(("pci:%p\n",pci)); 370 DEB_EE(("pci:%p\n",pci));
368 371
369 err = pci_enable_device(pci); 372 err = pci_enable_device(pci);
370 if (err < 0) { 373 if (err < 0) {
371 ERR(("pci_enable_device() failed.\n")); 374 ERR(("pci_enable_device() failed.\n"));
372 goto err_free; 375 goto err_unreg;
373 } 376 }
374 377
375 /* enable bus-mastering */ 378 /* enable bus-mastering */
@@ -452,8 +455,6 @@ static int saa7146_init_one(struct pci_dev *pci, const struct pci_device_id *ent
452 INFO(("found saa7146 @ mem %p (revision %d, irq %d) (0x%04x,0x%04x).\n", dev->mem, dev->revision, pci->irq, pci->subsystem_vendor, pci->subsystem_device)); 455 INFO(("found saa7146 @ mem %p (revision %d, irq %d) (0x%04x,0x%04x).\n", dev->mem, dev->revision, pci->irq, pci->subsystem_vendor, pci->subsystem_device));
453 dev->ext = ext; 456 dev->ext = ext;
454 457
455 pci_set_drvdata(pci, dev);
456
457 mutex_init(&dev->lock); 458 mutex_init(&dev->lock);
458 spin_lock_init(&dev->int_slock); 459 spin_lock_init(&dev->int_slock);
459 spin_lock_init(&dev->slock); 460 spin_lock_init(&dev->slock);
@@ -477,7 +478,7 @@ static int saa7146_init_one(struct pci_dev *pci, const struct pci_device_id *ent
477 478
478 if (ext->attach(dev, pci_ext)) { 479 if (ext->attach(dev, pci_ext)) {
479 DEB_D(("ext->attach() failed for %p. skipping device.\n",dev)); 480 DEB_D(("ext->attach() failed for %p. skipping device.\n",dev));
480 goto err_unprobe; 481 goto err_free_i2c;
481 } 482 }
482 483
483 INIT_LIST_HEAD(&dev->item); 484 INIT_LIST_HEAD(&dev->item);
@@ -488,8 +489,6 @@ static int saa7146_init_one(struct pci_dev *pci, const struct pci_device_id *ent
488out: 489out:
489 return err; 490 return err;
490 491
491err_unprobe:
492 pci_set_drvdata(pci, NULL);
493err_free_i2c: 492err_free_i2c:
494 pci_free_consistent(pci, SAA7146_RPS_MEM, dev->d_i2c.cpu_addr, 493 pci_free_consistent(pci, SAA7146_RPS_MEM, dev->d_i2c.cpu_addr,
495 dev->d_i2c.dma_handle); 494 dev->d_i2c.dma_handle);
@@ -507,6 +506,8 @@ err_release:
507 pci_release_region(pci, 0); 506 pci_release_region(pci, 0);
508err_disable: 507err_disable:
509 pci_disable_device(pci); 508 pci_disable_device(pci);
509err_unreg:
510 v4l2_device_unregister(&dev->v4l2_dev);
510err_free: 511err_free:
511 kfree(dev); 512 kfree(dev);
512 goto out; 513 goto out;
@@ -514,7 +515,8 @@ err_free:
514 515
515static void saa7146_remove_one(struct pci_dev *pdev) 516static void saa7146_remove_one(struct pci_dev *pdev)
516{ 517{
517 struct saa7146_dev* dev = pci_get_drvdata(pdev); 518 struct v4l2_device *v4l2_dev = pci_get_drvdata(pdev);
519 struct saa7146_dev *dev = container_of(v4l2_dev, struct saa7146_dev, v4l2_dev);
518 struct { 520 struct {
519 void *addr; 521 void *addr;
520 dma_addr_t dma; 522 dma_addr_t dma;
@@ -528,6 +530,7 @@ static void saa7146_remove_one(struct pci_dev *pdev)
528 DEB_EE(("dev:%p\n",dev)); 530 DEB_EE(("dev:%p\n",dev));
529 531
530 dev->ext->detach(dev); 532 dev->ext->detach(dev);
533 v4l2_device_unregister(&dev->v4l2_dev);
531 534
532 /* shut down all video dma transfers */ 535 /* shut down all video dma transfers */
533 saa7146_write(dev, MC1, 0x00ff0000); 536 saa7146_write(dev, MC1, 0x00ff0000);
diff --git a/include/media/saa7146.h b/include/media/saa7146.h
index c5a6e22a4b37..b9dfeeb26fae 100644
--- a/include/media/saa7146.h
+++ b/include/media/saa7146.h
@@ -13,6 +13,7 @@
13#include <linux/stringify.h> 13#include <linux/stringify.h>
14#include <linux/mutex.h> 14#include <linux/mutex.h>
15#include <linux/scatterlist.h> 15#include <linux/scatterlist.h>
16#include <media/v4l2-device.h>
16 17
17#include <linux/vmalloc.h> /* for vmalloc() */ 18#include <linux/vmalloc.h> /* for vmalloc() */
18#include <linux/mm.h> /* for vmalloc_to_page() */ 19#include <linux/mm.h> /* for vmalloc_to_page() */
@@ -110,6 +111,8 @@ struct saa7146_dev
110 111
111 struct list_head item; 112 struct list_head item;
112 113
114 struct v4l2_device v4l2_dev;
115
113 /* different device locks */ 116 /* different device locks */
114 spinlock_t slock; 117 spinlock_t slock;
115 struct mutex lock; 118 struct mutex lock;