summaryrefslogtreecommitdiff
path: root/linux/drivers
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <devnull@localhost>2005-06-20 15:35:05 +0000
committerMauro Carvalho Chehab <devnull@localhost>2005-06-20 15:35:05 +0000
commitaac6384c805c0867edcbc45270a63d4e4b366de8 (patch)
tree7de81377856686cc944f2b2c4a1ed18bf24aadb6 /linux/drivers
parent4e21c63b1bbee8b312500fa3d5ea141ecc9959e2 (diff)
downloadmediapointer-dvb-s2-aac6384c805c0867edcbc45270a63d4e4b366de8.tar.gz
mediapointer-dvb-s2-aac6384c805c0867edcbc45270a63d4e4b366de8.tar.bz2
This is some small changes on tuner-core.c to correct API behavior for stereo:
- v4l2_tuner has three fields for audio mode: capability (bitmask, says what the hardware is able to do). rxsubchans (bitmask, which channels are available). audmode (enum, current mode). For radio seeing a stereo signal but sending mono the driver can simply set this: rxsubchans = V4L2_TUNER_SUB_MONO | V4L2_TUNER_SUB_STEREO; audmode = V4L2_TUNER_MODE_MONO; - VIDIOCSTUNER should not allow turning stereo/mono. Code commented. It will be removed soon. Signed-off-by: Gerd Knorr <kraxel@bytesex.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@brturbo.com.br>
Diffstat (limited to 'linux/drivers')
-rw-r--r--linux/drivers/media/video/tuner-core.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/linux/drivers/media/video/tuner-core.c b/linux/drivers/media/video/tuner-core.c
index bda1fbbda..d86e234e3 100644
--- a/linux/drivers/media/video/tuner-core.c
+++ b/linux/drivers/media/video/tuner-core.c
@@ -1,5 +1,5 @@
/*
- * $Id: tuner-core.c,v 1.26 2005/06/19 23:52:22 mchehab Exp $
+ * $Id: tuner-core.c,v 1.27 2005/06/20 15:35:05 mchehab Exp $
*
* i2c tv tuner chip device driver
* core core, i.e. kernel interfaces, registering and so on
@@ -186,14 +186,12 @@ static void set_type(struct i2c_client *c, unsigned int type)
break;
default:
/* TEA5767 autodetection code */
- if ( c->addr==0x60 ) {
if (tea5767_tuner_init(c)!=EINVAL) {
t->type = TUNER_TEA5767;
if (first_tuner == 0x60)
first_tuner++;
break;
}
- }
default_tuner_init(c);
break;
@@ -502,17 +500,16 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
tuner -> signal = t->has_signal(client);
if (t->is_stereo) {
if (t->is_stereo(client)) {
- tuner -> rxsubchans |= V4L2_TUNER_SUB_STEREO;
+ tuner -> rxsubchans = V4L2_TUNER_SUB_STEREO | V4L2_TUNER_SUB_MONO;
} else {
- tuner -> rxsubchans &= V4L2_TUNER_SUB_MONO;
+ tuner -> rxsubchans = V4L2_TUNER_SUB_MONO;
}
}
- tuner->capability |= V4L2_TUNER_CAP_LOW;
- tuner->capability |= V4L2_TUNER_CAP_STEREO;
+ tuner->capability |= V4L2_TUNER_CAP_LOW | V4L2_TUNER_CAP_STEREO;
+ tuner->audmode = t->audmode;
tuner->rangelow = radio_range[0] * 16000;
tuner->rangehigh = radio_range[1] * 16000;
-
} else {
tuner->rangelow = tv_range[0] * 16;
tuner->rangehigh = tv_range[1] * 16;
@@ -521,6 +518,8 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
}
case VIDIOCSTUNER:
{
+#if 0
+ /* This is NOT an expected valid behavior for V4L1 API CALL... Should be used only for testing purposes */
struct video_tuner *vt = arg;
struct v4l2_tuner tuner;
@@ -543,6 +542,7 @@ tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
tuner_dbg ("Unimplemented IOCTL VIDIO_S_TUNER called to tuner-core.\n");
}
break;
+#endif
return 0;
}