aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/media/video/saa7191.c157
1 files changed, 63 insertions, 94 deletions
diff --git a/drivers/media/video/saa7191.c b/drivers/media/video/saa7191.c
index b4018cce3285..9943e5c35e15 100644
--- a/drivers/media/video/saa7191.c
+++ b/drivers/media/video/saa7191.c
@@ -22,6 +22,8 @@
22#include <linux/videodev.h> 22#include <linux/videodev.h>
23#include <linux/video_decoder.h> 23#include <linux/video_decoder.h>
24#include <linux/i2c.h> 24#include <linux/i2c.h>
25#include <media/v4l2-common.h>
26#include <media/v4l2-i2c-drv-legacy.h>
25 27
26#include "saa7191.h" 28#include "saa7191.h"
27 29
@@ -32,6 +34,10 @@ MODULE_VERSION(SAA7191_MODULE_VERSION);
32MODULE_AUTHOR("Mikael Nousiainen <tmnousia@cc.hut.fi>"); 34MODULE_AUTHOR("Mikael Nousiainen <tmnousia@cc.hut.fi>");
33MODULE_LICENSE("GPL"); 35MODULE_LICENSE("GPL");
34 36
37static unsigned short normal_i2c[] = { 0x8a >> 1, 0x8e >> 1, I2C_CLIENT_END };
38
39I2C_CLIENT_INSMOD;
40
35// #define SAA7191_DEBUG 41// #define SAA7191_DEBUG
36 42
37#ifdef SAA7191_DEBUG 43#ifdef SAA7191_DEBUG
@@ -54,8 +60,6 @@ struct saa7191 {
54 int norm; 60 int norm;
55}; 61};
56 62
57static struct i2c_driver i2c_driver_saa7191;
58
59static const u8 initseq[] = { 63static const u8 initseq[] = {
60 0, /* Subaddress */ 64 0, /* Subaddress */
61 65
@@ -561,83 +565,6 @@ static int saa7191_set_control(struct i2c_client *client,
561 565
562/* I2C-interface */ 566/* I2C-interface */
563 567
564static int saa7191_attach(struct i2c_adapter *adap, int addr, int kind)
565{
566 int err = 0;
567 struct saa7191 *decoder;
568 struct i2c_client *client;
569
570 printk(KERN_INFO "Philips SAA7191 driver version %s\n",
571 SAA7191_MODULE_VERSION);
572
573 client = kzalloc(sizeof(*client), GFP_KERNEL);
574 if (!client)
575 return -ENOMEM;
576 decoder = kzalloc(sizeof(*decoder), GFP_KERNEL);
577 if (!decoder) {
578 err = -ENOMEM;
579 goto out_free_client;
580 }
581
582 client->addr = addr;
583 client->adapter = adap;
584 client->driver = &i2c_driver_saa7191;
585 client->flags = 0;
586 strcpy(client->name, "saa7191 client");
587 i2c_set_clientdata(client, decoder);
588
589 decoder->client = client;
590
591 err = i2c_attach_client(client);
592 if (err)
593 goto out_free_decoder;
594
595 err = saa7191_write_block(client, sizeof(initseq), initseq);
596 if (err) {
597 printk(KERN_ERR "SAA7191 initialization failed\n");
598 goto out_detach_client;
599 }
600
601 printk(KERN_INFO "SAA7191 initialized\n");
602
603 decoder->input = SAA7191_INPUT_COMPOSITE;
604 decoder->norm = SAA7191_NORM_PAL;
605
606 err = saa7191_autodetect_norm(client);
607 if (err && (err != -EBUSY)) {
608 printk(KERN_ERR "SAA7191: Signal auto-detection failed\n");
609 }
610
611 return 0;
612
613out_detach_client:
614 i2c_detach_client(client);
615out_free_decoder:
616 kfree(decoder);
617out_free_client:
618 kfree(client);
619 return err;
620}
621
622static int saa7191_probe(struct i2c_adapter *adap)
623{
624 /* Always connected to VINO */
625 if (adap->id == I2C_HW_SGI_VINO)
626 return saa7191_attach(adap, SAA7191_ADDR, 0);
627 /* Feel free to add probe here :-) */
628 return -ENODEV;
629}
630
631static int saa7191_detach(struct i2c_client *client)
632{
633 struct saa7191 *decoder = i2c_get_clientdata(client);
634
635 i2c_detach_client(client);
636 kfree(decoder);
637 kfree(client);
638 return 0;
639}
640
641static int saa7191_command(struct i2c_client *client, unsigned int cmd, 568static int saa7191_command(struct i2c_client *client, unsigned int cmd,
642 void *arg) 569 void *arg)
643{ 570{
@@ -783,25 +710,67 @@ static int saa7191_command(struct i2c_client *client, unsigned int cmd,
783 return 0; 710 return 0;
784} 711}
785 712
786static struct i2c_driver i2c_driver_saa7191 = { 713static int saa7191_probe(struct i2c_client *client,
787 .driver = { 714 const struct i2c_device_id *id)
788 .name = "saa7191", 715{
789 }, 716 int err = 0;
790 .id = I2C_DRIVERID_SAA7191, 717 struct saa7191 *decoder;
791 .attach_adapter = saa7191_probe,
792 .detach_client = saa7191_detach,
793 .command = saa7191_command
794};
795 718
796static int saa7191_init(void) 719 v4l_info(client, "chip found @ 0x%x (%s)\n",
720 client->addr << 1, client->adapter->name);
721
722 decoder = kzalloc(sizeof(*decoder), GFP_KERNEL);
723 if (!decoder)
724 return -ENOMEM;
725
726 i2c_set_clientdata(client, decoder);
727
728 decoder->client = client;
729
730 err = saa7191_write_block(client, sizeof(initseq), initseq);
731 if (err) {
732 printk(KERN_ERR "SAA7191 initialization failed\n");
733 kfree(decoder);
734 return err;
735 }
736
737 printk(KERN_INFO "SAA7191 initialized\n");
738
739 decoder->input = SAA7191_INPUT_COMPOSITE;
740 decoder->norm = SAA7191_NORM_PAL;
741
742 err = saa7191_autodetect_norm(client);
743 if (err && (err != -EBUSY))
744 printk(KERN_ERR "SAA7191: Signal auto-detection failed\n");
745
746 return 0;
747}
748
749static int saa7191_remove(struct i2c_client *client)
797{ 750{
798 return i2c_add_driver(&i2c_driver_saa7191); 751 struct saa7191 *decoder = i2c_get_clientdata(client);
752
753 kfree(decoder);
754 return 0;
799} 755}
800 756
801static void saa7191_exit(void) 757static int saa7191_legacy_probe(struct i2c_adapter *adapter)
802{ 758{
803 i2c_del_driver(&i2c_driver_saa7191); 759 return adapter->id == I2C_HW_SGI_VINO;
804} 760}
805 761
806module_init(saa7191_init); 762static const struct i2c_device_id saa7191_id[] = {
807module_exit(saa7191_exit); 763 { "saa7191", 0 },
764 { }
765};
766MODULE_DEVICE_TABLE(i2c, saa7191_id);
767
768static struct v4l2_i2c_driver_data v4l2_i2c_data = {
769 .name = "saa7191",
770 .driverid = I2C_DRIVERID_SAA7191,
771 .command = saa7191_command,
772 .probe = saa7191_probe,
773 .remove = saa7191_remove,
774 .legacy_probe = saa7191_legacy_probe,
775 .id_table = saa7191_id,
776};