summaryrefslogtreecommitdiff
path: root/linux/drivers/media/video/saa7134/saa7134-core.c
diff options
context:
space:
mode:
authorHartmut Hackmann <hartmut.hackmann@t-online.de>2007-02-15 00:42:04 +0100
committerHartmut Hackmann <hartmut.hackmann@t-online.de>2007-02-15 00:42:04 +0100
commitabf69ab9d6b9d4c9729c7b4189c15171a1d2e575 (patch)
tree93584ab75248b049e881aab65914a4d65d064851 /linux/drivers/media/video/saa7134/saa7134-core.c
parent63d02f07474ecdd2c460bd789977c93bebb40beb (diff)
downloadmediapointer-dvb-s2-abf69ab9d6b9d4c9729c7b4189c15171a1d2e575.tar.gz
mediapointer-dvb-s2-abf69ab9d6b9d4c9729c7b4189c15171a1d2e575.tar.bz2
updated support for tuner callbacks
From: Hartmut Hackmann <hartmut.hackmann@t-online.de> This change supplies a more generic version of the tuner callback. The tuner struct now has a function pointer int (*tuner_callback) (void *dev, int command, int arg) additionally to a int config parameter. both can be set through the TUNER_SET_TYPE_ADDR client call. Note that the meaning of the parameters depend on the tuner type. Signed-off-by: Hartmut Hackmann <hartmut.hackmann@t-online.de>
Diffstat (limited to 'linux/drivers/media/video/saa7134/saa7134-core.c')
-rw-r--r--linux/drivers/media/video/saa7134/saa7134-core.c29
1 files changed, 23 insertions, 6 deletions
diff --git a/linux/drivers/media/video/saa7134/saa7134-core.c b/linux/drivers/media/video/saa7134/saa7134-core.c
index 180b1f854..0195b3597 100644
--- a/linux/drivers/media/video/saa7134/saa7134-core.c
+++ b/linux/drivers/media/video/saa7134/saa7134-core.c
@@ -140,7 +140,6 @@ void saa7134_track_gpio(struct saa7134_dev *dev, char *msg)
void saa7134_set_gpio(struct saa7134_dev *dev, int bit_no, int value)
{
u32 index, bitval;
- u8 sync_control;
index = 1 << bit_no;
switch (value) {
@@ -160,22 +159,40 @@ void saa7134_set_gpio(struct saa7134_dev *dev, int bit_no, int value)
dprintk("setting GPIO%d to tristate\n", bit_no);
saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, index, 0);
break;
- case 4: /* sync output on GPIO 22 for tda8275a, 50Hz*/
- case 5: /* sync output on GPIO 22 for tda8275a, 60Hz*/
- if (bit_no == 22) {
- dprintk("setting GPIO22 to vsync %d\n", value - 4);
+ }
+}
+
+int saa7134_tuner_callback(void *ptr, int command, int arg)
+{
+ u8 sync_control;
+ struct saa7134_dev *dev = ptr;
+
+ switch (dev->tuner_type) {
+ case TUNER_PHILIPS_TDA8290:
+ switch (command) {
+ case 0: /* switch LNA gain through GPIO 22*/
+ saa7134_set_gpio(dev, 22, arg) ;
+ break;
+ case 1: /* vsync output at GPIO22. 50 / 60Hz */
+ dprintk("setting GPIO22 to vsync %d\n", arg);
saa_andorb(SAA7134_VIDEO_PORT_CTRL3, 0x80, 0x80);
saa_andorb(SAA7134_VIDEO_PORT_CTRL6, 0x0f, 0x03);
- if (value == 5)
+ if (arg == 1)
sync_control = 11;
else
sync_control = 17;
saa_writeb(SAA7134_VGATE_START, sync_control);
saa_writeb(SAA7134_VGATE_STOP, sync_control + 1);
saa_andorb(SAA7134_MISC_VGATE_MSB, 0x03, 0x00);
+ break;
+ default:
+ return -EINVAL;
}
break;
+ default:
+ return -ENODEV;
}
+ return 0;
}
/* ------------------------------------------------------------------ */