diff options
| author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-05-14 08:36:50 -0300 | 
|---|---|---|
| committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-05-14 08:36:50 -0300 | 
| commit | f73d4223cf12d0d65a3bd9d6da0ff8807c86d064 (patch) | |
| tree | 69f2f087b6053c218a8f5431f56aff437c8ee538 /linux/drivers/media/dvb | |
| parent | 7e2fc0b0dd4648fcd4c2ca82093aebcfaed3e863 (diff) | |
| parent | bdef8c3d9a3ba2fab464529580ae8028d74e8aff (diff) | |
| download | mediapointer-dvb-s2-f73d4223cf12d0d65a3bd9d6da0ff8807c86d064.tar.gz mediapointer-dvb-s2-f73d4223cf12d0d65a3bd9d6da0ff8807c86d064.tar.bz2 | |
merge: http://linuxtv.org/hg/~mkrufky/k2c2
From: Mauro Carvalho Chehab <mchehab@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'linux/drivers/media/dvb')
| -rw-r--r-- | linux/drivers/media/dvb/dvb-usb/af9015.c | 8 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/dvb-usb/dvb-usb-ids.h | 1 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/firewire/firedtv-1394.c | 4 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/firewire/firedtv-dvb.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/firewire/firedtv-rc.c | 4 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/af9013.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/cx24116.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/drx397xD.c | 4 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/nxt200x.c | 6 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/or51132.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/frontends/tda10048.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/siano/smscoreapi.h | 57 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/siano/smsdvb.c | 41 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/ttpci/av7110_av.c | 124 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/ttpci/av7110_v4l.c | 2 | ||||
| -rw-r--r-- | linux/drivers/media/dvb/ttpci/budget-av.c | 2 | 
16 files changed, 167 insertions, 96 deletions
| diff --git a/linux/drivers/media/dvb/dvb-usb/af9015.c b/linux/drivers/media/dvb/dvb-usb/af9015.c index 57c678892..5d9aacd0a 100644 --- a/linux/drivers/media/dvb/dvb-usb/af9015.c +++ b/linux/drivers/media/dvb/dvb-usb/af9015.c @@ -1267,6 +1267,7 @@ static struct usb_device_id af9015_usb_table[] = {  /* 20 */{USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_A850)},  	{USB_DEVICE(USB_VID_AVERMEDIA, USB_PID_AVERMEDIA_A805)},  	{USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_CONCEPTRONIC_CTVDIGRCU)}, +	{USB_DEVICE(USB_VID_KWORLD_2,  USB_PID_KWORLD_MC810)},  	{0},  };  MODULE_DEVICE_TABLE(usb, af9015_usb_table); @@ -1537,7 +1538,7 @@ static struct dvb_usb_device_properties af9015_properties[] = {  		.i2c_algo = &af9015_i2c_algo, -		.num_device_descs = 2, /* max 9 */ +		.num_device_descs = 3, /* max 9 */  		.devices = {  			{  				.name = "AverMedia AVerTV Volar GPS 805 (A805)", @@ -1550,6 +1551,11 @@ static struct dvb_usb_device_properties af9015_properties[] = {  				.cold_ids = {&af9015_usb_table[22], NULL},  				.warm_ids = {NULL},  			}, +			{ +				.name = "KWorld Digial MC-810", +				.cold_ids = {&af9015_usb_table[23], NULL}, +				.warm_ids = {NULL}, +			},  		}  	},  }; diff --git a/linux/drivers/media/dvb/dvb-usb/dvb-usb-ids.h b/linux/drivers/media/dvb/dvb-usb/dvb-usb-ids.h index 6a4062d5d..1b5e65f1d 100644 --- a/linux/drivers/media/dvb/dvb-usb/dvb-usb-ids.h +++ b/linux/drivers/media/dvb/dvb-usb/dvb-usb-ids.h @@ -105,6 +105,7 @@  #define USB_PID_KWORLD_395U				0xe396  #define USB_PID_KWORLD_395U_2				0xe39b  #define USB_PID_KWORLD_395U_3				0xe395 +#define USB_PID_KWORLD_MC810				0xc810  #define USB_PID_KWORLD_PC160_2T				0xc160  #define USB_PID_KWORLD_VSTREAM_COLD			0x17de  #define USB_PID_KWORLD_VSTREAM_WARM			0x17df diff --git a/linux/drivers/media/dvb/firewire/firedtv-1394.c b/linux/drivers/media/dvb/firewire/firedtv-1394.c index 4e207658c..2b6eeeab5 100644 --- a/linux/drivers/media/dvb/firewire/firedtv-1394.c +++ b/linux/drivers/media/dvb/firewire/firedtv-1394.c @@ -225,7 +225,7 @@ fail_free:  static int node_remove(struct device *dev)  { -	struct firedtv *fdtv = dev->driver_data; +	struct firedtv *fdtv = dev_get_drvdata(dev);  	fdtv_dvb_unregister(fdtv); @@ -242,7 +242,7 @@ static int node_remove(struct device *dev)  static int node_update(struct unit_directory *ud)  { -	struct firedtv *fdtv = ud->device.driver_data; +	struct firedtv *fdtv = dev_get_drvdata(&ud->device);  	if (fdtv->isochannel >= 0)  		cmp_establish_pp_connection(fdtv, fdtv->subunit, diff --git a/linux/drivers/media/dvb/firewire/firedtv-dvb.c b/linux/drivers/media/dvb/firewire/firedtv-dvb.c index 9d308dd32..5742fde79 100644 --- a/linux/drivers/media/dvb/firewire/firedtv-dvb.c +++ b/linux/drivers/media/dvb/firewire/firedtv-dvb.c @@ -268,7 +268,7 @@ struct firedtv *fdtv_alloc(struct device *dev,  	if (!fdtv)  		return NULL; -	dev->driver_data	= fdtv; +	dev_set_drvdata(dev, fdtv);  	fdtv->device		= dev;  	fdtv->isochannel	= -1;  	fdtv->voltage		= 0xff; diff --git a/linux/drivers/media/dvb/firewire/firedtv-rc.c b/linux/drivers/media/dvb/firewire/firedtv-rc.c index 46a6324d7..27bca2e28 100644 --- a/linux/drivers/media/dvb/firewire/firedtv-rc.c +++ b/linux/drivers/media/dvb/firewire/firedtv-rc.c @@ -18,7 +18,7 @@  #include "firedtv.h"  /* fixed table with older keycodes, geared towards MythTV */ -const static u16 oldtable[] = { +static const u16 oldtable[] = {  	/* code from device: 0x4501...0x451f */ @@ -62,7 +62,7 @@ const static u16 oldtable[] = {  };  /* user-modifiable table for a remote as sold in 2008 */ -const static u16 keytable[] = { +static const u16 keytable[] = {  	/* code from device: 0x0300...0x031f */ diff --git a/linux/drivers/media/dvb/frontends/af9013.c b/linux/drivers/media/dvb/frontends/af9013.c index 937715a96..d12d99802 100644 --- a/linux/drivers/media/dvb/frontends/af9013.c +++ b/linux/drivers/media/dvb/frontends/af9013.c @@ -1456,7 +1456,7 @@ static int af9013_download_firmware(struct af9013_state *state)  		af9013_ops.info.name);  	/* request the firmware, this will block and timeout */ -	ret = request_firmware(&fw, fw_file,  &state->i2c->dev); +	ret = request_firmware(&fw, fw_file, state->i2c->dev.parent);  	if (ret) {  		err("did not find the firmware file. (%s) "  			"Please see linux/Documentation/dvb/ for more details" \ diff --git a/linux/drivers/media/dvb/frontends/cx24116.c b/linux/drivers/media/dvb/frontends/cx24116.c index b5ff0b6a8..fddd27bd1 100644 --- a/linux/drivers/media/dvb/frontends/cx24116.c +++ b/linux/drivers/media/dvb/frontends/cx24116.c @@ -492,7 +492,7 @@ static int cx24116_firmware_ondemand(struct dvb_frontend *fe)  		printk(KERN_INFO "%s: Waiting for firmware upload (%s)...\n",  			__func__, CX24116_DEFAULT_FIRMWARE);  		ret = request_firmware(&fw, CX24116_DEFAULT_FIRMWARE, -			&state->i2c->dev); +			state->i2c->dev.parent);  		printk(KERN_INFO "%s: Waiting for firmware upload(2)...\n",  			__func__);  		if (ret) { diff --git a/linux/drivers/media/dvb/frontends/drx397xD.c b/linux/drivers/media/dvb/frontends/drx397xD.c index 0bdb933d0..95eff4a81 100644 --- a/linux/drivers/media/dvb/frontends/drx397xD.c +++ b/linux/drivers/media/dvb/frontends/drx397xD.c @@ -124,10 +124,10 @@ static int drx_load_fw(struct drx397xD_state *s, enum fw_ix ix)  	}  	memset(&fw[ix].data[0], 0, sizeof(fw[0].data)); -	if (request_firmware(&fw[ix].file, fw[ix].name, &s->i2c->dev) != 0) { +	rc = request_firmware(&fw[ix].file, fw[ix].name, s->i2c->dev.parent); +	if (rc != 0) {  		printk(KERN_ERR "%s: Firmware \"%s\" not available\n",  		       mod_name, fw[ix].name); -		rc = -ENOENT;  		goto exit_err;  	} diff --git a/linux/drivers/media/dvb/frontends/nxt200x.c b/linux/drivers/media/dvb/frontends/nxt200x.c index 846350bc4..748f95b22 100644 --- a/linux/drivers/media/dvb/frontends/nxt200x.c +++ b/linux/drivers/media/dvb/frontends/nxt200x.c @@ -880,7 +880,8 @@ static int nxt2002_init(struct dvb_frontend* fe)  	/* request the firmware, this will block until someone uploads it */  	printk("nxt2002: Waiting for firmware upload (%s)...\n", NXT2002_DEFAULT_FIRMWARE); -	ret = request_firmware(&fw, NXT2002_DEFAULT_FIRMWARE, &state->i2c->dev); +	ret = request_firmware(&fw, NXT2002_DEFAULT_FIRMWARE, +			       state->i2c->dev.parent);  	printk("nxt2002: Waiting for firmware upload(2)...\n");  	if (ret) {  		printk("nxt2002: No firmware uploaded (timeout or file not found?)\n"); @@ -944,7 +945,8 @@ static int nxt2004_init(struct dvb_frontend* fe)  	/* request the firmware, this will block until someone uploads it */  	printk("nxt2004: Waiting for firmware upload (%s)...\n", NXT2004_DEFAULT_FIRMWARE); -	ret = request_firmware(&fw, NXT2004_DEFAULT_FIRMWARE, &state->i2c->dev); +	ret = request_firmware(&fw, NXT2004_DEFAULT_FIRMWARE, +			       state->i2c->dev.parent);  	printk("nxt2004: Waiting for firmware upload(2)...\n");  	if (ret) {  		printk("nxt2004: No firmware uploaded (timeout or file not found?)\n"); diff --git a/linux/drivers/media/dvb/frontends/or51132.c b/linux/drivers/media/dvb/frontends/or51132.c index 5ed32544d..8133ea3cd 100644 --- a/linux/drivers/media/dvb/frontends/or51132.c +++ b/linux/drivers/media/dvb/frontends/or51132.c @@ -340,7 +340,7 @@ static int or51132_set_parameters(struct dvb_frontend* fe,  		}  		printk("or51132: Waiting for firmware upload(%s)...\n",  		       fwname); -		ret = request_firmware(&fw, fwname, &state->i2c->dev); +		ret = request_firmware(&fw, fwname, state->i2c->dev.parent);  		if (ret) {  			printk(KERN_WARNING "or51132: No firmware up"  			       "loaded(timeout or file not found?)\n"); diff --git a/linux/drivers/media/dvb/frontends/tda10048.c b/linux/drivers/media/dvb/frontends/tda10048.c index 3163aad5b..a223e617f 100644 --- a/linux/drivers/media/dvb/frontends/tda10048.c +++ b/linux/drivers/media/dvb/frontends/tda10048.c @@ -492,7 +492,7 @@ static int tda10048_firmware_upload(struct dvb_frontend *fe)  		TDA10048_DEFAULT_FIRMWARE);  	ret = request_firmware(&fw, TDA10048_DEFAULT_FIRMWARE, -		&state->i2c->dev); +		state->i2c->dev.parent);  	if (ret) {  		printk(KERN_ERR "%s: Upload failed. (file not found?)\n",  			__func__); diff --git a/linux/drivers/media/dvb/siano/smscoreapi.h b/linux/drivers/media/dvb/siano/smscoreapi.h index 83e0e55f7..72e385c05 100644 --- a/linux/drivers/media/dvb/siano/smscoreapi.h +++ b/linux/drivers/media/dvb/siano/smscoreapi.h @@ -1,26 +1,26 @@ -/* - *  Driver for the Siano SMS1xxx USB dongle - * - *  author: Anatoly Greenblat - * - *  Copyright (c), 2005-2008 Siano Mobile Silicon, Inc. - * - *  This program is free software; you can redistribute it and/or modify - *  it under the terms of the GNU General Public License version 2 as - *  published by the Free Software Foundation; - * - *  Software distributed under the License is distributed on an "AS IS" - *  basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. - * - *  See the GNU General Public License for more details. - * - *  You should have received a copy of the GNU General Public License - *  along with this program; if not, write to the Free Software - *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - */ - -#ifndef __smscoreapi_h__ -#define __smscoreapi_h__ +/**************************************************************** + +Siano Mobile Silicon, Inc. +MDTV receiver kernel modules. +Copyright (C) 2006-2008, Uri Shkolnik, Anatoly Greenblat + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 2 of the License, or +(at your option) any later version. + + This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program.  If not, see <http://www.gnu.org/licenses/>. + +****************************************************************/ + +#ifndef __SMS_CORE_API_H__ +#define __SMS_CORE_API_H__  #include <linux/version.h>  #include <linux/device.h> @@ -28,15 +28,20 @@  #include <linux/mm.h>  #include <linux/scatterlist.h>  #include <linux/types.h> -#include <asm/page.h>  #include <linux/mutex.h> +#include <linux/wait.h> +#include <linux/timer.h> + +#include <asm/page.h>  #include "compat.h" +#define SMS_DVB3_SUBSYS +#ifdef SMS_DVB3_SUBSYS  #include "dmxdev.h"  #include "dvbdev.h"  #include "dvb_demux.h"  #include "dvb_frontend.h" - +#endif  #define kmutex_init(_p_) mutex_init(_p_)  #define kmutex_lock(_p_) mutex_lock(_p_) @@ -679,4 +684,4 @@ int smscore_led_state(struct smscore_device_t *core, int led);  	dprintk(KERN_DEBUG, DBG_ADV, fmt, ##arg) -#endif /* __smscoreapi_h__ */ +#endif /* __SMS_CORE_API_H__ */ diff --git a/linux/drivers/media/dvb/siano/smsdvb.c b/linux/drivers/media/dvb/siano/smsdvb.c index 035bd52c9..255ee5719 100644 --- a/linux/drivers/media/dvb/siano/smsdvb.c +++ b/linux/drivers/media/dvb/siano/smsdvb.c @@ -1,23 +1,23 @@ -/* - *  Driver for the Siano SMS1xxx USB dongle - * - *  Author: Uri Shkolni - * - *  Copyright (c), 2005-2008 Siano Mobile Silicon, Inc. - * - *  This program is free software; you can redistribute it and/or modify - *  it under the terms of the GNU General Public License version 2 as - *  published by the Free Software Foundation; - * - *  Software distributed under the License is distributed on an "AS IS" - *  basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. - * - *  See the GNU General Public License for more details. - * - *  You should have received a copy of the GNU General Public License - *  along with this program; if not, write to the Free Software - *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - */ +/**************************************************************** + +Siano Mobile Silicon, Inc. +MDTV receiver kernel modules. +Copyright (C) 2006-2008, Uri Shkolnik + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 2 of the License, or +(at your option) any later version. + + This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program.  If not, see <http://www.gnu.org/licenses/>. + +****************************************************************/  #include <linux/module.h>  #include <linux/init.h> @@ -488,7 +488,6 @@ static int smsdvb_hotplug(struct smscore_device_t *coredev,  	client->coredev = coredev;  	init_completion(&client->tune_done); -	init_completion(&client->stat_done);  	kmutex_lock(&g_smsdvb_clientslock); diff --git a/linux/drivers/media/dvb/ttpci/av7110_av.c b/linux/drivers/media/dvb/ttpci/av7110_av.c index e4d0900d5..538848141 100644 --- a/linux/drivers/media/dvb/ttpci/av7110_av.c +++ b/linux/drivers/media/dvb/ttpci/av7110_av.c @@ -89,6 +89,7 @@  static void p_to_t(u8 const *buf, long int length, u16 pid,  		   u8 *counter, struct dvb_demux_feed *feed); +static int write_ts_to_decoder(struct av7110 *av7110, int type, const u8 *buf, size_t len);  int av7110_record_cb(struct dvb_filter_pes2ts *p2t, u8 *buf, size_t len) @@ -192,8 +193,6 @@ int av7110_av_start_play(struct av7110 *av7110, int av)  		ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY, __Play, 2, AV_PES, 0);  		break;  	} -	if (!ret) -		ret = av7110->playing;  	return ret;  } @@ -437,6 +436,45 @@ static void play_audio_cb(u8 *buf, int count, void *priv)  	aux_ring_buffer_write(&av7110->aout, buf, count);  } + +#define FREE_COND_TS (dvb_ringbuffer_free(rb) >= 4096) + +static ssize_t ts_play(struct av7110 *av7110, const char __user *buf, +		       unsigned long count, int nonblock, int type) +{ +	struct dvb_ringbuffer *rb; +	u8 *kb; +	unsigned long todo = count; + +	dprintk(2, "%s: type %d cnt %lu\n", __func__, type, count); + +	rb = (type) ? &av7110->avout : &av7110->aout; +	kb = av7110->kbuf[type]; + +	if (!kb) +		return -ENOBUFS; + +	if (nonblock && !FREE_COND_TS) +		return -EWOULDBLOCK; + +	while (todo >= TS_SIZE) { +		if (!FREE_COND_TS) { +			if (nonblock) +				return count - todo; +			if (wait_event_interruptible(rb->queue, FREE_COND_TS)) +				return count - todo; +		} +		if (copy_from_user(kb, buf, TS_SIZE)) +			return -EFAULT; +		write_ts_to_decoder(av7110, type, kb, TS_SIZE); +		todo -= TS_SIZE; +		buf += TS_SIZE; +	} + +	return count - todo; +} + +  #define FREE_COND (dvb_ringbuffer_free(&av7110->avout) >= 20 * 1024 && \  		   dvb_ringbuffer_free(&av7110->aout) >= 20 * 1024) @@ -780,11 +818,37 @@ static void p_to_t(u8 const *buf, long int length, u16 pid, u8 *counter,  } +static int write_ts_to_decoder(struct av7110 *av7110, int type, const u8 *buf, size_t len) +{ +	struct ipack *ipack = &av7110->ipack[type]; + +	if (buf[1] & TRANS_ERROR) { +		av7110_ipack_reset(ipack); +		return -1; +	} + +	if (!(buf[3] & PAYLOAD)) +		return -1; + +	if (buf[1] & PAY_START) +		av7110_ipack_flush(ipack); + +	if (buf[3] & ADAPT_FIELD) { +		len -= buf[4] + 1; +		buf += buf[4] + 1; +		if (!len) +			return 0; +	} + +	av7110_ipack_instant_repack(buf + 4, len - 4, ipack); +	return 0; +} + +  int av7110_write_to_decoder(struct dvb_demux_feed *feed, const u8 *buf, size_t len)  {  	struct dvb_demux *demux = feed->demux;  	struct av7110 *av7110 = (struct av7110 *) demux->priv; -	struct ipack *ipack = &av7110->ipack[feed->pes_type];  	dprintk(2, "av7110:%p, \n", av7110); @@ -804,20 +868,7 @@ int av7110_write_to_decoder(struct dvb_demux_feed *feed, const u8 *buf, size_t l  		return -1;  	} -	if (!(buf[3] & 0x10)) /* no payload? */ -		return -1; -	if (buf[1] & 0x40) -		av7110_ipack_flush(ipack); - -	if (buf[3] & 0x20) {  /* adaptation field? */ -		len -= buf[4] + 1; -		buf += buf[4] + 1; -		if (!len) -			return 0; -	} - -	av7110_ipack_instant_repack(buf + 4, len - 4, &av7110->ipack[feed->pes_type]); -	return 0; +	return write_ts_to_decoder(av7110, feed->pes_type, buf, len);  } @@ -916,6 +967,7 @@ static ssize_t dvb_video_write(struct file *file, const char __user *buf,  {  	struct dvb_device *dvbdev = file->private_data;  	struct av7110 *av7110 = dvbdev->priv; +	unsigned char c;  	dprintk(2, "av7110:%p, \n", av7110); @@ -925,7 +977,12 @@ static ssize_t dvb_video_write(struct file *file, const char __user *buf,  	if (av7110->videostate.stream_source != VIDEO_SOURCE_MEMORY)  		return -EPERM; -	return dvb_play(av7110, buf, count, file->f_flags & O_NONBLOCK, 1); +	if (get_user(c, buf)) +		return -EFAULT; +	if (c == 0x47 && count % TS_SIZE == 0) +		return ts_play(av7110, buf, count, file->f_flags & O_NONBLOCK, 1); +	else +		return dvb_play(av7110, buf, count, file->f_flags & O_NONBLOCK, 1);  }  static unsigned int dvb_audio_poll(struct file *file, poll_table *wait) @@ -952,6 +1009,7 @@ static ssize_t dvb_audio_write(struct file *file, const char __user *buf,  {  	struct dvb_device *dvbdev = file->private_data;  	struct av7110 *av7110 = dvbdev->priv; +	unsigned char c;  	dprintk(2, "av7110:%p, \n", av7110); @@ -959,7 +1017,13 @@ static ssize_t dvb_audio_write(struct file *file, const char __user *buf,  		printk(KERN_ERR "not audio source memory\n");  		return -EPERM;  	} -	return dvb_aplay(av7110, buf, count, file->f_flags & O_NONBLOCK, 0); + +	if (get_user(c, buf)) +		return -EFAULT; +	if (c == 0x47 && count % TS_SIZE == 0) +		return ts_play(av7110, buf, count, file->f_flags & O_NONBLOCK, 0); +	else +		return dvb_aplay(av7110, buf, count, file->f_flags & O_NONBLOCK, 0);  }  static u8 iframe_header[] = { 0x00, 0x00, 0x01, 0xe0, 0x00, 0x00, 0x80, 0x00, 0x00 }; @@ -1062,7 +1126,6 @@ static int dvb_video_ioctl(struct inode *inode, struct file *file,  			if (ret)  				break;  		} -  		if (av7110->videostate.stream_source == VIDEO_SOURCE_MEMORY) {  			if (av7110->playing == RP_AV) {  				ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY, __Stop, 0); @@ -1122,20 +1185,16 @@ static int dvb_video_ioctl(struct inode *inode, struct file *file,  	case VIDEO_SET_DISPLAY_FORMAT:  	{  		video_displayformat_t format = (video_displayformat_t) arg; -  		switch (format) {  		case VIDEO_PAN_SCAN:  			av7110->display_panscan = VID_PAN_SCAN_PREF;  			break; -  		case VIDEO_LETTER_BOX:  			av7110->display_panscan = VID_VC_AND_PS_PREF;  			break; -  		case VIDEO_CENTER_CUT_OUT:  			av7110->display_panscan = VID_CENTRE_CUT_PREF;  			break; -  		default:  			ret = -EINVAL;  		} @@ -1183,7 +1242,8 @@ static int dvb_video_ioctl(struct inode *inode, struct file *file,  	case VIDEO_SLOWMOTION:  		if (av7110->playing&RP_VIDEO) { -			ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY, __Slow, 2, 0, 0); +			if (av7110->trickmode != TRICK_SLOW) +				ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY, __Slow, 2, 0, 0);  			if (!ret)  				ret = vidcom(av7110, AV_VIDEO_CMD_SLOW, arg);  		} else { @@ -1207,7 +1267,6 @@ static int dvb_video_ioctl(struct inode *inode, struct file *file,  	case VIDEO_CLEAR_BUFFER:  		dvb_ringbuffer_flush_spinlock_wakeup(&av7110->avout);  		av7110_ipack_reset(&av7110->ipack[1]); -  		if (av7110->playing == RP_AV) {  			ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY,  					    __Play, 2, AV_PES, 0); @@ -1228,13 +1287,13 @@ static int dvb_video_ioctl(struct inode *inode, struct file *file,  		break;  	case VIDEO_SET_STREAMTYPE: -  		break;  	default:  		ret = -ENOIOCTLCMD;  		break;  	} +  	return ret;  } @@ -1309,7 +1368,6 @@ static int dvb_audio_ioctl(struct inode *inode, struct file *file,  	case AUDIO_CHANNEL_SELECT:  		av7110->audiostate.channel_select = (audio_channel_select_t) arg; -  		switch(av7110->audiostate.channel_select) {  		case AUDIO_STEREO:  			ret = audcom(av7110, AUDIO_CMD_STEREO); @@ -1320,7 +1378,6 @@ static int dvb_audio_ioctl(struct inode *inode, struct file *file,  					msp_writereg(av7110, MSP_WR_DSP, 0x0008, 0x0220);  			}  			break; -  		case AUDIO_MONO_LEFT:  			ret = audcom(av7110, AUDIO_CMD_MONO_L);  			if (!ret) { @@ -1330,7 +1387,6 @@ static int dvb_audio_ioctl(struct inode *inode, struct file *file,  					msp_writereg(av7110, MSP_WR_DSP, 0x0008, 0x0200);  			}  			break; -  		case AUDIO_MONO_RIGHT:  			ret = audcom(av7110, AUDIO_CMD_MONO_R);  			if (!ret) { @@ -1340,7 +1396,6 @@ static int dvb_audio_ioctl(struct inode *inode, struct file *file,  					msp_writereg(av7110, MSP_WR_DSP, 0x0008, 0x0210);  			}  			break; -  		default:  			ret = -EINVAL;  			break; @@ -1366,21 +1421,24 @@ static int dvb_audio_ioctl(struct inode *inode, struct file *file,  			ret = av7110_fw_cmd(av7110, COMTYPE_REC_PLAY,  					    __Play, 2, AV_PES, 0);  		break; -	case AUDIO_SET_ID: +	case AUDIO_SET_ID:  		break; +  	case AUDIO_SET_MIXER:  	{  		struct audio_mixer *amix = (struct audio_mixer *)parg; -  		ret = av7110_set_volume(av7110, amix->volume_left, amix->volume_right);  		break;  	} +  	case AUDIO_SET_STREAMTYPE:  		break; +  	default:  		ret = -ENOIOCTLCMD;  	} +  	return ret;  } diff --git a/linux/drivers/media/dvb/ttpci/av7110_v4l.c b/linux/drivers/media/dvb/ttpci/av7110_v4l.c index 2210cff73..ce64c6214 100644 --- a/linux/drivers/media/dvb/ttpci/av7110_v4l.c +++ b/linux/drivers/media/dvb/ttpci/av7110_v4l.c @@ -458,7 +458,7 @@ static int vidioc_enum_input(struct file *file, void *fh, struct v4l2_input *i)  	dprintk(2, "VIDIOC_ENUMINPUT: %d\n", i->index);  	if (av7110->analog_tuner_flags) { -		if (i->index < 0 || i->index >= 4) +		if (i->index >= 4)  			return -EINVAL;  	} else {  		if (i->index != 0) diff --git a/linux/drivers/media/dvb/ttpci/budget-av.c b/linux/drivers/media/dvb/ttpci/budget-av.c index 855fe74b6..8ea915227 100644 --- a/linux/drivers/media/dvb/ttpci/budget-av.c +++ b/linux/drivers/media/dvb/ttpci/budget-av.c @@ -1413,7 +1413,7 @@ static struct v4l2_input knc1_inputs[KNC1_INPUTS] = {  static int vidioc_enum_input(struct file *file, void *fh, struct v4l2_input *i)  {  	dprintk(1, "VIDIOC_ENUMINPUT %d.\n", i->index); -	if (i->index < 0 || i->index >= KNC1_INPUTS) +	if (i->index >= KNC1_INPUTS)  		return -EINVAL;  	memcpy(i, &knc1_inputs[i->index], sizeof(struct v4l2_input));  	return 0; | 
