summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Boettcher <devnull@localhost>2005-04-29 10:44:48 +0000
committerPatrick Boettcher <devnull@localhost>2005-04-29 10:44:48 +0000
commite86aed48d36edbea2385cab090e464064c5620d5 (patch)
tree85f5a5c2b35c173d653954f20e97499f9f3c92c4
parent4335870fc9921e4c690eff9df3be152aa2e3e606 (diff)
downloadmediapointer-dvb-s2-e86aed48d36edbea2385cab090e464064c5620d5.tar.gz
mediapointer-dvb-s2-e86aed48d36edbea2385cab090e464064c5620d5.tar.bz2
added key-mapping for the a800 (Thanks to Glen Harris)
changed remote-control-key-types and functions (saved about 80 lines code)
-rw-r--r--linux/drivers/media/dvb/dvb-usb/a800.c51
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dibusb-common.c16
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dibusb-mb.c9
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dibusb-mc.c3
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dibusb.h2
-rw-r--r--linux/drivers/media/dvb/dvb-usb/digitv.c15
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dtt200u.c19
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dvb-usb-remote.c14
-rw-r--r--linux/drivers/media/dvb/dvb-usb/dvb-usb.h15
-rw-r--r--linux/drivers/media/dvb/dvb-usb/nova-t-usb2.c119
-rw-r--r--linux/drivers/media/dvb/dvb-usb/umt-010.c6
-rw-r--r--linux/drivers/media/dvb/dvb-usb/vp7045.c30
12 files changed, 130 insertions, 169 deletions
diff --git a/linux/drivers/media/dvb/dvb-usb/a800.c b/linux/drivers/media/dvb/dvb-usb/a800.c
index cc3f9dd9e..4c9a62320 100644
--- a/linux/drivers/media/dvb/dvb-usb/a800.c
+++ b/linux/drivers/media/dvb/dvb-usb/a800.c
@@ -25,18 +25,43 @@ static int a800_power_ctrl(struct dvb_usb_device *d, int onoff)
return 0;
}
-static struct dvb_usb_nec_rc_key a800_rc_keys[] = {
- { 0x00, 0x16, KEY_POWER }, /* dummy key */
+static struct dvb_usb_rc_key a800_rc_keys[] = {
+ { 0x02, 0x01, KEY_PROG1 }, /* SOURCE */
+ { 0x02, 0x00, KEY_POWER }, /* POWER */
+ { 0x02, 0x05, KEY_1 }, /* 1 */
+ { 0x02, 0x06, KEY_2 }, /* 2 */
+ { 0x02, 0x07, KEY_3 }, /* 3 */
+ { 0x02, 0x09, KEY_4 }, /* 4 */
+ { 0x02, 0x0a, KEY_5 }, /* 5 */
+ { 0x02, 0x0b, KEY_6 }, /* 6 */
+ { 0x02, 0x0d, KEY_7 }, /* 7 */
+ { 0x02, 0x0e, KEY_8 }, /* 8 */
+ { 0x02, 0x0f, KEY_9 }, /* 9 */
+ { 0x02, 0x12, KEY_LEFT }, /* L / DISPLAY */
+ { 0x02, 0x11, KEY_0 }, /* 0 */
+ { 0x02, 0x13, KEY_RIGHT }, /* R / CH RTN */
+ { 0x02, 0x17, KEY_PROG2 }, /* SNAP SHOT */
+ { 0x02, 0x10, KEY_PROG3 }, /* 16-CH PREV */
+ { 0x02, 0x03, KEY_CHANNELUP }, /* CH UP */
+ { 0x02, 0x1e, KEY_VOLUMEDOWN }, /* VOL DOWN */
+ { 0x02, 0x0c, KEY_ZOOM }, /* FULL SCREEN */
+ { 0x02, 0x1f, KEY_VOLUMEUP }, /* VOL UP */
+ { 0x02, 0x02, KEY_CHANNELDOWN }, /* CH DOWN */
+ { 0x02, 0x14, KEY_MUTE }, /* MUTE */
+ { 0x02, 0x08, KEY_AUDIO }, /* AUDIO */
+ { 0x02, 0x19, KEY_RECORD }, /* RECORD */
+ { 0x02, 0x18, KEY_PLAY }, /* PLAY */
+ { 0x02, 0x1b, KEY_STOP }, /* STOP */
+ { 0x02, 0x1a, KEY_PLAYPAUSE }, /* TIMESHIFT / PAUSE */
+ { 0x02, 0x1d, KEY_BACK }, /* << / RED */
+ { 0x02, 0x1c, KEY_FORWARD }, /* >> / YELLOW */
+ { 0x02, 0x03, KEY_TEXT }, /* TELETEXT */
+ { 0x02, 0x01, KEY_FIRST }, /* |<< / GREEN */
+ { 0x02, 0x00, KEY_LAST }, /* >>| / BLUE */
+ { 0x02, 0x04, KEY_EPG }, /* EPG */
+ { 0x02, 0x15, KEY_MENU }, /* MENU */
};
-int a800_rc_init(struct dvb_usb_device *d)
-{
- int i;
- for (i = 0; i < sizeof(a800_rc_keys)/sizeof(struct dvb_usb_nec_rc_key); i++)
- set_bit(a800_rc_keys[i].event, d->rc_input_dev.keybit);
- return 0;
-}
-
/*1. Make a vendor request with the following parameters:
* Request = 0x04
* Index = 0;
@@ -57,8 +82,7 @@ int a800_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
return -ENODEV;
/* call the universal NEC remote processor, to find out the key's state and event */
- dvb_usb_nec_rc_key_to_event(d,a800_rc_keys,sizeof(a800_rc_keys)/sizeof(struct dvb_usb_nec_rc_key),
- key,event,state);
+ dvb_usb_nec_rc_key_to_event(d,key,event,state);
if (key[0] != 0)
deb_rc("key: %x %x %x %x %x\n",key[0],key[1],key[2],key[3],key[4]);
return 0;
@@ -97,10 +121,9 @@ static struct dvb_usb_properties a800_properties = {
.power_ctrl = a800_power_ctrl,
.frontend_attach = dibusb_dib3000mc_frontend_attach,
.tuner_attach = dibusb_dib3000mc_tuner_attach,
- .read_mac_address = NULL,
.rc_interval = DEFAULT_RC_INTERVAL,
- .init_rc = a800_rc_init,
+ .rc_key_map = a800_rc_keys,
.query_rc = a800_rc_query,
.i2c_algo = &dibusb_i2c_algo,
diff --git a/linux/drivers/media/dvb/dvb-usb/dibusb-common.c b/linux/drivers/media/dvb/dvb-usb/dibusb-common.c
index 11f9128e8..d98e694bc 100644
--- a/linux/drivers/media/dvb/dvb-usb/dibusb-common.c
+++ b/linux/drivers/media/dvb/dvb-usb/dibusb-common.c
@@ -236,7 +236,7 @@ EXPORT_SYMBOL(dibusb_dib3000mc_tuner_attach);
/*
* common remote control stuff
*/
-static struct dvb_usb_nec_rc_key dibusb_rc_keys[] = {
+struct dvb_usb_rc_key dibusb_rc_keys[] = {
/* Key codes for the little Artec T1/Twinhan/HAMA/ remote. */
{ 0x00, 0x16, KEY_POWER },
{ 0x00, 0x10, KEY_MUTE },
@@ -304,23 +304,13 @@ static struct dvb_usb_nec_rc_key dibusb_rc_keys[] = {
{ 0x86, 0x1f, KEY_LEFT },
{ 0x86, 0x1b, KEY_RIGHT },
};
-
-
-int dibusb_rc_init(struct dvb_usb_device *d)
-{
- int i;
- for (i = 0; i < sizeof(dibusb_rc_keys)/sizeof(struct dvb_usb_nec_rc_key); i++)
- set_bit(dibusb_rc_keys[i].event, d->rc_input_dev.keybit);
- return 0;
-}
-EXPORT_SYMBOL(dibusb_rc_init);
+EXPORT_SYMBOL(dibusb_rc_keys);
int dibusb_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
{
u8 key[5],cmd = DIBUSB_REQ_POLL_REMOTE;
dvb_usb_generic_rw(d,&cmd,1,key,5,0);
- dvb_usb_nec_rc_key_to_event(d,dibusb_rc_keys,sizeof(dibusb_rc_keys)/sizeof(struct dvb_usb_nec_rc_key),
- key,event,state);
+ dvb_usb_nec_rc_key_to_event(d,key,event,state);
if (key[0] != 0)
deb_info("key: %x %x %x %x %x\n",key[0],key[1],key[2],key[3],key[4]);
return 0;
diff --git a/linux/drivers/media/dvb/dvb-usb/dibusb-mb.c b/linux/drivers/media/dvb/dvb-usb/dibusb-mb.c
index 09c5cb687..42da4cb72 100644
--- a/linux/drivers/media/dvb/dvb-usb/dibusb-mb.c
+++ b/linux/drivers/media/dvb/dvb-usb/dibusb-mb.c
@@ -132,10 +132,9 @@ static struct dvb_usb_properties dibusb1_1_properties = {
.power_ctrl = dibusb_power_ctrl,
.frontend_attach = dibusb_dib3000mb_frontend_attach,
.tuner_attach = dibusb_dib3000mb_tuner_attach,
- .read_mac_address = NULL,
.rc_interval = DEFAULT_RC_INTERVAL,
- .init_rc = dibusb_rc_init,
+ .rc_key_map = dibusb_rc_keys,
.query_rc = dibusb_rc_query,
.i2c_algo = &dibusb_i2c_algo,
@@ -204,10 +203,9 @@ static struct dvb_usb_properties dibusb1_1_an2235_properties = {
.power_ctrl = dibusb_power_ctrl,
.frontend_attach = dibusb_dib3000mb_frontend_attach,
.tuner_attach = dibusb_dib3000mb_tuner_attach,
- .read_mac_address = NULL,
.rc_interval = DEFAULT_RC_INTERVAL,
- .init_rc = dibusb_rc_init,
+ .rc_key_map = dibusb_rc_keys,
.query_rc = dibusb_rc_query,
.i2c_algo = &dibusb_i2c_algo,
@@ -248,10 +246,9 @@ static struct dvb_usb_properties dibusb2_0b_properties = {
.power_ctrl = dibusb2_0_power_ctrl,
.frontend_attach = dibusb_dib3000mb_frontend_attach,
.tuner_attach = dibusb_dib3000mb_tuner_attach,
- .read_mac_address = NULL,
.rc_interval = DEFAULT_RC_INTERVAL,
- .init_rc = dibusb_rc_init,
+ .rc_key_map = dibusb_rc_keys,
.query_rc = dibusb_rc_query,
.i2c_algo = &dibusb_i2c_algo,
diff --git a/linux/drivers/media/dvb/dvb-usb/dibusb-mc.c b/linux/drivers/media/dvb/dvb-usb/dibusb-mc.c
index 1754e7f60..e434029f1 100644
--- a/linux/drivers/media/dvb/dvb-usb/dibusb-mc.c
+++ b/linux/drivers/media/dvb/dvb-usb/dibusb-mc.c
@@ -47,10 +47,9 @@ static struct dvb_usb_properties dibusb_mc_properties = {
.power_ctrl = dibusb2_0_power_ctrl,
.frontend_attach = dibusb_dib3000mc_frontend_attach,
.tuner_attach = dibusb_dib3000mc_tuner_attach,
- .read_mac_address = NULL,
.rc_interval = DEFAULT_RC_INTERVAL,
- .init_rc = dibusb_rc_init,
+ .rc_key_map = dibusb_rc_keys,
.query_rc = dibusb_rc_query,
.i2c_algo = &dibusb_i2c_algo,
diff --git a/linux/drivers/media/dvb/dvb-usb/dibusb.h b/linux/drivers/media/dvb/dvb-usb/dibusb.h
index 40a36e2e5..d6871f19f 100644
--- a/linux/drivers/media/dvb/dvb-usb/dibusb.h
+++ b/linux/drivers/media/dvb/dvb-usb/dibusb.h
@@ -123,7 +123,7 @@ extern int dibusb2_0_power_ctrl(struct dvb_usb_device *d, int onoff);
#define DEFAULT_RC_INTERVAL 150
//#define DEFAULT_RC_INTERVAL 100000
-extern int dibusb_rc_init(struct dvb_usb_device *d);
+extern struct dvb_usb_rc_key dibusb_rc_keys[];
extern int dibusb_rc_query(struct dvb_usb_device *d, u32 *event, int *state);
#endif
diff --git a/linux/drivers/media/dvb/dvb-usb/digitv.c b/linux/drivers/media/dvb/dvb-usb/digitv.c
index 649a5cd80..9846ed272 100644
--- a/linux/drivers/media/dvb/dvb-usb/digitv.c
+++ b/linux/drivers/media/dvb/dvb-usb/digitv.c
@@ -163,17 +163,13 @@ static int digitv_frontend_attach(struct dvb_usb_device *d)
return -EIO;
}
-
-static struct dvb_usb_nec_rc_key digitv_rc_keys[] = {
+static struct dvb_usb_rc_key digitv_rc_keys[] = {
{ 0x00, 0x16, KEY_POWER }, /* dummy key */
};
-int digitv_rc_init(struct dvb_usb_device *d)
+static int digitv_rc_init(struct dvb_usb_device *d)
{
- int i;
- u8 b[4];
- for (i = 0; i < sizeof(digitv_rc_keys)/sizeof(struct dvb_usb_nec_rc_key); i++)
- set_bit(digitv_rc_keys[i].event, d->rc_input_dev.keybit);
+ u8 b[4] = { 0 };
b[0] = 1;
digitv_ctrl_msg(d,USB_WRITE_REMOTE_TYPE,0,b,4,NULL,0);
@@ -195,8 +191,7 @@ int digitv_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
key[0] = 0x01; /* if something is inside the buffer, simulate key press */
/* call the universal NEC remote processor, to find out the key's state and event */
- dvb_usb_nec_rc_key_to_event(d,digitv_rc_keys,sizeof(digitv_rc_keys)/sizeof(struct dvb_usb_nec_rc_key),
- key,event,state);
+ dvb_usb_nec_rc_key_to_event(d,key,event,state);
if (key[0] != 0)
deb_rc("key: %x %x %x %x %x\n",key[0],key[1],key[2],key[3],key[4]);
return 0;
@@ -235,7 +230,7 @@ static struct dvb_usb_properties digitv_properties = {
.read_mac_address = NULL,
.rc_interval = 1000,
- .init_rc = digitv_rc_init,
+ .rc_key_map = digitv_rc_keys,
.query_rc = digitv_rc_query,
.identify_state = digitv_identify_state,
diff --git a/linux/drivers/media/dvb/dvb-usb/dtt200u.c b/linux/drivers/media/dvb/dvb-usb/dtt200u.c
index 5fcde0538..75bd054d2 100644
--- a/linux/drivers/media/dvb/dvb-usb/dtt200u.c
+++ b/linux/drivers/media/dvb/dvb-usb/dtt200u.c
@@ -43,7 +43,7 @@ static int dtt200u_pid_filter(struct dvb_usb_device *d, int index, u16 pid, int
/* remote control */
/* key list for the tiny remote control (Yakumo, don't know about the others) */
-static struct dvb_usb_nec_rc_key dtt200u_rc_keys[] = {
+static struct dvb_usb_rc_key dtt200u_rc_keys[] = {
{ 0x80, 0x01, KEY_MUTE },
{ 0x80, 0x02, KEY_CHANNELDOWN },
{ 0x80, 0x03, KEY_VOLUMEDOWN },
@@ -64,20 +64,11 @@ static struct dvb_usb_nec_rc_key dtt200u_rc_keys[] = {
{ 0x80, 0x1f, KEY_9 },
};
-static int dtt200u_rc_init(struct dvb_usb_device *d)
-{
- int i;
- for (i = 0; i < sizeof(dtt200u_rc_keys)/sizeof(struct dvb_usb_nec_rc_key); i++)
- set_bit(dtt200u_rc_keys[i].event, d->rc_input_dev.keybit);
- return 0;
-}
-
static int dtt200u_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
{
u8 key[5],cmd = GET_RC_KEY;
dvb_usb_generic_rw(d,&cmd,1,key,5,0);
- dvb_usb_nec_rc_key_to_event(d,dtt200u_rc_keys,sizeof(dtt200u_rc_keys)/sizeof(struct dvb_usb_nec_rc_key),
- key,event,state);
+ dvb_usb_nec_rc_key_to_event(d,key,event,state);
if (key[0] != 0)
deb_info("key: %x %x %x %x %x\n",key[0],key[1],key[2],key[3],key[4]);
return 0;
@@ -113,13 +104,11 @@ static struct dvb_usb_properties dtt200u_properties = {
.streaming_ctrl = dtt200u_streaming_ctrl,
.pid_filter = dtt200u_pid_filter,
- .pid_filter_ctrl = NULL,
- .power_ctrl = NULL,
.frontend_attach = dtt200u_frontend_attach,
.rc_interval = 200,
+ .rc_key_map = dtt200u_rc_keys,
.query_rc = dtt200u_rc_query,
- .init_rc = dtt200u_rc_init,
.generic_bulk_ctrl_endpoint = 0x01,
@@ -177,5 +166,5 @@ module_exit(dtt200u_usb_module_exit);
MODULE_AUTHOR("Patrick Boettcher <patrick.boettcher@desy.de>");
MODULE_DESCRIPTION("Driver for the Yakumo/Hama/Typhoon DVB-T USB2.0 device");
-MODULE_VERSION("0.2");
+MODULE_VERSION("1.0");
MODULE_LICENSE("GPL");
diff --git a/linux/drivers/media/dvb/dvb-usb/dvb-usb-remote.c b/linux/drivers/media/dvb/dvb-usb/dvb-usb-remote.c
index e1db0352e..b3c65224f 100644
--- a/linux/drivers/media/dvb/dvb-usb/dvb-usb-remote.c
+++ b/linux/drivers/media/dvb/dvb-usb/dvb-usb-remote.c
@@ -82,7 +82,8 @@ schedule:
int dvb_usb_remote_init(struct dvb_usb_device *d)
{
- if (d->props.query_rc == NULL)
+ int i;
+ if (d->props.rc_key_map == NULL)
return 0;
/* Initialise the remote-control structures.*/
@@ -94,7 +95,8 @@ int dvb_usb_remote_init(struct dvb_usb_device *d)
d->rc_input_dev.name = "Remote control inside an USB DVB receiver";
/* set the bits for the keys */
- d->props.init_rc(d);
+ for (i = 0; i < sizeof(d->props.rc_key_map)/sizeof(struct dvb_usb_rc_key); i++)
+ set_bit(d->props.rc_key_map[i].event, d->rc_input_dev.keybit);
/* Start the remote-control polling. */
if (d->props.rc_interval < 40)
@@ -130,11 +132,11 @@ int dvb_usb_remote_exit(struct dvb_usb_device *d)
#define DVB_USB_RC_NEC_EMPTY 0x00
#define DVB_USB_RC_NEC_KEY_PRESSED 0x01
#define DVB_USB_RC_NEC_KEY_REPEATED 0x02
-int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d, struct
- dvb_usb_nec_rc_key keymap[],int key_count, u8 keybuf[5], u32 *event,
- int *state)
+int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d,
+ u8 keybuf[5], u32 *event, int *state)
{
int i;
+ struct dvb_usb_rc_key *keymap = d->props.rc_key_map;
*event = 0;
*state = REMOTE_NO_KEY_PRESSED;
switch (keybuf[0]) {
@@ -147,7 +149,7 @@ int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d, struct
break;
}
/* See if we can match the raw key code. */
- for (i = 0; i < key_count; i++)
+ for (i = 0; i < sizeof(keymap)/sizeof(struct dvb_usb_rc_key); i++)
if (keymap[i].custom == keybuf[1] &&
keymap[i].data == keybuf[3]) {
*event = keymap[i].event;
diff --git a/linux/drivers/media/dvb/dvb-usb/dvb-usb.h b/linux/drivers/media/dvb/dvb-usb/dvb-usb.h
index e5ae34fe5..ae779b659 100644
--- a/linux/drivers/media/dvb/dvb-usb/dvb-usb.h
+++ b/linux/drivers/media/dvb/dvb-usb/dvb-usb.h
@@ -58,6 +58,11 @@ struct dvb_usb_device_description {
struct usb_device_id *warm_ids[DVB_USB_ID_MAX_NUM]; /* list of USB ids when this device is at post firmware state */
};
+struct dvb_usb_rc_key {
+ u8 custom,data;
+ u32 event;
+};
+
struct dvb_usb_device;
/* properties of an dvb-usb-device */
@@ -93,10 +98,11 @@ struct dvb_usb_properties {
/* if the state (cold or warm) is not distinguishable by the USB IDs,
* the dvb-usb-device has to provie this callback to determine it*/
+/* remote control properties */
#define REMOTE_NO_KEY_PRESSED 0x00
#define REMOTE_KEY_PRESSED 0x01
#define REMOTE_KEY_REPEAT 0x02
- int (*init_rc) (struct dvb_usb_device *); /* remote query callback - NULL no ir-receiver */
+ struct dvb_usb_rc_key *rc_key_map;
int (*query_rc) (struct dvb_usb_device *, u32 *, int *); /* remote query callback - NULL no ir-receiver */
int rc_interval;
@@ -190,11 +196,6 @@ extern int dvb_usb_generic_rw(struct dvb_usb_device *, u8 *, u16, u8 *, u16,int)
extern int dvb_usb_generic_write(struct dvb_usb_device *, u8 *, u16);
/* common used remote control parsing */
-struct dvb_usb_nec_rc_key {
- u8 custom,data;
- u32 event;
-};
-
-extern int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *, struct dvb_usb_nec_rc_key[],int, u8[], u32 *, int *);
+extern int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *, u8[], u32 *, int *);
#endif
diff --git a/linux/drivers/media/dvb/dvb-usb/nova-t-usb2.c b/linux/drivers/media/dvb/dvb-usb/nova-t-usb2.c
index d51dfaf5e..86f697495 100644
--- a/linux/drivers/media/dvb/dvb-usb/nova-t-usb2.c
+++ b/linux/drivers/media/dvb/dvb-usb/nova-t-usb2.c
@@ -18,68 +18,60 @@ MODULE_PARM_DESC(debug, "set debugging level (1=rc (|-able))." DVB_USB_DEBUG_STA
#define deb_rc(args...) dprintk(debug,0x01,args)
/* Hauppauge NOVA-T USB2 keys */
-static const struct { u8 raw; uint32_t key; } haupp_rc_keys [] = {
- { 0x00, KEY_0 },
- { 0x01, KEY_1 },
- { 0x02, KEY_2 },
- { 0x03, KEY_3 },
- { 0x04, KEY_4 },
- { 0x05, KEY_5 },
- { 0x06, KEY_6 },
- { 0x07, KEY_7 },
- { 0x08, KEY_8 },
- { 0x09, KEY_9 },
- { 0x0a, KEY_KPASTERISK },
- { 0x0b, KEY_RED },
- { 0x0c, KEY_RADIO },
- { 0x0d, KEY_MENU },
- { 0x0e, KEY_GRAVE }, /* # */
- { 0x0f, KEY_MUTE },
- { 0x10, KEY_VOLUMEUP },
- { 0x11, KEY_VOLUMEDOWN },
- { 0x12, KEY_CHANNEL },
- { 0x14, KEY_UP },
- { 0x15, KEY_DOWN },
- { 0x16, KEY_LEFT },
- { 0x17, KEY_RIGHT },
- { 0x18, KEY_VIDEO },
- { 0x19, KEY_AUDIO },
- { 0x1a, KEY_MEDIA },
- { 0x1b, KEY_EPG },
- { 0x1c, KEY_TV },
- { 0x1e, KEY_NEXT },
- { 0x1f, KEY_BACK },
- { 0x20, KEY_CHANNELUP },
- { 0x21, KEY_CHANNELDOWN },
- { 0x24, KEY_LAST }, /* Skip backwards */
- { 0x25, KEY_OK },
- { 0x29, KEY_BLUE},
- { 0x2e, KEY_GREEN },
- { 0x30, KEY_PAUSE },
- { 0x32, KEY_REWIND },
- { 0x34, KEY_FASTFORWARD },
- { 0x35, KEY_PLAY },
- { 0x36, KEY_STOP },
- { 0x37, KEY_RECORD },
- { 0x38, KEY_YELLOW },
- { 0x3b, KEY_GOTO },
- { 0x3d, KEY_POWER },
+static struct dvb_usb_rc_key haupp_rc_keys [] = {
+ { 0x1e, 0x00, KEY_0 },
+ { 0x1e, 0x01, KEY_1 },
+ { 0x1e, 0x02, KEY_2 },
+ { 0x1e, 0x03, KEY_3 },
+ { 0x1e, 0x04, KEY_4 },
+ { 0x1e, 0x05, KEY_5 },
+ { 0x1e, 0x06, KEY_6 },
+ { 0x1e, 0x07, KEY_7 },
+ { 0x1e, 0x08, KEY_8 },
+ { 0x1e, 0x09, KEY_9 },
+ { 0x1e, 0x0a, KEY_KPASTERISK },
+ { 0x1e, 0x0b, KEY_RED },
+ { 0x1e, 0x0c, KEY_RADIO },
+ { 0x1e, 0x0d, KEY_MENU },
+ { 0x1e, 0x0e, KEY_GRAVE }, /* # */
+ { 0x1e, 0x0f, KEY_MUTE },
+ { 0x1e, 0x10, KEY_VOLUMEUP },
+ { 0x1e, 0x11, KEY_VOLUMEDOWN },
+ { 0x1e, 0x12, KEY_CHANNEL },
+ { 0x1e, 0x14, KEY_UP },
+ { 0x1e, 0x15, KEY_DOWN },
+ { 0x1e, 0x16, KEY_LEFT },
+ { 0x1e, 0x17, KEY_RIGHT },
+ { 0x1e, 0x18, KEY_VIDEO },
+ { 0x1e, 0x19, KEY_AUDIO },
+ { 0x1e, 0x1a, KEY_MEDIA },
+ { 0x1e, 0x1b, KEY_EPG },
+ { 0x1e, 0x1c, KEY_TV },
+ { 0x1e, 0x1e, KEY_NEXT },
+ { 0x1e, 0x1f, KEY_BACK },
+ { 0x1e, 0x20, KEY_CHANNELUP },
+ { 0x1e, 0x21, KEY_CHANNELDOWN },
+ { 0x1e, 0x24, KEY_LAST }, /* Skip backwards */
+ { 0x1e, 0x25, KEY_OK },
+ { 0x1e, 0x29, KEY_BLUE},
+ { 0x1e, 0x2e, KEY_GREEN },
+ { 0x1e, 0x30, KEY_PAUSE },
+ { 0x1e, 0x32, KEY_REWIND },
+ { 0x1e, 0x34, KEY_FASTFORWARD },
+ { 0x1e, 0x35, KEY_PLAY },
+ { 0x1e, 0x36, KEY_STOP },
+ { 0x1e, 0x37, KEY_RECORD },
+ { 0x1e, 0x38, KEY_YELLOW },
+ { 0x1e, 0x3b, KEY_GOTO },
+ { 0x1e, 0x3d, KEY_POWER },
};
-static int nova_t_rc_init(struct dvb_usb_device *d)
-{
- int i;
- for (i=0; i<sizeof(haupp_rc_keys)/sizeof(haupp_rc_keys[0]); i++)
- set_bit(haupp_rc_keys[i].key, d->rc_input_dev.keybit);
- return 0;
-}
-
/* Firmware bug? sometimes, when a new key is pressed, the previous pressed key
- * is delivered. No workaround yet.
+ * is delivered. No workaround yet, maybe a new firmware.
*/
static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
{
- u8 key[5],cmd[2] = { DIBUSB_REQ_POLL_REMOTE, 0x35 }, data,toggle;
+ u8 key[5],cmd[2] = { DIBUSB_REQ_POLL_REMOTE, 0x35 }, data,toggle,custom;
u16 raw;
int i;
struct dibusb_state *st = d->priv;
@@ -92,17 +84,14 @@ static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
raw = ((key[1] << 8) | key[2]) >> 3;
toggle = !!(raw & 0x800);
data = raw & 0x3f;
+ custom = (raw >> 6) & 0x1f;
deb_rc("raw key code 0x%02x, 0x%02x, 0x%02x to %02x toggle: %d\n",key[1],key[2],key[3],data,toggle);
- if (((raw >> 6) & 0x1f) != 0x1e) {
- deb_rc("key received - but ignored (%x)\n",(raw >> 6) & 0x1f);
- break;
- }
-
for (i = 0; i < sizeof(haupp_rc_keys)/sizeof(haupp_rc_keys[0]); i++) {
- if (haupp_rc_keys[i].raw == data) {
- *event = haupp_rc_keys[i].key;
+ if (haupp_rc_keys[i].data == data &&
+ haupp_rc_keys[i].custom == custom) {
+ *event = haupp_rc_keys[i].event;
*state = REMOTE_KEY_PRESSED;
if (st->old_toggle == toggle) {
if (st->last_repeat_count++ < 2)
@@ -111,7 +100,6 @@ static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
st->last_repeat_count = 0;
st->old_toggle = toggle;
}
-
break;
}
}
@@ -122,7 +110,6 @@ static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
break;
}
-
return 0;
}
@@ -161,7 +148,7 @@ static struct dvb_usb_properties nova_t_properties = {
.read_mac_address = NULL,
.rc_interval = 100,
- .init_rc = nova_t_rc_init,
+ .rc_key_map = haupp_rc_keys,
.query_rc = nova_t_rc_query,
.i2c_algo = &dibusb_i2c_algo,
diff --git a/linux/drivers/media/dvb/dvb-usb/umt-010.c b/linux/drivers/media/dvb/dvb-usb/umt-010.c
index 6fae66eaa..55bd34c29 100644
--- a/linux/drivers/media/dvb/dvb-usb/umt-010.c
+++ b/linux/drivers/media/dvb/dvb-usb/umt-010.c
@@ -100,15 +100,9 @@ static struct dvb_usb_properties umt_properties = {
.size_of_priv = sizeof(struct dibusb_state),
.streaming_ctrl = dibusb2_0_streaming_ctrl,
- .pid_filter = NULL,
- .pid_filter_ctrl = NULL,
.power_ctrl = dibusb_power_ctrl,
.frontend_attach = umt_mt352_frontend_attach,
.tuner_attach = umt_tuner_attach,
- .read_mac_address = NULL,
-
- .init_rc = NULL,
- .query_rc = NULL,
.i2c_algo = &dibusb_i2c_algo,
diff --git a/linux/drivers/media/dvb/dvb-usb/vp7045.c b/linux/drivers/media/dvb/dvb-usb/vp7045.c
index b603f1e43..e385bdbc0 100644
--- a/linux/drivers/media/dvb/dvb-usb/vp7045.c
+++ b/linux/drivers/media/dvb/dvb-usb/vp7045.c
@@ -93,29 +93,16 @@ static int vp7045_power_ctrl(struct dvb_usb_device *d, int onoff)
/* The keymapping struct. Somehow this should be loaded to the driver, but
* currently it is hardcoded. */
-struct {
- u8 raw;
- u32 key;
-} vp7045_rc_key_mapping[] = {
-
+static struct dvb_usb_rc_key vp7045_rc_keys[] = {
/* insert the keys like this. to make the raw keys visible, enable
* debug=0x04 when loading dvb-usb-vp7045. */
/* these keys are probably wrong. I don't have a working IR-receiver on my
* vp7045, so I can't test it. Patches are welcome. */
- { 0x01, KEY_1 },
- { 0x02, KEY_2 },
+ { 0x00, 0x01, KEY_1 },
+ { 0x00, 0x02, KEY_2 },
};
-static int vp7045_rc_init(struct dvb_usb_device *d)
-{
- int i;
- for (i = 0; i < sizeof(vp7045_rc_key_mapping)/sizeof(vp7045_rc_key_mapping[0]); i++)
- set_bit(vp7045_rc_key_mapping[i].key, d->rc_input_dev.keybit);
-
- return 0;
-}
-
static int vp7045_rc_query(struct dvb_usb_device *d, u32 *key_buf, int *state)
{
u8 key;
@@ -129,10 +116,10 @@ static int vp7045_rc_query(struct dvb_usb_device *d, u32 *key_buf, int *state)
return 0;
}
- for (i = 0; i < sizeof(vp7045_rc_key_mapping)/sizeof(vp7045_rc_key_mapping); i++)
- if (vp7045_rc_key_mapping[i].raw == key) {
+ for (i = 0; i < sizeof(vp7045_rc_keys)/sizeof(struct dvb_usb_rc_key); i++)
+ if (vp7045_rc_keys[i].data == key) {
*state = REMOTE_KEY_PRESSED;
- *key_buf = vp7045_rc_key_mapping[i].key;
+ *key_buf = vp7045_rc_keys[i].event;
break;
}
return 0;
@@ -205,15 +192,12 @@ static struct dvb_usb_properties vp7045_properties = {
.usb_ctrl = CYPRESS_FX2,
.firmware = "dvb-usb-vp7045-01.fw",
- .streaming_ctrl = NULL,
- .pid_filter = NULL,
- .pid_filter_ctrl = NULL,
.power_ctrl = vp7045_power_ctrl,
.frontend_attach = vp7045_frontend_attach,
.read_mac_address = vp7045_read_mac_addr,
.rc_interval = 400,
- .init_rc = vp7045_rc_init,
+ .rc_key_map = vp7045_rc_keys,
.query_rc = vp7045_rc_query,
/* parameter for the MPEG2-data transfer */