summaryrefslogtreecommitdiff
path: root/linux
diff options
context:
space:
mode:
Diffstat (limited to 'linux')
-rw-r--r--linux/drivers/media/dvb/cinergyT2/cinergyT2.c123
1 files changed, 79 insertions, 44 deletions
diff --git a/linux/drivers/media/dvb/cinergyT2/cinergyT2.c b/linux/drivers/media/dvb/cinergyT2/cinergyT2.c
index fb567c681..067e7143a 100644
--- a/linux/drivers/media/dvb/cinergyT2/cinergyT2.c
+++ b/linux/drivers/media/dvb/cinergyT2/cinergyT2.c
@@ -29,11 +29,11 @@
#include <linux/usb.h>
#include <linux/pci.h>
#include <linux/input.h>
+#include <linux/dvb/frontend.h>
#include "dmxdev.h"
#include "dvb_demux.h"
#include "dvb_net.h"
-#include "dvb_frontend.h"
#ifdef CONFIG_DVB_CINERGYT2_TUNING
@@ -87,6 +87,7 @@ struct cinergyt2 {
struct usb_device *udev;
struct semaphore sem;
struct dvb_adapter *adapter;
+ struct dvb_device *fedev;
struct dmxdev dmxdev;
struct dvb_net dvbnet;
@@ -95,6 +96,7 @@ struct cinergyt2 {
void *streambuf;
dma_addr_t streambuf_dmahandle;
struct urb *stream_urb [STREAM_URB_COUNT];
+
#ifdef ENABLE_RC
struct input_dev rc_input_dev;
struct work_struct rc_query_work;
@@ -334,7 +336,6 @@ int cinergyt2_start_feed(struct dvb_demux_feed *dvbdmxfeed)
if (cinergyt2->streaming == 0) {
- cinergyt2_control_sleep_mode(cinergyt2, 0);
if (cinergyt2_start_stream_xfer (cinergyt2) == 0)
cinergyt2_control_stream_transfer (cinergyt2, 1);
}
@@ -354,7 +355,6 @@ int cinergyt2_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
if (--cinergyt2->streaming == 0) {
cinergyt2_control_stream_transfer(cinergyt2, 0);
cinergyt2_stop_stream_xfer(cinergyt2);
- cinergyt2_control_sleep_mode(cinergyt2, 1);
}
return 0;
@@ -379,91 +379,91 @@ uint16_t compute_tps (struct dvb_frontend_parameters *param)
switch (op->code_rate_HP) {
case FEC_2_3:
- tps |= (1 << 9);
+ tps |= (1 << 7);
break;
case FEC_3_4:
- tps |= (2 << 9);
+ tps |= (2 << 7);
break;
case FEC_5_6:
- tps |= (3 << 9);
+ tps |= (3 << 7);
break;
case FEC_7_8:
- tps |= (4 << 9);
+ tps |= (4 << 7);
break;
case FEC_1_2:
case FEC_AUTO:
default:
- /* tps |= (0 << 9) */;
+ /* tps |= (0 << 7) */;
}
switch (op->code_rate_LP) {
case FEC_2_3:
- tps |= (1 << 6);
+ tps |= (1 << 4);
break;
case FEC_3_4:
- tps |= (2 << 6);
+ tps |= (2 << 4);
break;
case FEC_5_6:
- tps |= (3 << 6);
+ tps |= (3 << 4);
break;
case FEC_7_8:
- tps |= (4 << 6);
+ tps |= (4 << 4);
break;
case FEC_1_2:
case FEC_AUTO:
default:
- /* tps |= (0 << 6) */;
+ /* tps |= (0 << 4) */;
}
switch (op->constellation) {
case QAM_16:
- tps |= (1 << 14);
+ tps |= (1 << 13);
break;
case QAM_64:
- tps |= (2 << 14);
+ tps |= (2 << 13);
break;
case QPSK:
default:
- /* tps |= (0 << 14) */;
+ /* tps |= (0 << 13) */;
}
switch (op->transmission_mode) {
case TRANSMISSION_MODE_8K:
- tps |= (1 << 1);
+ tps |= (1 << 0);
break;
case TRANSMISSION_MODE_2K:
default:
- /* tps |= (0 << 1) */;
+ /* tps |= (0 << 0) */;
}
switch (op->guard_interval) {
case GUARD_INTERVAL_1_16:
- tps |= (1 << 3);
+ tps |= (1 << 2);
break;
case GUARD_INTERVAL_1_8:
- tps |= (2 << 3);
+ tps |= (2 << 2);
break;
case GUARD_INTERVAL_1_4:
- tps |= (3 << 3);
+ tps |= (3 << 2);
break;
case GUARD_INTERVAL_1_32:
default:
- /* tps |= (0 << 3) */;
+ /* tps |= (0 << 2) */;
}
switch (op->hierarchy_information) {
case HIERARCHY_1:
- tps |= (1 << 12);
+ tps |= (1 << 10);
break;
case HIERARCHY_2:
- tps |= (2 << 12);
+ tps |= (2 << 10);
break;
case HIERARCHY_4:
- tps |= (3 << 12);
+ tps |= (3 << 10);
break;
case HIERARCHY_NONE:
default:
- /* tps |= (0 << 12) */;
+ /* tps |= (0 << 10) */;
}
return tps;
@@ -495,15 +495,32 @@ struct dvbt_get_parameters_msg {
static
-int cinergyt2_fe_ioctl (struct dvb_frontend *fe, unsigned int ioctl_cmd, void *arg)
+int cinergyt2_fe_open (struct inode *inode, struct file *file)
+{
+ struct dvb_device *dvbdev = file->private_data;
+ cinergyt2_control_sleep_mode((struct cinergyt2 *) dvbdev->priv, 0);
+ return dvb_generic_open(inode, file);
+}
+
+
+static
+int cinergyt2_fe_release (struct inode *inode, struct file *file)
{
- struct cinergyt2 *cinergyt2 = fe->data;
+ struct dvb_device *dvbdev = file->private_data;
+ cinergyt2_control_sleep_mode((struct cinergyt2 *) dvbdev->priv, 1);
+ return dvb_generic_release (inode, file);
+}
+
+
+static
+int cinergyt2_fe_ioctl (struct inode *inode, struct file *file,
+ unsigned int cmd, void *arg)
+{
+ struct dvb_device *dvbdev = file->private_data;
+ struct cinergyt2 *cinergyt2 = dvbdev->priv;
int ret = 0;
- if (!cinergyt2->streaming)
- cinergyt2_control_sleep_mode(cinergyt2, 0);
-
- switch (ioctl_cmd) {
+ switch (cmd) {
case FE_GET_INFO:
memcpy (arg, &cinergyt2_fe_info, sizeof(struct dvb_frontend_info));
break;
@@ -608,23 +625,40 @@ int cinergyt2_fe_ioctl (struct dvb_frontend *fe, unsigned int ioctl_cmd, void *a
*/
break;
- case FE_INIT:
- case FE_SLEEP:
- /* no need to do anything */
- break;
-
default:
- ret = -EOPNOTSUPP;
+ ret = -EINVAL;
break;
}
- if (!cinergyt2->streaming)
- cinergyt2_control_sleep_mode(cinergyt2, 1);
-
return ret;
}
+static
+struct file_operations cinergyt2_fe_fops = {
+ .owner = THIS_MODULE,
+ .ioctl = dvb_generic_ioctl,
+ /**
+ * do we really need this? If so, let's implement it via
+ * schedule_delayed_work() similiar to the IR code.
+ */
+ /*.poll = cinergyt2_fe_poll, */
+ .open = cinergyt2_fe_open,
+ .release = cinergyt2_fe_release
+};
+
+
+static
+struct dvb_device cinergyt2_fe_template = {
+ .users = ~0,
+ .writers = 1,
+ .readers = (~0)-1,
+ .fops = &cinergyt2_fe_fops,
+ .kernel_ioctl = cinergyt2_fe_ioctl
+};
+
+
+
#ifdef ENABLE_RC
static
void cinergyt2_query_rc (void *data)
@@ -729,8 +763,9 @@ int cinergyt2_probe (struct usb_interface *intf,
if (dvb_net_init(cinergyt2->adapter, &cinergyt2->dvbnet, &cinergyt2->demux.dmx))
printk("cinergyt2_dvb: dvb_net_init failed!\n");
- dvb_register_frontend(cinergyt2_fe_ioctl, cinergyt2->adapter, cinergyt2,
- &cinergyt2_fe_info, THIS_MODULE);
+ dvb_register_device(cinergyt2->adapter, &cinergyt2->fedev,
+ &cinergyt2_fe_template, cinergyt2,
+ DVB_DEVICE_FRONTEND);
#ifdef ENABLE_RC
init_input_dev(&cinergyt2->rc_input_dev);
@@ -785,7 +820,7 @@ void cinergyt2_disconnect (struct usb_interface *intf)
dvb_dmxdev_release(&cinergyt2->dmxdev);
dvb_dmx_release(&cinergyt2->demux);
- dvb_unregister_frontend(cinergyt2_fe_ioctl, cinergyt2->adapter);
+ dvb_unregister_device(cinergyt2->fedev);
dvb_unregister_adapter(cinergyt2->adapter);
cinergyt2_free_stream_urbs(cinergyt2);