V4L/DVB (12598): dvb-usb: store rc5 custom and data at the same field
authorMauro Carvalho Chehab <mchehab@redhat.com>
Sat, 29 Aug 2009 18:19:31 +0000 (15:19 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Sat, 12 Sep 2009 15:19:48 +0000 (12:19 -0300)
In order to be closer to V4L IR implementation, it is needed to replace
u8 custom, data
to:
u16 scan

This allows using non-rc5 mappings, like the 8 bit keycodes used on older
protocols. It will also allow future implementations of rc6 keystrokes
when needed.

Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
19 files changed:
drivers/media/dvb/dvb-usb/a800.c
drivers/media/dvb/dvb-usb/af9005-remote.c
drivers/media/dvb/dvb-usb/af9015.c
drivers/media/dvb/dvb-usb/af9015.h
drivers/media/dvb/dvb-usb/anysee.c
drivers/media/dvb/dvb-usb/cinergyT2-core.c
drivers/media/dvb/dvb-usb/cxusb.c
drivers/media/dvb/dvb-usb/dib0700_devices.c
drivers/media/dvb/dvb-usb/dibusb-common.c
drivers/media/dvb/dvb-usb/digitv.c
drivers/media/dvb/dvb-usb/dtt200u.c
drivers/media/dvb/dvb-usb/dvb-usb-remote.c
drivers/media/dvb/dvb-usb/dvb-usb.h
drivers/media/dvb/dvb-usb/dw2102.c
drivers/media/dvb/dvb-usb/m920x.c
drivers/media/dvb/dvb-usb/nova-t-usb2.c
drivers/media/dvb/dvb-usb/opera1.c
drivers/media/dvb/dvb-usb/vp702x.c
drivers/media/dvb/dvb-usb/vp7045.c

index dc8c878..6247239 100644 (file)
@@ -38,41 +38,41 @@ static int a800_identify_state(struct usb_device *udev, struct dvb_usb_device_pr
 }
 
 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, 0x1e, KEY_VOLUMEDOWN },  /* VOL DOWN */
-       { 0x02, 0x0c, KEY_ZOOM },        /* FULL SCREEN */
-       { 0x02, 0x1f, KEY_VOLUMEUP },    /* VOL UP */
-       { 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, 0x04, KEY_EPG },         /* EPG */
-       { 0x02, 0x15, KEY_MENU },        /* MENU */
-
-       { 0x03, 0x03, KEY_CHANNELUP },   /* CH UP */
-       { 0x03, 0x02, KEY_CHANNELDOWN }, /* CH DOWN */
-       { 0x03, 0x01, KEY_FIRST },       /* |<< / GREEN */
-       { 0x03, 0x00, KEY_LAST },        /* >>| / BLUE */
+       { 0x0201, KEY_PROG1 },       /* SOURCE */
+       { 0x0200, KEY_POWER },       /* POWER */
+       { 0x0205, KEY_1 },           /* 1 */
+       { 0x0206, KEY_2 },           /* 2 */
+       { 0x0207, KEY_3 },           /* 3 */
+       { 0x0209, KEY_4 },           /* 4 */
+       { 0x020a, KEY_5 },           /* 5 */
+       { 0x020b, KEY_6 },           /* 6 */
+       { 0x020d, KEY_7 },           /* 7 */
+       { 0x020e, KEY_8 },           /* 8 */
+       { 0x020f, KEY_9 },           /* 9 */
+       { 0x0212, KEY_LEFT },        /* L / DISPLAY */
+       { 0x0211, KEY_0 },           /* 0 */
+       { 0x0213, KEY_RIGHT },       /* R / CH RTN */
+       { 0x0217, KEY_PROG2 },       /* SNAP SHOT */
+       { 0x0210, KEY_PROG3 },       /* 16-CH PREV */
+       { 0x021e, KEY_VOLUMEDOWN },  /* VOL DOWN */
+       { 0x020c, KEY_ZOOM },        /* FULL SCREEN */
+       { 0x021f, KEY_VOLUMEUP },    /* VOL UP */
+       { 0x0214, KEY_MUTE },        /* MUTE */
+       { 0x0208, KEY_AUDIO },       /* AUDIO */
+       { 0x0219, KEY_RECORD },      /* RECORD */
+       { 0x0218, KEY_PLAY },        /* PLAY */
+       { 0x021b, KEY_STOP },        /* STOP */
+       { 0x021a, KEY_PLAYPAUSE },   /* TIMESHIFT / PAUSE */
+       { 0x021d, KEY_BACK },        /* << / RED */
+       { 0x021c, KEY_FORWARD },     /* >> / YELLOW */
+       { 0x0203, KEY_TEXT },        /* TELETEXT */
+       { 0x0204, KEY_EPG },         /* EPG */
+       { 0x0215, KEY_MENU },        /* MENU */
+
+       { 0x0303, KEY_CHANNELUP },   /* CH UP */
+       { 0x0302, KEY_CHANNELDOWN }, /* CH DOWN */
+       { 0x0301, KEY_FIRST },       /* |<< / GREEN */
+       { 0x0300, KEY_LAST },        /* >>| / BLUE */
 
 };
 
index 7c596f9..f4379c6 100644 (file)
@@ -35,43 +35,43 @@ MODULE_PARM_DESC(debug,
 
 struct dvb_usb_rc_key af9005_rc_keys[] = {
 
-       {0x01, 0xb7, KEY_POWER},
-       {0x01, 0xa7, KEY_VOLUMEUP},
-       {0x01, 0x87, KEY_CHANNELUP},
-       {0x01, 0x7f, KEY_MUTE},
-       {0x01, 0xbf, KEY_VOLUMEDOWN},
-       {0x01, 0x3f, KEY_CHANNELDOWN},
-       {0x01, 0xdf, KEY_1},
-       {0x01, 0x5f, KEY_2},
-       {0x01, 0x9f, KEY_3},
-       {0x01, 0x1f, KEY_4},
-       {0x01, 0xef, KEY_5},
-       {0x01, 0x6f, KEY_6},
-       {0x01, 0xaf, KEY_7},
-       {0x01, 0x27, KEY_8},
-       {0x01, 0x07, KEY_9},
-       {0x01, 0xcf, KEY_ZOOM},
-       {0x01, 0x4f, KEY_0},
-       {0x01, 0x8f, KEY_GOTO}, /* marked jump on the remote */
+       {0x01b7, KEY_POWER},
+       {0x01a7, KEY_VOLUMEUP},
+       {0x0187, KEY_CHANNELUP},
+       {0x017f, KEY_MUTE},
+       {0x01bf, KEY_VOLUMEDOWN},
+       {0x013f, KEY_CHANNELDOWN},
+       {0x01df, KEY_1},
+       {0x015f, KEY_2},
+       {0x019f, KEY_3},
+       {0x011f, KEY_4},
+       {0x01ef, KEY_5},
+       {0x016f, KEY_6},
+       {0x01af, KEY_7},
+       {0x0127, KEY_8},
+       {0x0107, KEY_9},
+       {0x01cf, KEY_ZOOM},
+       {0x014f, KEY_0},
+       {0x018f, KEY_GOTO},     /* marked jump on the remote */
 
-       {0x00, 0xbd, KEY_POWER},
-       {0x00, 0x7d, KEY_VOLUMEUP},
-       {0x00, 0xfd, KEY_CHANNELUP},
-       {0x00, 0x9d, KEY_MUTE},
-       {0x00, 0x5d, KEY_VOLUMEDOWN},
-       {0x00, 0xdd, KEY_CHANNELDOWN},
-       {0x00, 0xad, KEY_1},
-       {0x00, 0x6d, KEY_2},
-       {0x00, 0xed, KEY_3},
-       {0x00, 0x8d, KEY_4},
-       {0x00, 0x4d, KEY_5},
-       {0x00, 0xcd, KEY_6},
-       {0x00, 0xb5, KEY_7},
-       {0x00, 0x75, KEY_8},
-       {0x00, 0xf5, KEY_9},
-       {0x00, 0x95, KEY_ZOOM},
-       {0x00, 0x55, KEY_0},
-       {0x00, 0xd5, KEY_GOTO}, /* marked jump on the remote */
+       {0x00bd, KEY_POWER},
+       {0x007d, KEY_VOLUMEUP},
+       {0x00fd, KEY_CHANNELUP},
+       {0x009d, KEY_MUTE},
+       {0x005d, KEY_VOLUMEDOWN},
+       {0x00dd, KEY_CHANNELDOWN},
+       {0x00ad, KEY_1},
+       {0x006d, KEY_2},
+       {0x00ed, KEY_3},
+       {0x008d, KEY_4},
+       {0x004d, KEY_5},
+       {0x00cd, KEY_6},
+       {0x00b5, KEY_7},
+       {0x0075, KEY_8},
+       {0x00f5, KEY_9},
+       {0x0095, KEY_ZOOM},
+       {0x0055, KEY_0},
+       {0x00d5, KEY_GOTO},     /* marked jump on the remote */
 };
 
 int af9005_rc_keys_size = ARRAY_SIZE(af9005_rc_keys);
@@ -131,8 +131,8 @@ int af9005_rc_decode(struct dvb_usb_device *d, u8 * data, int len, u32 * event,
                                return 0;
                        }
                        for (i = 0; i < af9005_rc_keys_size; i++) {
-                               if (af9005_rc_keys[i].custom == cust
-                                   && af9005_rc_keys[i].data == dat) {
+                               if (rc5_custom(&af9005_rc_keys[i]) == cust
+                                   && rc5_data(&af9005_rc_keys[i]) == dat) {
                                        *event = af9005_rc_keys[i].event;
                                        *state = REMOTE_KEY_PRESSED;
                                        deb_decode
index 7e571ad..99cdd0d 100644 (file)
@@ -1043,8 +1043,8 @@ static int af9015_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        *state = REMOTE_NO_KEY_PRESSED;
 
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (!buf[1] && keymap[i].custom == buf[0] &&
-                   keymap[i].data == buf[2]) {
+               if (!buf[1] && rc5_custom(&keymap[i]) == buf[0] &&
+                   rc5_data(&keymap[i]) == buf[2]) {
                        *event = keymap[i].event;
                        *state = REMOTE_KEY_PRESSED;
                        break;
index 8d81a17..c41f30e 100644 (file)
@@ -121,21 +121,21 @@ enum af9015_remote {
 
 /* Leadtek WinFast DTV Dongle Gold */
 static struct dvb_usb_rc_key af9015_rc_keys_leadtek[] = {
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x00, 0x27, KEY_0 },
-       { 0x00, 0x28, KEY_ENTER },
-       { 0x00, 0x4f, KEY_VOLUMEUP },
-       { 0x00, 0x50, KEY_VOLUMEDOWN },
-       { 0x00, 0x51, KEY_CHANNELDOWN },
-       { 0x00, 0x52, KEY_CHANNELUP },
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0027, KEY_0 },
+       { 0x0028, KEY_ENTER },
+       { 0x004f, KEY_VOLUMEUP },
+       { 0x0050, KEY_VOLUMEDOWN },
+       { 0x0051, KEY_CHANNELDOWN },
+       { 0x0052, KEY_CHANNELUP },
 };
 
 static u8 af9015_ir_table_leadtek[] = {
@@ -193,60 +193,60 @@ static u8 af9015_ir_table_leadtek[] = {
 
 /* TwinHan AzureWave AD-TU700(704J) */
 static struct dvb_usb_rc_key af9015_rc_keys_twinhan[] = {
-       { 0x05, 0x3f, KEY_POWER },
-       { 0x00, 0x19, KEY_FAVORITES },    /* Favorite List */
-       { 0x00, 0x04, KEY_TEXT },         /* Teletext */
-       { 0x00, 0x0e, KEY_POWER },
-       { 0x00, 0x0e, KEY_INFO },         /* Preview */
-       { 0x00, 0x08, KEY_EPG },          /* Info/EPG */
-       { 0x00, 0x0f, KEY_LIST },         /* Record List */
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x00, 0x27, KEY_0 },
-       { 0x00, 0x29, KEY_CANCEL },       /* Cancel */
-       { 0x00, 0x4c, KEY_CLEAR },        /* Clear */
-       { 0x00, 0x2a, KEY_BACK },         /* Back */
-       { 0x00, 0x2b, KEY_TAB },          /* Tab */
-       { 0x00, 0x52, KEY_UP },           /* up arrow */
-       { 0x00, 0x51, KEY_DOWN },         /* down arrow */
-       { 0x00, 0x4f, KEY_RIGHT },        /* right arrow */
-       { 0x00, 0x50, KEY_LEFT },         /* left arrow */
-       { 0x00, 0x28, KEY_ENTER },        /* Enter / ok */
-       { 0x02, 0x52, KEY_VOLUMEUP },
-       { 0x02, 0x51, KEY_VOLUMEDOWN },
-       { 0x00, 0x4e, KEY_CHANNELDOWN },
-       { 0x00, 0x4b, KEY_CHANNELUP },
-       { 0x00, 0x4a, KEY_RECORD },
-       { 0x01, 0x11, KEY_PLAY },
-       { 0x00, 0x17, KEY_PAUSE },
-       { 0x00, 0x0c, KEY_REWIND },       /* FR << */
-       { 0x00, 0x11, KEY_FASTFORWARD },  /* FF >> */
-       { 0x01, 0x15, KEY_PREVIOUS },     /* Replay */
-       { 0x01, 0x0e, KEY_NEXT },         /* Skip */
-       { 0x00, 0x13, KEY_CAMERA },       /* Capture */
-       { 0x01, 0x0f, KEY_LANGUAGE },     /* SAP */
-       { 0x01, 0x13, KEY_TV2 },          /* PIP */
-       { 0x00, 0x1d, KEY_ZOOM },         /* Full Screen */
-       { 0x01, 0x17, KEY_SUBTITLE },     /* Subtitle / CC */
-       { 0x00, 0x10, KEY_MUTE },
-       { 0x01, 0x19, KEY_AUDIO },        /* L/R */ /* TODO better event */
-       { 0x01, 0x16, KEY_SLEEP },        /* Hibernate */
-       { 0x01, 0x16, KEY_SWITCHVIDEOMODE },
+       { 0x053f, KEY_POWER },
+       { 0x0019, KEY_FAVORITES },    /* Favorite List */
+       { 0x0004, KEY_TEXT },         /* Teletext */
+       { 0x000e, KEY_POWER },
+       { 0x000e, KEY_INFO },         /* Preview */
+       { 0x0008, KEY_EPG },          /* Info/EPG */
+       { 0x000f, KEY_LIST },         /* Record List */
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0027, KEY_0 },
+       { 0x0029, KEY_CANCEL },       /* Cancel */
+       { 0x004c, KEY_CLEAR },        /* Clear */
+       { 0x002a, KEY_BACK },         /* Back */
+       { 0x002b, KEY_TAB },          /* Tab */
+       { 0x0052, KEY_UP },           /* up arrow */
+       { 0x0051, KEY_DOWN },         /* down arrow */
+       { 0x004f, KEY_RIGHT },        /* right arrow */
+       { 0x0050, KEY_LEFT },         /* left arrow */
+       { 0x0028, KEY_ENTER },        /* Enter / ok */
+       { 0x0252, KEY_VOLUMEUP },
+       { 0x0251, KEY_VOLUMEDOWN },
+       { 0x004e, KEY_CHANNELDOWN },
+       { 0x004b, KEY_CHANNELUP },
+       { 0x004a, KEY_RECORD },
+       { 0x0111, KEY_PLAY },
+       { 0x0017, KEY_PAUSE },
+       { 0x000c, KEY_REWIND },       /* FR << */
+       { 0x0011, KEY_FASTFORWARD },  /* FF >> */
+       { 0x0115, KEY_PREVIOUS },     /* Replay */
+       { 0x010e, KEY_NEXT },         /* Skip */
+       { 0x0013, KEY_CAMERA },       /* Capture */
+       { 0x010f, KEY_LANGUAGE },     /* SAP */
+       { 0x0113, KEY_TV2 },          /* PIP */
+       { 0x001d, KEY_ZOOM },         /* Full Screen */
+       { 0x0117, KEY_SUBTITLE },     /* Subtitle / CC */
+       { 0x0010, KEY_MUTE },
+       { 0x0119, KEY_AUDIO },        /* L/R */ /* TODO better event */
+       { 0x0116, KEY_SLEEP },        /* Hibernate */
+       { 0x0116, KEY_SWITCHVIDEOMODE },
                                          /* A/V */ /* TODO does not work */
-       { 0x00, 0x06, KEY_AGAIN },        /* Recall */
-       { 0x01, 0x16, KEY_KPPLUS },       /* Zoom+ */ /* TODO does not work */
-       { 0x01, 0x16, KEY_KPMINUS },      /* Zoom- */ /* TODO does not work */
-       { 0x02, 0x15, KEY_RED },
-       { 0x02, 0x0a, KEY_GREEN },
-       { 0x02, 0x1c, KEY_YELLOW },
-       { 0x02, 0x05, KEY_BLUE },
+       { 0x0006, KEY_AGAIN },        /* Recall */
+       { 0x0116, KEY_KPPLUS },       /* Zoom+ */ /* TODO does not work */
+       { 0x0116, KEY_KPMINUS },      /* Zoom- */ /* TODO does not work */
+       { 0x0215, KEY_RED },
+       { 0x020a, KEY_GREEN },
+       { 0x021c, KEY_YELLOW },
+       { 0x0205, KEY_BLUE },
 };
 
 static u8 af9015_ir_table_twinhan[] = {
@@ -304,24 +304,24 @@ static u8 af9015_ir_table_twinhan[] = {
 
 /* A-Link DTU(m) */
 static struct dvb_usb_rc_key af9015_rc_keys_a_link[] = {
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x00, 0x27, KEY_0 },
-       { 0x00, 0x2e, KEY_CHANNELUP },
-       { 0x00, 0x2d, KEY_CHANNELDOWN },
-       { 0x04, 0x28, KEY_ZOOM },
-       { 0x00, 0x41, KEY_MUTE },
-       { 0x00, 0x42, KEY_VOLUMEDOWN },
-       { 0x00, 0x43, KEY_VOLUMEUP },
-       { 0x00, 0x44, KEY_GOTO },         /* jump */
-       { 0x05, 0x45, KEY_POWER },
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0027, KEY_0 },
+       { 0x002e, KEY_CHANNELUP },
+       { 0x002d, KEY_CHANNELDOWN },
+       { 0x0428, KEY_ZOOM },
+       { 0x0041, KEY_MUTE },
+       { 0x0042, KEY_VOLUMEDOWN },
+       { 0x0043, KEY_VOLUMEUP },
+       { 0x0044, KEY_GOTO },         /* jump */
+       { 0x0545, KEY_POWER },
 };
 
 static u8 af9015_ir_table_a_link[] = {
@@ -347,24 +347,24 @@ static u8 af9015_ir_table_a_link[] = {
 
 /* MSI DIGIVOX mini II V3.0 */
 static struct dvb_usb_rc_key af9015_rc_keys_msi[] = {
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x00, 0x27, KEY_0 },
-       { 0x03, 0x0f, KEY_CHANNELUP },
-       { 0x03, 0x0e, KEY_CHANNELDOWN },
-       { 0x00, 0x42, KEY_VOLUMEDOWN },
-       { 0x00, 0x43, KEY_VOLUMEUP },
-       { 0x05, 0x45, KEY_POWER },
-       { 0x00, 0x52, KEY_UP },           /* up */
-       { 0x00, 0x51, KEY_DOWN },         /* down */
-       { 0x00, 0x28, KEY_ENTER },
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0027, KEY_0 },
+       { 0x030f, KEY_CHANNELUP },
+       { 0x030e, KEY_CHANNELDOWN },
+       { 0x0042, KEY_VOLUMEDOWN },
+       { 0x0043, KEY_VOLUMEUP },
+       { 0x0545, KEY_POWER },
+       { 0x0052, KEY_UP },           /* up */
+       { 0x0051, KEY_DOWN },         /* down */
+       { 0x0028, KEY_ENTER },
 };
 
 static u8 af9015_ir_table_msi[] = {
@@ -390,42 +390,42 @@ static u8 af9015_ir_table_msi[] = {
 
 /* MYGICTV U718 */
 static struct dvb_usb_rc_key af9015_rc_keys_mygictv[] = {
-       { 0x00, 0x3d, KEY_SWITCHVIDEOMODE },
+       { 0x003d, KEY_SWITCHVIDEOMODE },
                                          /* TV / AV */
-       { 0x05, 0x45, KEY_POWER },
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x00, 0x27, KEY_0 },
-       { 0x00, 0x41, KEY_MUTE },
-       { 0x00, 0x2a, KEY_ESC },          /* Esc */
-       { 0x00, 0x2e, KEY_CHANNELUP },
-       { 0x00, 0x2d, KEY_CHANNELDOWN },
-       { 0x00, 0x42, KEY_VOLUMEDOWN },
-       { 0x00, 0x43, KEY_VOLUMEUP },
-       { 0x00, 0x52, KEY_UP },           /* up arrow */
-       { 0x00, 0x51, KEY_DOWN },         /* down arrow */
-       { 0x00, 0x4f, KEY_RIGHT },        /* right arrow */
-       { 0x00, 0x50, KEY_LEFT },         /* left arrow */
-       { 0x00, 0x28, KEY_ENTER },        /* ok */
-       { 0x01, 0x15, KEY_RECORD },
-       { 0x03, 0x13, KEY_PLAY },
-       { 0x01, 0x13, KEY_PAUSE },
-       { 0x01, 0x16, KEY_STOP },
-       { 0x03, 0x07, KEY_REWIND },       /* FR << */
-       { 0x03, 0x09, KEY_FASTFORWARD },  /* FF >> */
-       { 0x00, 0x3b, KEY_TIME },         /* TimeShift */
-       { 0x00, 0x3e, KEY_CAMERA },       /* Snapshot */
-       { 0x03, 0x16, KEY_CYCLEWINDOWS }, /* yellow, min / max */
-       { 0x00, 0x00, KEY_ZOOM },         /* 'select' (?) */
-       { 0x03, 0x16, KEY_SHUFFLE },      /* Shuffle */
-       { 0x03, 0x45, KEY_POWER },
+       { 0x0545, KEY_POWER },
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0027, KEY_0 },
+       { 0x0041, KEY_MUTE },
+       { 0x002a, KEY_ESC },          /* Esc */
+       { 0x002e, KEY_CHANNELUP },
+       { 0x002d, KEY_CHANNELDOWN },
+       { 0x0042, KEY_VOLUMEDOWN },
+       { 0x0043, KEY_VOLUMEUP },
+       { 0x0052, KEY_UP },           /* up arrow */
+       { 0x0051, KEY_DOWN },         /* down arrow */
+       { 0x004f, KEY_RIGHT },        /* right arrow */
+       { 0x0050, KEY_LEFT },         /* left arrow */
+       { 0x0028, KEY_ENTER },        /* ok */
+       { 0x0115, KEY_RECORD },
+       { 0x0313, KEY_PLAY },
+       { 0x0113, KEY_PAUSE },
+       { 0x0116, KEY_STOP },
+       { 0x0307, KEY_REWIND },       /* FR << */
+       { 0x0309, KEY_FASTFORWARD },  /* FF >> */
+       { 0x003b, KEY_TIME },         /* TimeShift */
+       { 0x003e, KEY_CAMERA },       /* Snapshot */
+       { 0x0316, KEY_CYCLEWINDOWS }, /* yellow, min / max */
+       { 0x0000, KEY_ZOOM },         /* 'select' (?) */
+       { 0x0316, KEY_SHUFFLE },      /* Shuffle */
+       { 0x0345, KEY_POWER },
 };
 
 static u8 af9015_ir_table_mygictv[] = {
@@ -516,41 +516,41 @@ static u8 af9015_ir_table_kworld[] = {
 
 /* AverMedia Volar X */
 static struct dvb_usb_rc_key af9015_rc_keys_avermedia[] = {
-       { 0x05, 0x3d, KEY_PROG1 },       /* SOURCE */
-       { 0x05, 0x12, KEY_POWER },       /* POWER */
-       { 0x05, 0x1e, KEY_1 },           /* 1 */
-       { 0x05, 0x1f, KEY_2 },           /* 2 */
-       { 0x05, 0x20, KEY_3 },           /* 3 */
-       { 0x05, 0x21, KEY_4 },           /* 4 */
-       { 0x05, 0x22, KEY_5 },           /* 5 */
-       { 0x05, 0x23, KEY_6 },           /* 6 */
-       { 0x05, 0x24, KEY_7 },           /* 7 */
-       { 0x05, 0x25, KEY_8 },           /* 8 */
-       { 0x05, 0x26, KEY_9 },           /* 9 */
-       { 0x05, 0x3f, KEY_LEFT },        /* L / DISPLAY */
-       { 0x05, 0x27, KEY_0 },           /* 0 */
-       { 0x05, 0x0f, KEY_RIGHT },       /* R / CH RTN */
-       { 0x05, 0x18, KEY_PROG2 },       /* SNAP SHOT */
-       { 0x05, 0x1c, KEY_PROG3 },       /* 16-CH PREV */
-       { 0x05, 0x2d, KEY_VOLUMEDOWN },  /* VOL DOWN */
-       { 0x05, 0x3e, KEY_ZOOM },        /* FULL SCREEN */
-       { 0x05, 0x2e, KEY_VOLUMEUP },    /* VOL UP */
-       { 0x05, 0x10, KEY_MUTE },        /* MUTE */
-       { 0x05, 0x04, KEY_AUDIO },       /* AUDIO */
-       { 0x05, 0x15, KEY_RECORD },      /* RECORD */
-       { 0x05, 0x11, KEY_PLAY },        /* PLAY */
-       { 0x05, 0x16, KEY_STOP },        /* STOP */
-       { 0x05, 0x0c, KEY_PLAYPAUSE },   /* TIMESHIFT / PAUSE */
-       { 0x05, 0x05, KEY_BACK },        /* << / RED */
-       { 0x05, 0x09, KEY_FORWARD },     /* >> / YELLOW */
-       { 0x05, 0x17, KEY_TEXT },        /* TELETEXT */
-       { 0x05, 0x0a, KEY_EPG },         /* EPG */
-       { 0x05, 0x13, KEY_MENU },        /* MENU */
-
-       { 0x05, 0x0e, KEY_CHANNELUP },   /* CH UP */
-       { 0x05, 0x0d, KEY_CHANNELDOWN }, /* CH DOWN */
-       { 0x05, 0x19, KEY_FIRST },       /* |<< / GREEN */
-       { 0x05, 0x08, KEY_LAST },        /* >>| / BLUE */
+       { 0x053d, KEY_PROG1 },       /* SOURCE */
+       { 0x0512, KEY_POWER },       /* POWER */
+       { 0x051e, KEY_1 },           /* 1 */
+       { 0x051f, KEY_2 },           /* 2 */
+       { 0x0520, KEY_3 },           /* 3 */
+       { 0x0521, KEY_4 },           /* 4 */
+       { 0x0522, KEY_5 },           /* 5 */
+       { 0x0523, KEY_6 },           /* 6 */
+       { 0x0524, KEY_7 },           /* 7 */
+       { 0x0525, KEY_8 },           /* 8 */
+       { 0x0526, KEY_9 },           /* 9 */
+       { 0x053f, KEY_LEFT },        /* L / DISPLAY */
+       { 0x0527, KEY_0 },           /* 0 */
+       { 0x050f, KEY_RIGHT },       /* R / CH RTN */
+       { 0x0518, KEY_PROG2 },       /* SNAP SHOT */
+       { 0x051c, KEY_PROG3 },       /* 16-CH PREV */
+       { 0x052d, KEY_VOLUMEDOWN },  /* VOL DOWN */
+       { 0x053e, KEY_ZOOM },        /* FULL SCREEN */
+       { 0x052e, KEY_VOLUMEUP },    /* VOL UP */
+       { 0x0510, KEY_MUTE },        /* MUTE */
+       { 0x0504, KEY_AUDIO },       /* AUDIO */
+       { 0x0515, KEY_RECORD },      /* RECORD */
+       { 0x0511, KEY_PLAY },        /* PLAY */
+       { 0x0516, KEY_STOP },        /* STOP */
+       { 0x050c, KEY_PLAYPAUSE },   /* TIMESHIFT / PAUSE */
+       { 0x0505, KEY_BACK },        /* << / RED */
+       { 0x0509, KEY_FORWARD },     /* >> / YELLOW */
+       { 0x0517, KEY_TEXT },        /* TELETEXT */
+       { 0x050a, KEY_EPG },         /* EPG */
+       { 0x0513, KEY_MENU },        /* MENU */
+
+       { 0x050e, KEY_CHANNELUP },   /* CH UP */
+       { 0x050d, KEY_CHANNELDOWN }, /* CH DOWN */
+       { 0x0519, KEY_FIRST },       /* |<< / GREEN */
+       { 0x0508, KEY_LAST },        /* >>| / BLUE */
 };
 
 static u8 af9015_ir_table_avermedia[] = {
@@ -622,34 +622,34 @@ static u8 af9015_ir_table_avermedia_ks[] = {
 
 /* Digittrade DVB-T USB Stick */
 static struct dvb_usb_rc_key af9015_rc_keys_digittrade[] = {
-       { 0x01, 0x0f, KEY_LAST },       /* RETURN */
-       { 0x05, 0x17, KEY_TEXT },       /* TELETEXT */
-       { 0x01, 0x08, KEY_EPG },        /* EPG */
-       { 0x05, 0x13, KEY_POWER },      /* POWER */
-       { 0x01, 0x09, KEY_ZOOM },       /* FULLSCREEN */
-       { 0x00, 0x40, KEY_AUDIO },      /* DUAL SOUND */
-       { 0x00, 0x2c, KEY_PRINT },      /* SNAPSHOT */
-       { 0x05, 0x16, KEY_SUBTITLE },   /* SUBTITLE */
-       { 0x00, 0x52, KEY_CHANNELUP },  /* CH Up */
-       { 0x00, 0x51, KEY_CHANNELDOWN },/* Ch Dn */
-       { 0x00, 0x57, KEY_VOLUMEUP },   /* Vol Up */
-       { 0x00, 0x56, KEY_VOLUMEDOWN }, /* Vol Dn */
-       { 0x01, 0x10, KEY_MUTE },       /* MUTE */
-       { 0x00, 0x27, KEY_0 },
-       { 0x00, 0x1e, KEY_1 },
-       { 0x00, 0x1f, KEY_2 },
-       { 0x00, 0x20, KEY_3 },
-       { 0x00, 0x21, KEY_4 },
-       { 0x00, 0x22, KEY_5 },
-       { 0x00, 0x23, KEY_6 },
-       { 0x00, 0x24, KEY_7 },
-       { 0x00, 0x25, KEY_8 },
-       { 0x00, 0x26, KEY_9 },
-       { 0x01, 0x17, KEY_PLAYPAUSE },  /* TIMESHIFT */
-       { 0x01, 0x15, KEY_RECORD },     /* RECORD */
-       { 0x03, 0x13, KEY_PLAY },       /* PLAY */
-       { 0x01, 0x16, KEY_STOP },       /* STOP */
-       { 0x01, 0x13, KEY_PAUSE },      /* PAUSE */
+       { 0x010f, KEY_LAST },   /* RETURN */
+       { 0x0517, KEY_TEXT },   /* TELETEXT */
+       { 0x0108, KEY_EPG },    /* EPG */
+       { 0x0513, KEY_POWER },  /* POWER */
+       { 0x0109, KEY_ZOOM },   /* FULLSCREEN */
+       { 0x0040, KEY_AUDIO },  /* DUAL SOUND */
+       { 0x002c, KEY_PRINT },  /* SNAPSHOT */
+       { 0x0516, KEY_SUBTITLE },       /* SUBTITLE */
+       { 0x0052, KEY_CHANNELUP },      /* CH Up */
+       { 0x0051, KEY_CHANNELDOWN },/* Ch Dn */
+       { 0x0057, KEY_VOLUMEUP },       /* Vol Up */
+       { 0x0056, KEY_VOLUMEDOWN },     /* Vol Dn */
+       { 0x0110, KEY_MUTE },   /* MUTE */
+       { 0x0027, KEY_0 },
+       { 0x001e, KEY_1 },
+       { 0x001f, KEY_2 },
+       { 0x0020, KEY_3 },
+       { 0x0021, KEY_4 },
+       { 0x0022, KEY_5 },
+       { 0x0023, KEY_6 },
+       { 0x0024, KEY_7 },
+       { 0x0025, KEY_8 },
+       { 0x0026, KEY_9 },
+       { 0x0117, KEY_PLAYPAUSE },      /* TIMESHIFT */
+       { 0x0115, KEY_RECORD }, /* RECORD */
+       { 0x0313, KEY_PLAY },   /* PLAY */
+       { 0x0116, KEY_STOP },   /* STOP */
+       { 0x0113, KEY_PAUSE },  /* PAUSE */
 };
 
 static u8 af9015_ir_table_digittrade[] = {
@@ -685,34 +685,34 @@ static u8 af9015_ir_table_digittrade[] = {
 
 /* TREKSTOR DVB-T USB Stick */
 static struct dvb_usb_rc_key af9015_rc_keys_trekstor[] = {
-       { 0x07, 0x04, KEY_AGAIN },              /* Home */
-       { 0x07, 0x05, KEY_MUTE },               /* Mute */
-       { 0x07, 0x06, KEY_UP },                 /* Up */
-       { 0x07, 0x07, KEY_DOWN },               /* Down */
-       { 0x07, 0x09, KEY_RIGHT },              /* Right */
-       { 0x07, 0x0a, KEY_ENTER },              /* OK */
-       { 0x07, 0x0b, KEY_FASTFORWARD },        /* Fast forward */
-       { 0x07, 0x0c, KEY_REWIND },             /* Rewind */
-       { 0x07, 0x0d, KEY_PLAY },               /* Play/Pause */
-       { 0x07, 0x0e, KEY_VOLUMEUP },           /* Volume + */
-       { 0x07, 0x0f, KEY_VOLUMEDOWN },         /* Volume - */
-       { 0x07, 0x10, KEY_RECORD },             /* Record */
-       { 0x07, 0x11, KEY_STOP },               /* Stop */
-       { 0x07, 0x12, KEY_ZOOM },               /* TV */
-       { 0x07, 0x13, KEY_EPG },                /* Info/EPG */
-       { 0x07, 0x14, KEY_CHANNELDOWN },        /* Channel - */
-       { 0x07, 0x15, KEY_CHANNELUP },          /* Channel + */
-       { 0x07, 0x1e, KEY_1 },
-       { 0x07, 0x1f, KEY_2 },
-       { 0x07, 0x20, KEY_3 },
-       { 0x07, 0x21, KEY_4 },
-       { 0x07, 0x22, KEY_5 },
-       { 0x07, 0x23, KEY_6 },
-       { 0x07, 0x24, KEY_7 },
-       { 0x07, 0x25, KEY_8 },
-       { 0x07, 0x26, KEY_9 },
-       { 0x07, 0x08, KEY_LEFT },               /* LEFT */
-       { 0x07, 0x27, KEY_0 },
+       { 0x0704, KEY_AGAIN },          /* Home */
+       { 0x0705, KEY_MUTE },           /* Mute */
+       { 0x0706, KEY_UP },                     /* Up */
+       { 0x0707, KEY_DOWN },           /* Down */
+       { 0x0709, KEY_RIGHT },          /* Right */
+       { 0x070a, KEY_ENTER },          /* OK */
+       { 0x070b, KEY_FASTFORWARD },    /* Fast forward */
+       { 0x070c, KEY_REWIND },         /* Rewind */
+       { 0x070d, KEY_PLAY },           /* Play/Pause */
+       { 0x070e, KEY_VOLUMEUP },               /* Volume + */
+       { 0x070f, KEY_VOLUMEDOWN },             /* Volume - */
+       { 0x0710, KEY_RECORD },         /* Record */
+       { 0x0711, KEY_STOP },           /* Stop */
+       { 0x0712, KEY_ZOOM },           /* TV */
+       { 0x0713, KEY_EPG },            /* Info/EPG */
+       { 0x0714, KEY_CHANNELDOWN },    /* Channel - */
+       { 0x0715, KEY_CHANNELUP },              /* Channel + */
+       { 0x071e, KEY_1 },
+       { 0x071f, KEY_2 },
+       { 0x0720, KEY_3 },
+       { 0x0721, KEY_4 },
+       { 0x0722, KEY_5 },
+       { 0x0723, KEY_6 },
+       { 0x0724, KEY_7 },
+       { 0x0725, KEY_8 },
+       { 0x0726, KEY_9 },
+       { 0x0708, KEY_LEFT },           /* LEFT */
+       { 0x0727, KEY_0 },
 };
 
 static u8 af9015_ir_table_trekstor[] = {
index c6e7b42..7381aff 100644 (file)
@@ -389,8 +389,8 @@ static int anysee_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        *state = REMOTE_NO_KEY_PRESSED;
 
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (keymap[i].custom == ircode[0] &&
-                   keymap[i].data == ircode[1]) {
+               if (rc5_custom(&keymap[i]) == ircode[0] &&
+                   rc5_data(&keymap[i]) == ircode[1]) {
                        *event = keymap[i].event;
                        *state = REMOTE_KEY_PRESSED;
                        return 0;
@@ -400,50 +400,50 @@ static int anysee_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
 }
 
 static struct dvb_usb_rc_key anysee_rc_keys[] = {
-       { 0x01, 0x00, KEY_0 },
-       { 0x01, 0x01, KEY_1 },
-       { 0x01, 0x02, KEY_2 },
-       { 0x01, 0x03, KEY_3 },
-       { 0x01, 0x04, KEY_4 },
-       { 0x01, 0x05, KEY_5 },
-       { 0x01, 0x06, KEY_6 },
-       { 0x01, 0x07, KEY_7 },
-       { 0x01, 0x08, KEY_8 },
-       { 0x01, 0x09, KEY_9 },
-       { 0x01, 0x0a, KEY_POWER },
-       { 0x01, 0x0b, KEY_DOCUMENTS },    /* * */
-       { 0x01, 0x19, KEY_FAVORITES },
-       { 0x01, 0x20, KEY_SLEEP },
-       { 0x01, 0x21, KEY_MODE },         /* 4:3 / 16:9 select */
-       { 0x01, 0x22, KEY_ZOOM },
-       { 0x01, 0x47, KEY_TEXT },
-       { 0x01, 0x16, KEY_TV },           /* TV / radio select */
-       { 0x01, 0x1e, KEY_LANGUAGE },     /* Second Audio Program */
-       { 0x01, 0x1a, KEY_SUBTITLE },
-       { 0x01, 0x1b, KEY_CAMERA },       /* screenshot */
-       { 0x01, 0x42, KEY_MUTE },
-       { 0x01, 0x0e, KEY_MENU },
-       { 0x01, 0x0f, KEY_EPG },
-       { 0x01, 0x17, KEY_INFO },
-       { 0x01, 0x10, KEY_EXIT },
-       { 0x01, 0x13, KEY_VOLUMEUP },
-       { 0x01, 0x12, KEY_VOLUMEDOWN },
-       { 0x01, 0x11, KEY_CHANNELUP },
-       { 0x01, 0x14, KEY_CHANNELDOWN },
-       { 0x01, 0x15, KEY_OK },
-       { 0x01, 0x1d, KEY_RED },
-       { 0x01, 0x1f, KEY_GREEN },
-       { 0x01, 0x1c, KEY_YELLOW },
-       { 0x01, 0x44, KEY_BLUE },
-       { 0x01, 0x0c, KEY_SHUFFLE },      /* snapshot */
-       { 0x01, 0x48, KEY_STOP },
-       { 0x01, 0x50, KEY_PLAY },
-       { 0x01, 0x51, KEY_PAUSE },
-       { 0x01, 0x49, KEY_RECORD },
-       { 0x01, 0x18, KEY_PREVIOUS },     /* |<< */
-       { 0x01, 0x0d, KEY_NEXT },         /* >>| */
-       { 0x01, 0x24, KEY_PROG1 },        /* F1 */
-       { 0x01, 0x25, KEY_PROG2 },        /* F2 */
+       { 0x0100, KEY_0 },
+       { 0x0101, KEY_1 },
+       { 0x0102, KEY_2 },
+       { 0x0103, KEY_3 },
+       { 0x0104, KEY_4 },
+       { 0x0105, KEY_5 },
+       { 0x0106, KEY_6 },
+       { 0x0107, KEY_7 },
+       { 0x0108, KEY_8 },
+       { 0x0109, KEY_9 },
+       { 0x010a, KEY_POWER },
+       { 0x010b, KEY_DOCUMENTS },    /* * */
+       { 0x0119, KEY_FAVORITES },
+       { 0x0120, KEY_SLEEP },
+       { 0x0121, KEY_MODE },         /* 4:3 / 16:9 select */
+       { 0x0122, KEY_ZOOM },
+       { 0x0147, KEY_TEXT },
+       { 0x0116, KEY_TV },           /* TV / radio select */
+       { 0x011e, KEY_LANGUAGE },     /* Second Audio Program */
+       { 0x011a, KEY_SUBTITLE },
+       { 0x011b, KEY_CAMERA },       /* screenshot */
+       { 0x0142, KEY_MUTE },
+       { 0x010e, KEY_MENU },
+       { 0x010f, KEY_EPG },
+       { 0x0117, KEY_INFO },
+       { 0x0110, KEY_EXIT },
+       { 0x0113, KEY_VOLUMEUP },
+       { 0x0112, KEY_VOLUMEDOWN },
+       { 0x0111, KEY_CHANNELUP },
+       { 0x0114, KEY_CHANNELDOWN },
+       { 0x0115, KEY_OK },
+       { 0x011d, KEY_RED },
+       { 0x011f, KEY_GREEN },
+       { 0x011c, KEY_YELLOW },
+       { 0x0144, KEY_BLUE },
+       { 0x010c, KEY_SHUFFLE },      /* snapshot */
+       { 0x0148, KEY_STOP },
+       { 0x0150, KEY_PLAY },
+       { 0x0151, KEY_PAUSE },
+       { 0x0149, KEY_RECORD },
+       { 0x0118, KEY_PREVIOUS },     /* |<< */
+       { 0x010d, KEY_NEXT },         /* >>| */
+       { 0x0124, KEY_PROG1 },        /* F1 */
+       { 0x0125, KEY_PROG2 },        /* F2 */
 };
 
 /* DVB USB Driver stuff */
index 80e37a0..e37ac4d 100644 (file)
@@ -85,43 +85,43 @@ static int cinergyt2_frontend_attach(struct dvb_usb_adapter *adap)
 }
 
 static struct dvb_usb_rc_key cinergyt2_rc_keys[] = {
-       { 0x04, 0x01,   KEY_POWER },
-       { 0x04, 0x02,   KEY_1 },
-       { 0x04, 0x03,   KEY_2 },
-       { 0x04, 0x04,   KEY_3 },
-       { 0x04, 0x05,   KEY_4 },
-       { 0x04, 0x06,   KEY_5 },
-       { 0x04, 0x07,   KEY_6 },
-       { 0x04, 0x08,   KEY_7 },
-       { 0x04, 0x09,   KEY_8 },
-       { 0x04, 0x0a,   KEY_9 },
-       { 0x04, 0x0c,   KEY_0 },
-       { 0x04, 0x0b,   KEY_VIDEO },
-       { 0x04, 0x0d,   KEY_REFRESH },
-       { 0x04, 0x0e,   KEY_SELECT },
-       { 0x04, 0x0f,   KEY_EPG },
-       { 0x04, 0x10,   KEY_UP },
-       { 0x04, 0x14,   KEY_DOWN },
-       { 0x04, 0x11,   KEY_LEFT },
-       { 0x04, 0x13,   KEY_RIGHT },
-       { 0x04, 0x12,   KEY_OK },
-       { 0x04, 0x15,   KEY_TEXT },
-       { 0x04, 0x16,   KEY_INFO },
-       { 0x04, 0x17,   KEY_RED },
-       { 0x04, 0x18,   KEY_GREEN },
-       { 0x04, 0x19,   KEY_YELLOW },
-       { 0x04, 0x1a,   KEY_BLUE },
-       { 0x04, 0x1c,   KEY_VOLUMEUP },
-       { 0x04, 0x1e,   KEY_VOLUMEDOWN },
-       { 0x04, 0x1d,   KEY_MUTE },
-       { 0x04, 0x1b,   KEY_CHANNELUP },
-       { 0x04, 0x1f,   KEY_CHANNELDOWN },
-       { 0x04, 0x40,   KEY_PAUSE },
-       { 0x04, 0x4c,   KEY_PLAY },
-       { 0x04, 0x58,   KEY_RECORD },
-       { 0x04, 0x54,   KEY_PREVIOUS },
-       { 0x04, 0x48,   KEY_STOP },
-       { 0x04, 0x5c,   KEY_NEXT }
+       { 0x0401, KEY_POWER },
+       { 0x0402, KEY_1 },
+       { 0x0403, KEY_2 },
+       { 0x0404, KEY_3 },
+       { 0x0405, KEY_4 },
+       { 0x0406, KEY_5 },
+       { 0x0407, KEY_6 },
+       { 0x0408, KEY_7 },
+       { 0x0409, KEY_8 },
+       { 0x040a, KEY_9 },
+       { 0x040c, KEY_0 },
+       { 0x040b, KEY_VIDEO },
+       { 0x040d, KEY_REFRESH },
+       { 0x040e, KEY_SELECT },
+       { 0x040f, KEY_EPG },
+       { 0x0410, KEY_UP },
+       { 0x0414, KEY_DOWN },
+       { 0x0411, KEY_LEFT },
+       { 0x0413, KEY_RIGHT },
+       { 0x0412, KEY_OK },
+       { 0x0415, KEY_TEXT },
+       { 0x0416, KEY_INFO },
+       { 0x0417, KEY_RED },
+       { 0x0418, KEY_GREEN },
+       { 0x0419, KEY_YELLOW },
+       { 0x041a, KEY_BLUE },
+       { 0x041c, KEY_VOLUMEUP },
+       { 0x041e, KEY_VOLUMEDOWN },
+       { 0x041d, KEY_MUTE },
+       { 0x041b, KEY_CHANNELUP },
+       { 0x041f, KEY_CHANNELDOWN },
+       { 0x0440, KEY_PAUSE },
+       { 0x044c, KEY_PLAY },
+       { 0x0458, KEY_RECORD },
+       { 0x0454, KEY_PREVIOUS },
+       { 0x0448, KEY_STOP },
+       { 0x045c, KEY_NEXT }
 };
 
 /* Number of keypresses to ignore before detect repeating */
index 88205e7..f65591f 100644 (file)
@@ -392,8 +392,8 @@ static int cxusb_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        *state = REMOTE_NO_KEY_PRESSED;
 
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (keymap[i].custom == ircode[2] &&
-                   keymap[i].data == ircode[3]) {
+               if (rc5_custom(&keymap[i]) == ircode[2] &&
+                   rc5_data(&keymap[i]) == ircode[3]) {
                        *event = keymap[i].event;
                        *state = REMOTE_KEY_PRESSED;
 
@@ -420,8 +420,8 @@ static int cxusb_bluebird2_rc_query(struct dvb_usb_device *d, u32 *event,
                return 0;
 
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (keymap[i].custom == ircode[1] &&
-                   keymap[i].data == ircode[2]) {
+               if (rc5_custom(&keymap[i]) == ircode[1] &&
+                   rc5_data(&keymap[i]) == ircode[2]) {
                        *event = keymap[i].event;
                        *state = REMOTE_KEY_PRESSED;
 
@@ -446,8 +446,8 @@ static int cxusb_d680_dmb_rc_query(struct dvb_usb_device *d, u32 *event,
                return 0;
 
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (keymap[i].custom == ircode[0] &&
-                   keymap[i].data == ircode[1]) {
+               if (rc5_custom(&keymap[i]) == ircode[0] &&
+                   rc5_data(&keymap[i]) == ircode[1]) {
                        *event = keymap[i].event;
                        *state = REMOTE_KEY_PRESSED;
 
@@ -459,128 +459,128 @@ static int cxusb_d680_dmb_rc_query(struct dvb_usb_device *d, u32 *event,
 }
 
 static struct dvb_usb_rc_key dvico_mce_rc_keys[] = {
-       { 0xfe, 0x02, KEY_TV },
-       { 0xfe, 0x0e, KEY_MP3 },
-       { 0xfe, 0x1a, KEY_DVD },
-       { 0xfe, 0x1e, KEY_FAVORITES },
-       { 0xfe, 0x16, KEY_SETUP },
-       { 0xfe, 0x46, KEY_POWER2 },
-       { 0xfe, 0x0a, KEY_EPG },
-       { 0xfe, 0x49, KEY_BACK },
-       { 0xfe, 0x4d, KEY_MENU },
-       { 0xfe, 0x51, KEY_UP },
-       { 0xfe, 0x5b, KEY_LEFT },
-       { 0xfe, 0x5f, KEY_RIGHT },
-       { 0xfe, 0x53, KEY_DOWN },
-       { 0xfe, 0x5e, KEY_OK },
-       { 0xfe, 0x59, KEY_INFO },
-       { 0xfe, 0x55, KEY_TAB },
-       { 0xfe, 0x0f, KEY_PREVIOUSSONG },/* Replay */
-       { 0xfe, 0x12, KEY_NEXTSONG },   /* Skip */
-       { 0xfe, 0x42, KEY_ENTER  },     /* Windows/Start */
-       { 0xfe, 0x15, KEY_VOLUMEUP },
-       { 0xfe, 0x05, KEY_VOLUMEDOWN },
-       { 0xfe, 0x11, KEY_CHANNELUP },
-       { 0xfe, 0x09, KEY_CHANNELDOWN },
-       { 0xfe, 0x52, KEY_CAMERA },
-       { 0xfe, 0x5a, KEY_TUNER },      /* Live */
-       { 0xfe, 0x19, KEY_OPEN },
-       { 0xfe, 0x0b, KEY_1 },
-       { 0xfe, 0x17, KEY_2 },
-       { 0xfe, 0x1b, KEY_3 },
-       { 0xfe, 0x07, KEY_4 },
-       { 0xfe, 0x50, KEY_5 },
-       { 0xfe, 0x54, KEY_6 },
-       { 0xfe, 0x48, KEY_7 },
-       { 0xfe, 0x4c, KEY_8 },
-       { 0xfe, 0x58, KEY_9 },
-       { 0xfe, 0x13, KEY_ANGLE },      /* Aspect */
-       { 0xfe, 0x03, KEY_0 },
-       { 0xfe, 0x1f, KEY_ZOOM },
-       { 0xfe, 0x43, KEY_REWIND },
-       { 0xfe, 0x47, KEY_PLAYPAUSE },
-       { 0xfe, 0x4f, KEY_FASTFORWARD },
-       { 0xfe, 0x57, KEY_MUTE },
-       { 0xfe, 0x0d, KEY_STOP },
-       { 0xfe, 0x01, KEY_RECORD },
-       { 0xfe, 0x4e, KEY_POWER },
+       { 0xfe02, KEY_TV },
+       { 0xfe0e, KEY_MP3 },
+       { 0xfe1a, KEY_DVD },
+       { 0xfe1e, KEY_FAVORITES },
+       { 0xfe16, KEY_SETUP },
+       { 0xfe46, KEY_POWER2 },
+       { 0xfe0a, KEY_EPG },
+       { 0xfe49, KEY_BACK },
+       { 0xfe4d, KEY_MENU },
+       { 0xfe51, KEY_UP },
+       { 0xfe5b, KEY_LEFT },
+       { 0xfe5f, KEY_RIGHT },
+       { 0xfe53, KEY_DOWN },
+       { 0xfe5e, KEY_OK },
+       { 0xfe59, KEY_INFO },
+       { 0xfe55, KEY_TAB },
+       { 0xfe0f, KEY_PREVIOUSSONG },/* Replay */
+       { 0xfe12, KEY_NEXTSONG },       /* Skip */
+       { 0xfe42, KEY_ENTER      },     /* Windows/Start */
+       { 0xfe15, KEY_VOLUMEUP },
+       { 0xfe05, KEY_VOLUMEDOWN },
+       { 0xfe11, KEY_CHANNELUP },
+       { 0xfe09, KEY_CHANNELDOWN },
+       { 0xfe52, KEY_CAMERA },
+       { 0xfe5a, KEY_TUNER },  /* Live */
+       { 0xfe19, KEY_OPEN },
+       { 0xfe0b, KEY_1 },
+       { 0xfe17, KEY_2 },
+       { 0xfe1b, KEY_3 },
+       { 0xfe07, KEY_4 },
+       { 0xfe50, KEY_5 },
+       { 0xfe54, KEY_6 },
+       { 0xfe48, KEY_7 },
+       { 0xfe4c, KEY_8 },
+       { 0xfe58, KEY_9 },
+       { 0xfe13, KEY_ANGLE },  /* Aspect */
+       { 0xfe03, KEY_0 },
+       { 0xfe1f, KEY_ZOOM },
+       { 0xfe43, KEY_REWIND },
+       { 0xfe47, KEY_PLAYPAUSE },
+       { 0xfe4f, KEY_FASTFORWARD },
+       { 0xfe57, KEY_MUTE },
+       { 0xfe0d, KEY_STOP },
+       { 0xfe01, KEY_RECORD },
+       { 0xfe4e, KEY_POWER },
 };
 
 static struct dvb_usb_rc_key dvico_portable_rc_keys[] = {
-       { 0xfc, 0x02, KEY_SETUP },       /* Profile */
-       { 0xfc, 0x43, KEY_POWER2 },
-       { 0xfc, 0x06, KEY_EPG },
-       { 0xfc, 0x5a, KEY_BACK },
-       { 0xfc, 0x05, KEY_MENU },
-       { 0xfc, 0x47, KEY_INFO },
-       { 0xfc, 0x01, KEY_TAB },
-       { 0xfc, 0x42, KEY_PREVIOUSSONG },/* Replay */
-       { 0xfc, 0x49, KEY_VOLUMEUP },
-       { 0xfc, 0x09, KEY_VOLUMEDOWN },
-       { 0xfc, 0x54, KEY_CHANNELUP },
-       { 0xfc, 0x0b, KEY_CHANNELDOWN },
-       { 0xfc, 0x16, KEY_CAMERA },
-       { 0xfc, 0x40, KEY_TUNER },      /* ATV/DTV */
-       { 0xfc, 0x45, KEY_OPEN },
-       { 0xfc, 0x19, KEY_1 },
-       { 0xfc, 0x18, KEY_2 },
-       { 0xfc, 0x1b, KEY_3 },
-       { 0xfc, 0x1a, KEY_4 },
-       { 0xfc, 0x58, KEY_5 },
-       { 0xfc, 0x59, KEY_6 },
-       { 0xfc, 0x15, KEY_7 },
-       { 0xfc, 0x14, KEY_8 },
-       { 0xfc, 0x17, KEY_9 },
-       { 0xfc, 0x44, KEY_ANGLE },      /* Aspect */
-       { 0xfc, 0x55, KEY_0 },
-       { 0xfc, 0x07, KEY_ZOOM },
-       { 0xfc, 0x0a, KEY_REWIND },
-       { 0xfc, 0x08, KEY_PLAYPAUSE },
-       { 0xfc, 0x4b, KEY_FASTFORWARD },
-       { 0xfc, 0x5b, KEY_MUTE },
-       { 0xfc, 0x04, KEY_STOP },
-       { 0xfc, 0x56, KEY_RECORD },
-       { 0xfc, 0x57, KEY_POWER },
-       { 0xfc, 0x41, KEY_UNKNOWN },    /* INPUT */
-       { 0xfc, 0x00, KEY_UNKNOWN },    /* HD */
+       { 0xfc02, KEY_SETUP },       /* Profile */
+       { 0xfc43, KEY_POWER2 },
+       { 0xfc06, KEY_EPG },
+       { 0xfc5a, KEY_BACK },
+       { 0xfc05, KEY_MENU },
+       { 0xfc47, KEY_INFO },
+       { 0xfc01, KEY_TAB },
+       { 0xfc42, KEY_PREVIOUSSONG },/* Replay */
+       { 0xfc49, KEY_VOLUMEUP },
+       { 0xfc09, KEY_VOLUMEDOWN },
+       { 0xfc54, KEY_CHANNELUP },
+       { 0xfc0b, KEY_CHANNELDOWN },
+       { 0xfc16, KEY_CAMERA },
+       { 0xfc40, KEY_TUNER },  /* ATV/DTV */
+       { 0xfc45, KEY_OPEN },
+       { 0xfc19, KEY_1 },
+       { 0xfc18, KEY_2 },
+       { 0xfc1b, KEY_3 },
+       { 0xfc1a, KEY_4 },
+       { 0xfc58, KEY_5 },
+       { 0xfc59, KEY_6 },
+       { 0xfc15, KEY_7 },
+       { 0xfc14, KEY_8 },
+       { 0xfc17, KEY_9 },
+       { 0xfc44, KEY_ANGLE },  /* Aspect */
+       { 0xfc55, KEY_0 },
+       { 0xfc07, KEY_ZOOM },
+       { 0xfc0a, KEY_REWIND },
+       { 0xfc08, KEY_PLAYPAUSE },
+       { 0xfc4b, KEY_FASTFORWARD },
+       { 0xfc5b, KEY_MUTE },
+       { 0xfc04, KEY_STOP },
+       { 0xfc56, KEY_RECORD },
+       { 0xfc57, KEY_POWER },
+       { 0xfc41, KEY_UNKNOWN },    /* INPUT */
+       { 0xfc00, KEY_UNKNOWN },    /* HD */
 };
 
 static struct dvb_usb_rc_key d680_dmb_rc_keys[] = {
-       { 0x00, 0x38, KEY_UNKNOWN },    /* TV/AV */
-       { 0x08, 0x0c, KEY_ZOOM },
-       { 0x08, 0x00, KEY_0 },
-       { 0x00, 0x01, KEY_1 },
-       { 0x08, 0x02, KEY_2 },
-       { 0x00, 0x03, KEY_3 },
-       { 0x08, 0x04, KEY_4 },
-       { 0x00, 0x05, KEY_5 },
-       { 0x08, 0x06, KEY_6 },
-       { 0x00, 0x07, KEY_7 },
-       { 0x08, 0x08, KEY_8 },
-       { 0x00, 0x09, KEY_9 },
-       { 0x00, 0x0a, KEY_MUTE },
-       { 0x08, 0x29, KEY_BACK },
-       { 0x00, 0x12, KEY_CHANNELUP },
-       { 0x08, 0x13, KEY_CHANNELDOWN },
-       { 0x00, 0x2b, KEY_VOLUMEUP },
-       { 0x08, 0x2c, KEY_VOLUMEDOWN },
-       { 0x00, 0x20, KEY_UP },
-       { 0x08, 0x21, KEY_DOWN },
-       { 0x00, 0x11, KEY_LEFT },
-       { 0x08, 0x10, KEY_RIGHT },
-       { 0x00, 0x0d, KEY_OK },
-       { 0x08, 0x1f, KEY_RECORD },
-       { 0x00, 0x17, KEY_PLAYPAUSE },
-       { 0x08, 0x16, KEY_PLAYPAUSE },
-       { 0x00, 0x0b, KEY_STOP },
-       { 0x08, 0x27, KEY_FASTFORWARD },
-       { 0x00, 0x26, KEY_REWIND },
-       { 0x08, 0x1e, KEY_UNKNOWN },    /* Time Shift */
-       { 0x00, 0x0e, KEY_UNKNOWN },    /* Snapshot */
-       { 0x08, 0x2d, KEY_UNKNOWN },    /* Mouse Cursor */
-       { 0x00, 0x0f, KEY_UNKNOWN },    /* Minimize/Maximize */
-       { 0x08, 0x14, KEY_UNKNOWN },    /* Shuffle */
-       { 0x00, 0x25, KEY_POWER },
+       { 0x0038, KEY_UNKNOWN },        /* TV/AV */
+       { 0x080c, KEY_ZOOM },
+       { 0x0800, KEY_0 },
+       { 0x0001, KEY_1 },
+       { 0x0802, KEY_2 },
+       { 0x0003, KEY_3 },
+       { 0x0804, KEY_4 },
+       { 0x0005, KEY_5 },
+       { 0x0806, KEY_6 },
+       { 0x0007, KEY_7 },
+       { 0x0808, KEY_8 },
+       { 0x0009, KEY_9 },
+       { 0x000a, KEY_MUTE },
+       { 0x0829, KEY_BACK },
+       { 0x0012, KEY_CHANNELUP },
+       { 0x0813, KEY_CHANNELDOWN },
+       { 0x002b, KEY_VOLUMEUP },
+       { 0x082c, KEY_VOLUMEDOWN },
+       { 0x0020, KEY_UP },
+       { 0x0821, KEY_DOWN },
+       { 0x0011, KEY_LEFT },
+       { 0x0810, KEY_RIGHT },
+       { 0x000d, KEY_OK },
+       { 0x081f, KEY_RECORD },
+       { 0x0017, KEY_PLAYPAUSE },
+       { 0x0816, KEY_PLAYPAUSE },
+       { 0x000b, KEY_STOP },
+       { 0x0827, KEY_FASTFORWARD },
+       { 0x0026, KEY_REWIND },
+       { 0x081e, KEY_UNKNOWN },    /* Time Shift */
+       { 0x000e, KEY_UNKNOWN },    /* Snapshot */
+       { 0x082d, KEY_UNKNOWN },    /* Mouse Cursor */
+       { 0x000f, KEY_UNKNOWN },    /* Minimize/Maximize */
+       { 0x0814, KEY_UNKNOWN },    /* Shuffle */
+       { 0x0025, KEY_POWER },
 };
 
 static int cxusb_dee1601_demod_init(struct dvb_frontend* fe)
index 7b0263f..d1d6f44 100644 (file)
@@ -509,7 +509,8 @@ static int dib0700_rc_query_legacy(struct dvb_usb_device *d, u32 *event,
                        return 0;
                }
                for (i=0;i<d->props.rc_key_map_size; i++) {
-                       if (keymap[i].custom == key[3-2] && keymap[i].data == key[3-3]) {
+                       if (rc5_custom(&keymap[i]) == key[3-2] &&
+                           rc5_data(&keymap[i]) == key[3-3]) {
                                st->rc_counter = 0;
                                *event = keymap[i].event;
                                *state = REMOTE_KEY_PRESSED;
@@ -522,7 +523,8 @@ static int dib0700_rc_query_legacy(struct dvb_usb_device *d, u32 *event,
        default: {
                /* RC-5 protocol changes toggle bit on new keypress */
                for (i = 0; i < d->props.rc_key_map_size; i++) {
-                       if (keymap[i].custom == key[3-2] && keymap[i].data == key[3-3]) {
+                       if (rc5_custom(&keymap[i]) == key[3-2] &&
+                           rc5_data(&keymap[i]) == key[3-3]) {
                                if (d->last_event == keymap[i].event &&
                                        key[3-1] == st->rc_toggle) {
                                        st->rc_counter++;
@@ -616,8 +618,8 @@ static int dib0700_rc_query_v1_20(struct dvb_usb_device *d, u32 *event,
 
        /* Find the key in the map */
        for (i = 0; i < d->props.rc_key_map_size; i++) {
-               if (keymap[i].custom == poll_reply.system_lsb &&
-                   keymap[i].data == poll_reply.data) {
+               if (rc5_custom(&keymap[i]) == poll_reply.system_lsb &&
+                   rc5_data(&keymap[i]) == poll_reply.data) {
                        *event = keymap[i].event;
                        found = 1;
                        break;
@@ -684,193 +686,193 @@ static int dib0700_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
 
 static struct dvb_usb_rc_key dib0700_rc_keys[] = {
        /* Key codes for the tiny Pinnacle remote*/
-       { 0x07, 0x00, KEY_MUTE },
-       { 0x07, 0x01, KEY_MENU }, // Pinnacle logo
-       { 0x07, 0x39, KEY_POWER },
-       { 0x07, 0x03, KEY_VOLUMEUP },
-       { 0x07, 0x09, KEY_VOLUMEDOWN },
-       { 0x07, 0x06, KEY_CHANNELUP },
-       { 0x07, 0x0c, KEY_CHANNELDOWN },
-       { 0x07, 0x0f, KEY_1 },
-       { 0x07, 0x15, KEY_2 },
-       { 0x07, 0x10, KEY_3 },
-       { 0x07, 0x18, KEY_4 },
-       { 0x07, 0x1b, KEY_5 },
-       { 0x07, 0x1e, KEY_6 },
-       { 0x07, 0x11, KEY_7 },
-       { 0x07, 0x21, KEY_8 },
-       { 0x07, 0x12, KEY_9 },
-       { 0x07, 0x27, KEY_0 },
-       { 0x07, 0x24, KEY_SCREEN }, // 'Square' key
-       { 0x07, 0x2a, KEY_TEXT },   // 'T' key
-       { 0x07, 0x2d, KEY_REWIND },
-       { 0x07, 0x30, KEY_PLAY },
-       { 0x07, 0x33, KEY_FASTFORWARD },
-       { 0x07, 0x36, KEY_RECORD },
-       { 0x07, 0x3c, KEY_STOP },
-       { 0x07, 0x3f, KEY_CANCEL }, // '?' key
+       { 0x0700, KEY_MUTE },
+       { 0x0701, KEY_MENU }, /* Pinnacle logo */
+       { 0x0739, KEY_POWER },
+       { 0x0703, KEY_VOLUMEUP },
+       { 0x0709, KEY_VOLUMEDOWN },
+       { 0x0706, KEY_CHANNELUP },
+       { 0x070c, KEY_CHANNELDOWN },
+       { 0x070f, KEY_1 },
+       { 0x0715, KEY_2 },
+       { 0x0710, KEY_3 },
+       { 0x0718, KEY_4 },
+       { 0x071b, KEY_5 },
+       { 0x071e, KEY_6 },
+       { 0x0711, KEY_7 },
+       { 0x0721, KEY_8 },
+       { 0x0712, KEY_9 },
+       { 0x0727, KEY_0 },
+       { 0x0724, KEY_SCREEN }, /* 'Square' key */
+       { 0x072a, KEY_TEXT },   /* 'T' key */
+       { 0x072d, KEY_REWIND },
+       { 0x0730, KEY_PLAY },
+       { 0x0733, KEY_FASTFORWARD },
+       { 0x0736, KEY_RECORD },
+       { 0x073c, KEY_STOP },
+       { 0x073f, KEY_CANCEL }, /* '?' key */
        /* Key codes for the Terratec Cinergy DT XS Diversity, similar to cinergyT2.c */
-       { 0xeb, 0x01, KEY_POWER },
-       { 0xeb, 0x02, KEY_1 },
-       { 0xeb, 0x03, KEY_2 },
-       { 0xeb, 0x04, KEY_3 },
-       { 0xeb, 0x05, KEY_4 },
-       { 0xeb, 0x06, KEY_5 },
-       { 0xeb, 0x07, KEY_6 },
-       { 0xeb, 0x08, KEY_7 },
-       { 0xeb, 0x09, KEY_8 },
-       { 0xeb, 0x0a, KEY_9 },
-       { 0xeb, 0x0b, KEY_VIDEO },
-       { 0xeb, 0x0c, KEY_0 },
-       { 0xeb, 0x0d, KEY_REFRESH },
-       { 0xeb, 0x0f, KEY_EPG },
-       { 0xeb, 0x10, KEY_UP },
-       { 0xeb, 0x11, KEY_LEFT },
-       { 0xeb, 0x12, KEY_OK },
-       { 0xeb, 0x13, KEY_RIGHT },
-       { 0xeb, 0x14, KEY_DOWN },
-       { 0xeb, 0x16, KEY_INFO },
-       { 0xeb, 0x17, KEY_RED },
-       { 0xeb, 0x18, KEY_GREEN },
-       { 0xeb, 0x19, KEY_YELLOW },
-       { 0xeb, 0x1a, KEY_BLUE },
-       { 0xeb, 0x1b, KEY_CHANNELUP },
-       { 0xeb, 0x1c, KEY_VOLUMEUP },
-       { 0xeb, 0x1d, KEY_MUTE },
-       { 0xeb, 0x1e, KEY_VOLUMEDOWN },
-       { 0xeb, 0x1f, KEY_CHANNELDOWN },
-       { 0xeb, 0x40, KEY_PAUSE },
-       { 0xeb, 0x41, KEY_HOME },
-       { 0xeb, 0x42, KEY_MENU }, /* DVD Menu */
-       { 0xeb, 0x43, KEY_SUBTITLE },
-       { 0xeb, 0x44, KEY_TEXT }, /* Teletext */
-       { 0xeb, 0x45, KEY_DELETE },
-       { 0xeb, 0x46, KEY_TV },
-       { 0xeb, 0x47, KEY_DVD },
-       { 0xeb, 0x48, KEY_STOP },
-       { 0xeb, 0x49, KEY_VIDEO },
-       { 0xeb, 0x4a, KEY_AUDIO }, /* Music */
-       { 0xeb, 0x4b, KEY_SCREEN }, /* Pic */
-       { 0xeb, 0x4c, KEY_PLAY },
-       { 0xeb, 0x4d, KEY_BACK },
-       { 0xeb, 0x4e, KEY_REWIND },
-       { 0xeb, 0x4f, KEY_FASTFORWARD },
-       { 0xeb, 0x54, KEY_PREVIOUS },
-       { 0xeb, 0x58, KEY_RECORD },
-       { 0xeb, 0x5c, KEY_NEXT },
+       { 0xeb01, KEY_POWER },
+       { 0xeb02, KEY_1 },
+       { 0xeb03, KEY_2 },
+       { 0xeb04, KEY_3 },
+       { 0xeb05, KEY_4 },
+       { 0xeb06, KEY_5 },
+       { 0xeb07, KEY_6 },
+       { 0xeb08, KEY_7 },
+       { 0xeb09, KEY_8 },
+       { 0xeb0a, KEY_9 },
+       { 0xeb0b, KEY_VIDEO },
+       { 0xeb0c, KEY_0 },
+       { 0xeb0d, KEY_REFRESH },
+       { 0xeb0f, KEY_EPG },
+       { 0xeb10, KEY_UP },
+       { 0xeb11, KEY_LEFT },
+       { 0xeb12, KEY_OK },
+       { 0xeb13, KEY_RIGHT },
+       { 0xeb14, KEY_DOWN },
+       { 0xeb16, KEY_INFO },
+       { 0xeb17, KEY_RED },
+       { 0xeb18, KEY_GREEN },
+       { 0xeb19, KEY_YELLOW },
+       { 0xeb1a, KEY_BLUE },
+       { 0xeb1b, KEY_CHANNELUP },
+       { 0xeb1c, KEY_VOLUMEUP },
+       { 0xeb1d, KEY_MUTE },
+       { 0xeb1e, KEY_VOLUMEDOWN },
+       { 0xeb1f, KEY_CHANNELDOWN },
+       { 0xeb40, KEY_PAUSE },
+       { 0xeb41, KEY_HOME },
+       { 0xeb42, KEY_MENU }, /* DVD Menu */
+       { 0xeb43, KEY_SUBTITLE },
+       { 0xeb44, KEY_TEXT }, /* Teletext */
+       { 0xeb45, KEY_DELETE },
+       { 0xeb46, KEY_TV },
+       { 0xeb47, KEY_DVD },
+       { 0xeb48, KEY_STOP },
+       { 0xeb49, KEY_VIDEO },
+       { 0xeb4a, KEY_AUDIO }, /* Music */
+       { 0xeb4b, KEY_SCREEN }, /* Pic */
+       { 0xeb4c, KEY_PLAY },
+       { 0xeb4d, KEY_BACK },
+       { 0xeb4e, KEY_REWIND },
+       { 0xeb4f, KEY_FASTFORWARD },
+       { 0xeb54, KEY_PREVIOUS },
+       { 0xeb58, KEY_RECORD },
+       { 0xeb5c, KEY_NEXT },
 
        /* Key codes for the Haupauge WinTV Nova-TD, copied from nova-t-usb2.c (Nova-T USB2) */
-       { 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 },
+       { 0x1e00, KEY_0 },
+       { 0x1e01, KEY_1 },
+       { 0x1e02, KEY_2 },
+       { 0x1e03, KEY_3 },
+       { 0x1e04, KEY_4 },
+       { 0x1e05, KEY_5 },
+       { 0x1e06, KEY_6 },
+       { 0x1e07, KEY_7 },
+       { 0x1e08, KEY_8 },
+       { 0x1e09, KEY_9 },
+       { 0x1e0a, KEY_KPASTERISK },
+       { 0x1e0b, KEY_RED },
+       { 0x1e0c, KEY_RADIO },
+       { 0x1e0d, KEY_MENU },
+       { 0x1e0e, KEY_GRAVE }, /* # */
+       { 0x1e0f, KEY_MUTE },
+       { 0x1e10, KEY_VOLUMEUP },
+       { 0x1e11, KEY_VOLUMEDOWN },
+       { 0x1e12, KEY_CHANNEL },
+       { 0x1e14, KEY_UP },
+       { 0x1e15, KEY_DOWN },
+       { 0x1e16, KEY_LEFT },
+       { 0x1e17, KEY_RIGHT },
+       { 0x1e18, KEY_VIDEO },
+       { 0x1e19, KEY_AUDIO },
+       { 0x1e1a, KEY_MEDIA },
+       { 0x1e1b, KEY_EPG },
+       { 0x1e1c, KEY_TV },
+       { 0x1e1e, KEY_NEXT },
+       { 0x1e1f, KEY_BACK },
+       { 0x1e20, KEY_CHANNELUP },
+       { 0x1e21, KEY_CHANNELDOWN },
+       { 0x1e24, KEY_LAST }, /* Skip backwards */
+       { 0x1e25, KEY_OK },
+       { 0x1e29, KEY_BLUE},
+       { 0x1e2e, KEY_GREEN },
+       { 0x1e30, KEY_PAUSE },
+       { 0x1e32, KEY_REWIND },
+       { 0x1e34, KEY_FASTFORWARD },
+       { 0x1e35, KEY_PLAY },
+       { 0x1e36, KEY_STOP },
+       { 0x1e37, KEY_RECORD },
+       { 0x1e38, KEY_YELLOW },
+       { 0x1e3b, KEY_GOTO },
+       { 0x1e3d, KEY_POWER },
 
        /* Key codes for the Leadtek Winfast DTV Dongle */
-       { 0x00, 0x42, KEY_POWER },
-       { 0x07, 0x7c, KEY_TUNER },
-       { 0x0f, 0x4e, KEY_PRINT }, /* PREVIEW */
-       { 0x08, 0x40, KEY_SCREEN }, /* full screen toggle*/
-       { 0x0f, 0x71, KEY_DOT }, /* frequency */
-       { 0x07, 0x43, KEY_0 },
-       { 0x0c, 0x41, KEY_1 },
-       { 0x04, 0x43, KEY_2 },
-       { 0x0b, 0x7f, KEY_3 },
-       { 0x0e, 0x41, KEY_4 },
-       { 0x06, 0x43, KEY_5 },
-       { 0x09, 0x7f, KEY_6 },
-       { 0x0d, 0x7e, KEY_7 },
-       { 0x05, 0x7c, KEY_8 },
-       { 0x0a, 0x40, KEY_9 },
-       { 0x0e, 0x4e, KEY_CLEAR },
-       { 0x04, 0x7c, KEY_CHANNEL }, /* show channel number */
-       { 0x0f, 0x41, KEY_LAST }, /* recall */
-       { 0x03, 0x42, KEY_MUTE },
-       { 0x06, 0x4c, KEY_RESERVED }, /* PIP button*/
-       { 0x01, 0x72, KEY_SHUFFLE }, /* SNAPSHOT */
-       { 0x0c, 0x4e, KEY_PLAYPAUSE }, /* TIMESHIFT */
-       { 0x0b, 0x70, KEY_RECORD },
-       { 0x03, 0x7d, KEY_VOLUMEUP },
-       { 0x01, 0x7d, KEY_VOLUMEDOWN },
-       { 0x02, 0x42, KEY_CHANNELUP },
-       { 0x00, 0x7d, KEY_CHANNELDOWN },
+       { 0x0042, KEY_POWER },
+       { 0x077c, KEY_TUNER },
+       { 0x0f4e, KEY_PRINT }, /* PREVIEW */
+       { 0x0840, KEY_SCREEN }, /* full screen toggle*/
+       { 0x0f71, KEY_DOT }, /* frequency */
+       { 0x0743, KEY_0 },
+       { 0x0c41, KEY_1 },
+       { 0x0443, KEY_2 },
+       { 0x0b7f, KEY_3 },
+       { 0x0e41, KEY_4 },
+       { 0x0643, KEY_5 },
+       { 0x097f, KEY_6 },
+       { 0x0d7e, KEY_7 },
+       { 0x057c, KEY_8 },
+       { 0x0a40, KEY_9 },
+       { 0x0e4e, KEY_CLEAR },
+       { 0x047c, KEY_CHANNEL }, /* show channel number */
+       { 0x0f41, KEY_LAST }, /* recall */
+       { 0x0342, KEY_MUTE },
+       { 0x064c, KEY_RESERVED }, /* PIP button*/
+       { 0x0172, KEY_SHUFFLE }, /* SNAPSHOT */
+       { 0x0c4e, KEY_PLAYPAUSE }, /* TIMESHIFT */
+       { 0x0b70, KEY_RECORD },
+       { 0x037d, KEY_VOLUMEUP },
+       { 0x017d, KEY_VOLUMEDOWN },
+       { 0x0242, KEY_CHANNELUP },
+       { 0x007d, KEY_CHANNELDOWN },
 
        /* Key codes for Nova-TD "credit card" remote control. */
-       { 0x1d, 0x00, KEY_0 },
-       { 0x1d, 0x01, KEY_1 },
-       { 0x1d, 0x02, KEY_2 },
-       { 0x1d, 0x03, KEY_3 },
-       { 0x1d, 0x04, KEY_4 },
-       { 0x1d, 0x05, KEY_5 },
-       { 0x1d, 0x06, KEY_6 },
-       { 0x1d, 0x07, KEY_7 },
-       { 0x1d, 0x08, KEY_8 },
-       { 0x1d, 0x09, KEY_9 },
-       { 0x1d, 0x0a, KEY_TEXT },
-       { 0x1d, 0x0d, KEY_MENU },
-       { 0x1d, 0x0f, KEY_MUTE },
-       { 0x1d, 0x10, KEY_VOLUMEUP },
-       { 0x1d, 0x11, KEY_VOLUMEDOWN },
-       { 0x1d, 0x12, KEY_CHANNEL },
-       { 0x1d, 0x14, KEY_UP },
-       { 0x1d, 0x15, KEY_DOWN },
-       { 0x1d, 0x16, KEY_LEFT },
-       { 0x1d, 0x17, KEY_RIGHT },
-       { 0x1d, 0x1c, KEY_TV },
-       { 0x1d, 0x1e, KEY_NEXT },
-       { 0x1d, 0x1f, KEY_BACK },
-       { 0x1d, 0x20, KEY_CHANNELUP },
-       { 0x1d, 0x21, KEY_CHANNELDOWN },
-       { 0x1d, 0x24, KEY_LAST },
-       { 0x1d, 0x25, KEY_OK },
-       { 0x1d, 0x30, KEY_PAUSE },
-       { 0x1d, 0x32, KEY_REWIND },
-       { 0x1d, 0x34, KEY_FASTFORWARD },
-       { 0x1d, 0x35, KEY_PLAY },
-       { 0x1d, 0x36, KEY_STOP },
-       { 0x1d, 0x37, KEY_RECORD },
-       { 0x1d, 0x3b, KEY_GOTO },
-       { 0x1d, 0x3d, KEY_POWER },
+       { 0x1d00, KEY_0 },
+       { 0x1d01, KEY_1 },
+       { 0x1d02, KEY_2 },
+       { 0x1d03, KEY_3 },
+       { 0x1d04, KEY_4 },
+       { 0x1d05, KEY_5 },
+       { 0x1d06, KEY_6 },
+       { 0x1d07, KEY_7 },
+       { 0x1d08, KEY_8 },
+       { 0x1d09, KEY_9 },
+       { 0x1d0a, KEY_TEXT },
+       { 0x1d0d, KEY_MENU },
+       { 0x1d0f, KEY_MUTE },
+       { 0x1d10, KEY_VOLUMEUP },
+       { 0x1d11, KEY_VOLUMEDOWN },
+       { 0x1d12, KEY_CHANNEL },
+       { 0x1d14, KEY_UP },
+       { 0x1d15, KEY_DOWN },
+       { 0x1d16, KEY_LEFT },
+       { 0x1d17, KEY_RIGHT },
+       { 0x1d1c, KEY_TV },
+       { 0x1d1e, KEY_NEXT },
+       { 0x1d1f, KEY_BACK },
+       { 0x1d20, KEY_CHANNELUP },
+       { 0x1d21, KEY_CHANNELDOWN },
+       { 0x1d24, KEY_LAST },
+       { 0x1d25, KEY_OK },
+       { 0x1d30, KEY_PAUSE },
+       { 0x1d32, KEY_REWIND },
+       { 0x1d34, KEY_FASTFORWARD },
+       { 0x1d35, KEY_PLAY },
+       { 0x1d36, KEY_STOP },
+       { 0x1d37, KEY_RECORD },
+       { 0x1d3b, KEY_GOTO },
+       { 0x1d3d, KEY_POWER },
 };
 
 /* STK7700P: Hauppauge Nova-T Stick, AVerMedia Volar */
index 8dbad1e..da34979 100644 (file)
@@ -318,132 +318,132 @@ EXPORT_SYMBOL(dibusb_dib3000mc_tuner_attach);
  */
 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 },
-       { 0x00, 0x03, KEY_1 },
-       { 0x00, 0x01, KEY_2 },
-       { 0x00, 0x06, KEY_3 },
-       { 0x00, 0x09, KEY_4 },
-       { 0x00, 0x1d, KEY_5 },
-       { 0x00, 0x1f, KEY_6 },
-       { 0x00, 0x0d, KEY_7 },
-       { 0x00, 0x19, KEY_8 },
-       { 0x00, 0x1b, KEY_9 },
-       { 0x00, 0x15, KEY_0 },
-       { 0x00, 0x05, KEY_CHANNELUP },
-       { 0x00, 0x02, KEY_CHANNELDOWN },
-       { 0x00, 0x1e, KEY_VOLUMEUP },
-       { 0x00, 0x0a, KEY_VOLUMEDOWN },
-       { 0x00, 0x11, KEY_RECORD },
-       { 0x00, 0x17, KEY_FAVORITES }, /* Heart symbol - Channel list. */
-       { 0x00, 0x14, KEY_PLAY },
-       { 0x00, 0x1a, KEY_STOP },
-       { 0x00, 0x40, KEY_REWIND },
-       { 0x00, 0x12, KEY_FASTFORWARD },
-       { 0x00, 0x0e, KEY_PREVIOUS }, /* Recall - Previous channel. */
-       { 0x00, 0x4c, KEY_PAUSE },
-       { 0x00, 0x4d, KEY_SCREEN }, /* Full screen mode. */
-       { 0x00, 0x54, KEY_AUDIO }, /* MTS - Switch to secondary audio. */
+       { 0x0016, KEY_POWER },
+       { 0x0010, KEY_MUTE },
+       { 0x0003, KEY_1 },
+       { 0x0001, KEY_2 },
+       { 0x0006, KEY_3 },
+       { 0x0009, KEY_4 },
+       { 0x001d, KEY_5 },
+       { 0x001f, KEY_6 },
+       { 0x000d, KEY_7 },
+       { 0x0019, KEY_8 },
+       { 0x001b, KEY_9 },
+       { 0x0015, KEY_0 },
+       { 0x0005, KEY_CHANNELUP },
+       { 0x0002, KEY_CHANNELDOWN },
+       { 0x001e, KEY_VOLUMEUP },
+       { 0x000a, KEY_VOLUMEDOWN },
+       { 0x0011, KEY_RECORD },
+       { 0x0017, KEY_FAVORITES }, /* Heart symbol - Channel list. */
+       { 0x0014, KEY_PLAY },
+       { 0x001a, KEY_STOP },
+       { 0x0040, KEY_REWIND },
+       { 0x0012, KEY_FASTFORWARD },
+       { 0x000e, KEY_PREVIOUS }, /* Recall - Previous channel. */
+       { 0x004c, KEY_PAUSE },
+       { 0x004d, KEY_SCREEN }, /* Full screen mode. */
+       { 0x0054, KEY_AUDIO }, /* MTS - Switch to secondary audio. */
        /* additional keys TwinHan VisionPlus, the Artec seemingly not have */
-       { 0x00, 0x0c, KEY_CANCEL }, /* Cancel */
-       { 0x00, 0x1c, KEY_EPG }, /* EPG */
-       { 0x00, 0x00, KEY_TAB }, /* Tab */
-       { 0x00, 0x48, KEY_INFO }, /* Preview */
-       { 0x00, 0x04, KEY_LIST }, /* RecordList */
-       { 0x00, 0x0f, KEY_TEXT }, /* Teletext */
+       { 0x000c, KEY_CANCEL }, /* Cancel */
+       { 0x001c, KEY_EPG }, /* EPG */
+       { 0x0000, KEY_TAB }, /* Tab */
+       { 0x0048, KEY_INFO }, /* Preview */
+       { 0x0004, KEY_LIST }, /* RecordList */
+       { 0x000f, KEY_TEXT }, /* Teletext */
        /* Key codes for the KWorld/ADSTech/JetWay remote. */
-       { 0x86, 0x12, KEY_POWER },
-       { 0x86, 0x0f, KEY_SELECT }, /* source */
-       { 0x86, 0x0c, KEY_UNKNOWN }, /* scan */
-       { 0x86, 0x0b, KEY_EPG },
-       { 0x86, 0x10, KEY_MUTE },
-       { 0x86, 0x01, KEY_1 },
-       { 0x86, 0x02, KEY_2 },
-       { 0x86, 0x03, KEY_3 },
-       { 0x86, 0x04, KEY_4 },
-       { 0x86, 0x05, KEY_5 },
-       { 0x86, 0x06, KEY_6 },
-       { 0x86, 0x07, KEY_7 },
-       { 0x86, 0x08, KEY_8 },
-       { 0x86, 0x09, KEY_9 },
-       { 0x86, 0x0a, KEY_0 },
-       { 0x86, 0x18, KEY_ZOOM },
-       { 0x86, 0x1c, KEY_UNKNOWN }, /* preview */
-       { 0x86, 0x13, KEY_UNKNOWN }, /* snap */
-       { 0x86, 0x00, KEY_UNDO },
-       { 0x86, 0x1d, KEY_RECORD },
-       { 0x86, 0x0d, KEY_STOP },
-       { 0x86, 0x0e, KEY_PAUSE },
-       { 0x86, 0x16, KEY_PLAY },
-       { 0x86, 0x11, KEY_BACK },
-       { 0x86, 0x19, KEY_FORWARD },
-       { 0x86, 0x14, KEY_UNKNOWN }, /* pip */
-       { 0x86, 0x15, KEY_ESC },
-       { 0x86, 0x1a, KEY_UP },
-       { 0x86, 0x1e, KEY_DOWN },
-       { 0x86, 0x1f, KEY_LEFT },
-       { 0x86, 0x1b, KEY_RIGHT },
+       { 0x8612, KEY_POWER },
+       { 0x860f, KEY_SELECT }, /* source */
+       { 0x860c, KEY_UNKNOWN }, /* scan */
+       { 0x860b, KEY_EPG },
+       { 0x8610, KEY_MUTE },
+       { 0x8601, KEY_1 },
+       { 0x8602, KEY_2 },
+       { 0x8603, KEY_3 },
+       { 0x8604, KEY_4 },
+       { 0x8605, KEY_5 },
+       { 0x8606, KEY_6 },
+       { 0x8607, KEY_7 },
+       { 0x8608, KEY_8 },
+       { 0x8609, KEY_9 },
+       { 0x860a, KEY_0 },
+       { 0x8618, KEY_ZOOM },
+       { 0x861c, KEY_UNKNOWN }, /* preview */
+       { 0x8613, KEY_UNKNOWN }, /* snap */
+       { 0x8600, KEY_UNDO },
+       { 0x861d, KEY_RECORD },
+       { 0x860d, KEY_STOP },
+       { 0x860e, KEY_PAUSE },
+       { 0x8616, KEY_PLAY },
+       { 0x8611, KEY_BACK },
+       { 0x8619, KEY_FORWARD },
+       { 0x8614, KEY_UNKNOWN }, /* pip */
+       { 0x8615, KEY_ESC },
+       { 0x861a, KEY_UP },
+       { 0x861e, KEY_DOWN },
+       { 0x861f, KEY_LEFT },
+       { 0x861b, KEY_RIGHT },
 
        /* Key codes for the DiBcom MOD3000 remote. */
-       { 0x80, 0x00, KEY_MUTE },
-       { 0x80, 0x01, KEY_TEXT },
-       { 0x80, 0x02, KEY_HOME },
-       { 0x80, 0x03, KEY_POWER },
-
-       { 0x80, 0x04, KEY_RED },
-       { 0x80, 0x05, KEY_GREEN },
-       { 0x80, 0x06, KEY_YELLOW },
-       { 0x80, 0x07, KEY_BLUE },
-
-       { 0x80, 0x08, KEY_DVD },
-       { 0x80, 0x09, KEY_AUDIO },
-       { 0x80, 0x0a, KEY_MEDIA },      /* Pictures */
-       { 0x80, 0x0b, KEY_VIDEO },
-
-       { 0x80, 0x0c, KEY_BACK },
-       { 0x80, 0x0d, KEY_UP },
-       { 0x80, 0x0e, KEY_RADIO },
-       { 0x80, 0x0f, KEY_EPG },
-
-       { 0x80, 0x10, KEY_LEFT },
-       { 0x80, 0x11, KEY_OK },
-       { 0x80, 0x12, KEY_RIGHT },
-       { 0x80, 0x13, KEY_UNKNOWN },    /* SAP */
-
-       { 0x80, 0x14, KEY_TV },
-       { 0x80, 0x15, KEY_DOWN },
-       { 0x80, 0x16, KEY_MENU },       /* DVD Menu */
-       { 0x80, 0x17, KEY_LAST },
-
-       { 0x80, 0x18, KEY_RECORD },
-       { 0x80, 0x19, KEY_STOP },
-       { 0x80, 0x1a, KEY_PAUSE },
-       { 0x80, 0x1b, KEY_PLAY },
-
-       { 0x80, 0x1c, KEY_PREVIOUS },
-       { 0x80, 0x1d, KEY_REWIND },
-       { 0x80, 0x1e, KEY_FASTFORWARD },
-       { 0x80, 0x1f, KEY_NEXT},
-
-       { 0x80, 0x40, KEY_1 },
-       { 0x80, 0x41, KEY_2 },
-       { 0x80, 0x42, KEY_3 },
-       { 0x80, 0x43, KEY_CHANNELUP },
-
-       { 0x80, 0x44, KEY_4 },
-       { 0x80, 0x45, KEY_5 },
-       { 0x80, 0x46, KEY_6 },
-       { 0x80, 0x47, KEY_CHANNELDOWN },
-
-       { 0x80, 0x48, KEY_7 },
-       { 0x80, 0x49, KEY_8 },
-       { 0x80, 0x4a, KEY_9 },
-       { 0x80, 0x4b, KEY_VOLUMEUP },
-
-       { 0x80, 0x4c, KEY_CLEAR },
-       { 0x80, 0x4d, KEY_0 },
-       { 0x80, 0x4e, KEY_ENTER },
-       { 0x80, 0x4f, KEY_VOLUMEDOWN },
+       { 0x8000, KEY_MUTE },
+       { 0x8001, KEY_TEXT },
+       { 0x8002, KEY_HOME },
+       { 0x8003, KEY_POWER },
+
+       { 0x8004, KEY_RED },
+       { 0x8005, KEY_GREEN },
+       { 0x8006, KEY_YELLOW },
+       { 0x8007, KEY_BLUE },
+
+       { 0x8008, KEY_DVD },
+       { 0x8009, KEY_AUDIO },
+       { 0x800a, KEY_MEDIA },      /* Pictures */
+       { 0x800b, KEY_VIDEO },
+
+       { 0x800c, KEY_BACK },
+       { 0x800d, KEY_UP },
+       { 0x800e, KEY_RADIO },
+       { 0x800f, KEY_EPG },
+
+       { 0x8010, KEY_LEFT },
+       { 0x8011, KEY_OK },
+       { 0x8012, KEY_RIGHT },
+       { 0x8013, KEY_UNKNOWN },    /* SAP */
+
+       { 0x8014, KEY_TV },
+       { 0x8015, KEY_DOWN },
+       { 0x8016, KEY_MENU },       /* DVD Menu */
+       { 0x8017, KEY_LAST },
+
+       { 0x8018, KEY_RECORD },
+       { 0x8019, KEY_STOP },
+       { 0x801a, KEY_PAUSE },
+       { 0x801b, KEY_PLAY },
+
+       { 0x801c, KEY_PREVIOUS },
+       { 0x801d, KEY_REWIND },
+       { 0x801e, KEY_FASTFORWARD },
+       { 0x801f, KEY_NEXT},
+
+       { 0x8040, KEY_1 },
+       { 0x8041, KEY_2 },
+       { 0x8042, KEY_3 },
+       { 0x8043, KEY_CHANNELUP },
+
+       { 0x8044, KEY_4 },
+       { 0x8045, KEY_5 },
+       { 0x8046, KEY_6 },
+       { 0x8047, KEY_CHANNELDOWN },
+
+       { 0x8048, KEY_7 },
+       { 0x8049, KEY_8 },
+       { 0x804a, KEY_9 },
+       { 0x804b, KEY_VOLUMEUP },
+
+       { 0x804c, KEY_CLEAR },
+       { 0x804d, KEY_0 },
+       { 0x804e, KEY_ENTER },
+       { 0x804f, KEY_VOLUMEDOWN },
 };
 EXPORT_SYMBOL(dibusb_rc_keys);
 
index b545cf3..955147d 100644 (file)
@@ -162,61 +162,61 @@ static int digitv_tuner_attach(struct dvb_usb_adapter *adap)
 }
 
 static struct dvb_usb_rc_key digitv_rc_keys[] = {
-       { 0x5f, 0x55, KEY_0 },
-       { 0x6f, 0x55, KEY_1 },
-       { 0x9f, 0x55, KEY_2 },
-       { 0xaf, 0x55, KEY_3 },
-       { 0x5f, 0x56, KEY_4 },
-       { 0x6f, 0x56, KEY_5 },
-       { 0x9f, 0x56, KEY_6 },
-       { 0xaf, 0x56, KEY_7 },
-       { 0x5f, 0x59, KEY_8 },
-       { 0x6f, 0x59, KEY_9 },
-       { 0x9f, 0x59, KEY_TV },
-       { 0xaf, 0x59, KEY_AUX },
-       { 0x5f, 0x5a, KEY_DVD },
-       { 0x6f, 0x5a, KEY_POWER },
-       { 0x9f, 0x5a, KEY_MHP },     /* labelled 'Picture' */
-       { 0xaf, 0x5a, KEY_AUDIO },
-       { 0x5f, 0x65, KEY_INFO },
-       { 0x6f, 0x65, KEY_F13 },     /* 16:9 */
-       { 0x9f, 0x65, KEY_F14 },     /* 14:9 */
-       { 0xaf, 0x65, KEY_EPG },
-       { 0x5f, 0x66, KEY_EXIT },
-       { 0x6f, 0x66, KEY_MENU },
-       { 0x9f, 0x66, KEY_UP },
-       { 0xaf, 0x66, KEY_DOWN },
-       { 0x5f, 0x69, KEY_LEFT },
-       { 0x6f, 0x69, KEY_RIGHT },
-       { 0x9f, 0x69, KEY_ENTER },
-       { 0xaf, 0x69, KEY_CHANNELUP },
-       { 0x5f, 0x6a, KEY_CHANNELDOWN },
-       { 0x6f, 0x6a, KEY_VOLUMEUP },
-       { 0x9f, 0x6a, KEY_VOLUMEDOWN },
-       { 0xaf, 0x6a, KEY_RED },
-       { 0x5f, 0x95, KEY_GREEN },
-       { 0x6f, 0x95, KEY_YELLOW },
-       { 0x9f, 0x95, KEY_BLUE },
-       { 0xaf, 0x95, KEY_SUBTITLE },
-       { 0x5f, 0x96, KEY_F15 },     /* AD */
-       { 0x6f, 0x96, KEY_TEXT },
-       { 0x9f, 0x96, KEY_MUTE },
-       { 0xaf, 0x96, KEY_REWIND },
-       { 0x5f, 0x99, KEY_STOP },
-       { 0x6f, 0x99, KEY_PLAY },
-       { 0x9f, 0x99, KEY_FASTFORWARD },
-       { 0xaf, 0x99, KEY_F16 },     /* chapter */
-       { 0x5f, 0x9a, KEY_PAUSE },
-       { 0x6f, 0x9a, KEY_PLAY },
-       { 0x9f, 0x9a, KEY_RECORD },
-       { 0xaf, 0x9a, KEY_F17 },     /* picture in picture */
-       { 0x5f, 0xa5, KEY_KPPLUS },  /* zoom in */
-       { 0x6f, 0xa5, KEY_KPMINUS }, /* zoom out */
-       { 0x9f, 0xa5, KEY_F18 },     /* capture */
-       { 0xaf, 0xa5, KEY_F19 },     /* web */
-       { 0x5f, 0xa6, KEY_EMAIL },
-       { 0x6f, 0xa6, KEY_PHONE },
-       { 0x9f, 0xa6, KEY_PC },
+       { 0x5f55, KEY_0 },
+       { 0x6f55, KEY_1 },
+       { 0x9f55, KEY_2 },
+       { 0xaf55, KEY_3 },
+       { 0x5f56, KEY_4 },
+       { 0x6f56, KEY_5 },
+       { 0x9f56, KEY_6 },
+       { 0xaf56, KEY_7 },
+       { 0x5f59, KEY_8 },
+       { 0x6f59, KEY_9 },
+       { 0x9f59, KEY_TV },
+       { 0xaf59, KEY_AUX },
+       { 0x5f5a, KEY_DVD },
+       { 0x6f5a, KEY_POWER },
+       { 0x9f5a, KEY_MHP },     /* labelled 'Picture' */
+       { 0xaf5a, KEY_AUDIO },
+       { 0x5f65, KEY_INFO },
+       { 0x6f65, KEY_F13 },     /* 16:9 */
+       { 0x9f65, KEY_F14 },     /* 14:9 */
+       { 0xaf65, KEY_EPG },
+       { 0x5f66, KEY_EXIT },
+       { 0x6f66, KEY_MENU },
+       { 0x9f66, KEY_UP },
+       { 0xaf66, KEY_DOWN },
+       { 0x5f69, KEY_LEFT },
+       { 0x6f69, KEY_RIGHT },
+       { 0x9f69, KEY_ENTER },
+       { 0xaf69, KEY_CHANNELUP },
+       { 0x5f6a, KEY_CHANNELDOWN },
+       { 0x6f6a, KEY_VOLUMEUP },
+       { 0x9f6a, KEY_VOLUMEDOWN },
+       { 0xaf6a, KEY_RED },
+       { 0x5f95, KEY_GREEN },
+       { 0x6f95, KEY_YELLOW },
+       { 0x9f95, KEY_BLUE },
+       { 0xaf95, KEY_SUBTITLE },
+       { 0x5f96, KEY_F15 },     /* AD */
+       { 0x6f96, KEY_TEXT },
+       { 0x9f96, KEY_MUTE },
+       { 0xaf96, KEY_REWIND },
+       { 0x5f99, KEY_STOP },
+       { 0x6f99, KEY_PLAY },
+       { 0x9f99, KEY_FASTFORWARD },
+       { 0xaf99, KEY_F16 },     /* chapter */
+       { 0x5f9a, KEY_PAUSE },
+       { 0x6f9a, KEY_PLAY },
+       { 0x9f9a, KEY_RECORD },
+       { 0xaf9a, KEY_F17 },     /* picture in picture */
+       { 0x5fa5, KEY_KPPLUS },  /* zoom in */
+       { 0x6fa5, KEY_KPMINUS }, /* zoom out */
+       { 0x9fa5, KEY_F18 },     /* capture */
+       { 0xafa5, KEY_F19 },     /* web */
+       { 0x5fa6, KEY_EMAIL },
+       { 0x6fa6, KEY_PHONE },
+       { 0x9fa6, KEY_PC },
 };
 
 static int digitv_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
@@ -238,8 +238,8 @@ static int digitv_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        if (key[1] != 0)
        {
                  for (i = 0; i < d->props.rc_key_map_size; i++) {
-                       if (d->props.rc_key_map[i].custom == key[1] &&
-                           d->props.rc_key_map[i].data == key[2]) {
+                       if (rc5_custom(&d->props.rc_key_map[i]) == key[1] &&
+                           rc5_data(&d->props.rc_key_map[i]) == key[2]) {
                                *event = d->props.rc_key_map[i].event;
                                *state = REMOTE_KEY_PRESSED;
                                return 0;
index 81a6cbf..a1b12b0 100644 (file)
@@ -58,24 +58,24 @@ static int dtt200u_pid_filter(struct dvb_usb_adapter *adap, int index, u16 pid,
 /* remote control */
 /* key list for the tiny remote control (Yakumo, don't know about the others) */
 static struct dvb_usb_rc_key dtt200u_rc_keys[] = {
-       { 0x80, 0x01, KEY_MUTE },
-       { 0x80, 0x02, KEY_CHANNELDOWN },
-       { 0x80, 0x03, KEY_VOLUMEDOWN },
-       { 0x80, 0x04, KEY_1 },
-       { 0x80, 0x05, KEY_2 },
-       { 0x80, 0x06, KEY_3 },
-       { 0x80, 0x07, KEY_4 },
-       { 0x80, 0x08, KEY_5 },
-       { 0x80, 0x09, KEY_6 },
-       { 0x80, 0x0a, KEY_7 },
-       { 0x80, 0x0c, KEY_ZOOM },
-       { 0x80, 0x0d, KEY_0 },
-       { 0x80, 0x0e, KEY_SELECT },
-       { 0x80, 0x12, KEY_POWER },
-       { 0x80, 0x1a, KEY_CHANNELUP },
-       { 0x80, 0x1b, KEY_8 },
-       { 0x80, 0x1e, KEY_VOLUMEUP },
-       { 0x80, 0x1f, KEY_9 },
+       { 0x8001, KEY_MUTE },
+       { 0x8002, KEY_CHANNELDOWN },
+       { 0x8003, KEY_VOLUMEDOWN },
+       { 0x8004, KEY_1 },
+       { 0x8005, KEY_2 },
+       { 0x8006, KEY_3 },
+       { 0x8007, KEY_4 },
+       { 0x8008, KEY_5 },
+       { 0x8009, KEY_6 },
+       { 0x800a, KEY_7 },
+       { 0x800c, KEY_ZOOM },
+       { 0x800d, KEY_0 },
+       { 0x800e, KEY_SELECT },
+       { 0x8012, KEY_POWER },
+       { 0x801a, KEY_CHANNELUP },
+       { 0x801b, KEY_8 },
+       { 0x801e, KEY_VOLUMEUP },
+       { 0x801f, KEY_9 },
 };
 
 static int dtt200u_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
index c0c2c22..16aec8c 100644 (file)
@@ -178,8 +178,8 @@ int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *d,
                        }
                        /* See if we can match the raw key code. */
                        for (i = 0; i < d->props.rc_key_map_size; i++)
-                               if (keymap[i].custom == keybuf[1] &&
-                                       keymap[i].data == keybuf[3]) {
+                               if (rc5_custom(&keymap[i]) == keybuf[1] &&
+                                       rc5_data(&keymap[i]) == keybuf[3]) {
                                        *event = keymap[i].event;
                                        *state = REMOTE_KEY_PRESSED;
                                        return 0;
index e441d27..fe2b87e 100644 (file)
@@ -81,10 +81,25 @@ struct dvb_usb_device_description {
  * @event: the input event assigned to key identified by custom and data
  */
 struct dvb_usb_rc_key {
-       u8 custom,data;
+       u16 scan;
        u32 event;
 };
 
+static inline u8 rc5_custom(struct dvb_usb_rc_key *key)
+{
+       return (key->scan >> 8) & 0xff;
+}
+
+static inline u8 rc5_data(struct dvb_usb_rc_key *key)
+{
+       return key->scan & 0xff;
+}
+
+static inline u8 rc5_scan(struct dvb_usb_rc_key *key)
+{
+       return key->scan & 0xffff;
+}
+
 struct dvb_usb_device;
 struct dvb_usb_adapter;
 struct usb_data_stream;
index d9424c3..5bb9479 100644 (file)
@@ -749,122 +749,122 @@ static int s630_zl10039_tuner_attach(struct dvb_usb_adapter *adap)
 }
 
 static struct dvb_usb_rc_key dw210x_rc_keys[] = {
-       { 0xf8, 0x0a, KEY_Q },          /*power*/
-       { 0xf8, 0x0c, KEY_M },          /*mute*/
-       { 0xf8, 0x11, KEY_1 },
-       { 0xf8, 0x12, KEY_2 },
-       { 0xf8, 0x13, KEY_3 },
-       { 0xf8, 0x14, KEY_4 },
-       { 0xf8, 0x15, KEY_5 },
-       { 0xf8, 0x16, KEY_6 },
-       { 0xf8, 0x17, KEY_7 },
-       { 0xf8, 0x18, KEY_8 },
-       { 0xf8, 0x19, KEY_9 },
-       { 0xf8, 0x10, KEY_0 },
-       { 0xf8, 0x1c, KEY_PAGEUP },     /*ch+*/
-       { 0xf8, 0x0f, KEY_PAGEDOWN },   /*ch-*/
-       { 0xf8, 0x1a, KEY_O },          /*vol+*/
-       { 0xf8, 0x0e, KEY_Z },          /*vol-*/
-       { 0xf8, 0x04, KEY_R },          /*rec*/
-       { 0xf8, 0x09, KEY_D },          /*fav*/
-       { 0xf8, 0x08, KEY_BACKSPACE },  /*rewind*/
-       { 0xf8, 0x07, KEY_A },          /*fast*/
-       { 0xf8, 0x0b, KEY_P },          /*pause*/
-       { 0xf8, 0x02, KEY_ESC },        /*cancel*/
-       { 0xf8, 0x03, KEY_G },          /*tab*/
-       { 0xf8, 0x00, KEY_UP },         /*up*/
-       { 0xf8, 0x1f, KEY_ENTER },      /*ok*/
-       { 0xf8, 0x01, KEY_DOWN },       /*down*/
-       { 0xf8, 0x05, KEY_C },          /*cap*/
-       { 0xf8, 0x06, KEY_S },          /*stop*/
-       { 0xf8, 0x40, KEY_F },          /*full*/
-       { 0xf8, 0x1e, KEY_W },          /*tvmode*/
-       { 0xf8, 0x1b, KEY_B },          /*recall*/
+       { 0xf80a, KEY_Q },              /*power*/
+       { 0xf80c, KEY_M },              /*mute*/
+       { 0xf811, KEY_1 },
+       { 0xf812, KEY_2 },
+       { 0xf813, KEY_3 },
+       { 0xf814, KEY_4 },
+       { 0xf815, KEY_5 },
+       { 0xf816, KEY_6 },
+       { 0xf817, KEY_7 },
+       { 0xf818, KEY_8 },
+       { 0xf819, KEY_9 },
+       { 0xf810, KEY_0 },
+       { 0xf81c, KEY_PAGEUP }, /*ch+*/
+       { 0xf80f, KEY_PAGEDOWN },       /*ch-*/
+       { 0xf81a, KEY_O },              /*vol+*/
+       { 0xf80e, KEY_Z },              /*vol-*/
+       { 0xf804, KEY_R },              /*rec*/
+       { 0xf809, KEY_D },              /*fav*/
+       { 0xf808, KEY_BACKSPACE },      /*rewind*/
+       { 0xf807, KEY_A },              /*fast*/
+       { 0xf80b, KEY_P },              /*pause*/
+       { 0xf802, KEY_ESC },    /*cancel*/
+       { 0xf803, KEY_G },              /*tab*/
+       { 0xf800, KEY_UP },             /*up*/
+       { 0xf81f, KEY_ENTER },  /*ok*/
+       { 0xf801, KEY_DOWN },   /*down*/
+       { 0xf805, KEY_C },              /*cap*/
+       { 0xf806, KEY_S },              /*stop*/
+       { 0xf840, KEY_F },              /*full*/
+       { 0xf81e, KEY_W },              /*tvmode*/
+       { 0xf81b, KEY_B },              /*recall*/
 };
 
 static struct dvb_usb_rc_key tevii_rc_keys[] = {
-       { 0xf8, 0x0a, KEY_POWER },
-       { 0xf8, 0x0c, KEY_MUTE },
-       { 0xf8, 0x11, KEY_1 },
-       { 0xf8, 0x12, KEY_2 },
-       { 0xf8, 0x13, KEY_3 },
-       { 0xf8, 0x14, KEY_4 },
-       { 0xf8, 0x15, KEY_5 },
-       { 0xf8, 0x16, KEY_6 },
-       { 0xf8, 0x17, KEY_7 },
-       { 0xf8, 0x18, KEY_8 },
-       { 0xf8, 0x19, KEY_9 },
-       { 0xf8, 0x10, KEY_0 },
-       { 0xf8, 0x1c, KEY_MENU },
-       { 0xf8, 0x0f, KEY_VOLUMEDOWN },
-       { 0xf8, 0x1a, KEY_LAST },
-       { 0xf8, 0x0e, KEY_OPEN },
-       { 0xf8, 0x04, KEY_RECORD },
-       { 0xf8, 0x09, KEY_VOLUMEUP },
-       { 0xf8, 0x08, KEY_CHANNELUP },
-       { 0xf8, 0x07, KEY_PVR },
-       { 0xf8, 0x0b, KEY_TIME },
-       { 0xf8, 0x02, KEY_RIGHT },
-       { 0xf8, 0x03, KEY_LEFT },
-       { 0xf8, 0x00, KEY_UP },
-       { 0xf8, 0x1f, KEY_OK },
-       { 0xf8, 0x01, KEY_DOWN },
-       { 0xf8, 0x05, KEY_TUNER },
-       { 0xf8, 0x06, KEY_CHANNELDOWN },
-       { 0xf8, 0x40, KEY_PLAYPAUSE },
-       { 0xf8, 0x1e, KEY_REWIND },
-       { 0xf8, 0x1b, KEY_FAVORITES },
-       { 0xf8, 0x1d, KEY_BACK },
-       { 0xf8, 0x4d, KEY_FASTFORWARD },
-       { 0xf8, 0x44, KEY_EPG },
-       { 0xf8, 0x4c, KEY_INFO },
-       { 0xf8, 0x41, KEY_AB },
-       { 0xf8, 0x43, KEY_AUDIO },
-       { 0xf8, 0x45, KEY_SUBTITLE },
-       { 0xf8, 0x4a, KEY_LIST },
-       { 0xf8, 0x46, KEY_F1 },
-       { 0xf8, 0x47, KEY_F2 },
-       { 0xf8, 0x5e, KEY_F3 },
-       { 0xf8, 0x5c, KEY_F4 },
-       { 0xf8, 0x52, KEY_F5 },
-       { 0xf8, 0x5a, KEY_F6 },
-       { 0xf8, 0x56, KEY_MODE },
-       { 0xf8, 0x58, KEY_SWITCHVIDEOMODE },
+       { 0xf80a, KEY_POWER },
+       { 0xf80c, KEY_MUTE },
+       { 0xf811, KEY_1 },
+       { 0xf812, KEY_2 },
+       { 0xf813, KEY_3 },
+       { 0xf814, KEY_4 },
+       { 0xf815, KEY_5 },
+       { 0xf816, KEY_6 },
+       { 0xf817, KEY_7 },
+       { 0xf818, KEY_8 },
+       { 0xf819, KEY_9 },
+       { 0xf810, KEY_0 },
+       { 0xf81c, KEY_MENU },
+       { 0xf80f, KEY_VOLUMEDOWN },
+       { 0xf81a, KEY_LAST },
+       { 0xf80e, KEY_OPEN },
+       { 0xf804, KEY_RECORD },
+       { 0xf809, KEY_VOLUMEUP },
+       { 0xf808, KEY_CHANNELUP },
+       { 0xf807, KEY_PVR },
+       { 0xf80b, KEY_TIME },
+       { 0xf802, KEY_RIGHT },
+       { 0xf803, KEY_LEFT },
+       { 0xf800, KEY_UP },
+       { 0xf81f, KEY_OK },
+       { 0xf801, KEY_DOWN },
+       { 0xf805, KEY_TUNER },
+       { 0xf806, KEY_CHANNELDOWN },
+       { 0xf840, KEY_PLAYPAUSE },
+       { 0xf81e, KEY_REWIND },
+       { 0xf81b, KEY_FAVORITES },
+       { 0xf81d, KEY_BACK },
+       { 0xf84d, KEY_FASTFORWARD },
+       { 0xf844, KEY_EPG },
+       { 0xf84c, KEY_INFO },
+       { 0xf841, KEY_AB },
+       { 0xf843, KEY_AUDIO },
+       { 0xf845, KEY_SUBTITLE },
+       { 0xf84a, KEY_LIST },
+       { 0xf846, KEY_F1 },
+       { 0xf847, KEY_F2 },
+       { 0xf85e, KEY_F3 },
+       { 0xf85c, KEY_F4 },
+       { 0xf852, KEY_F5 },
+       { 0xf85a, KEY_F6 },
+       { 0xf856, KEY_MODE },
+       { 0xf858, KEY_SWITCHVIDEOMODE },
 };
 
 static struct dvb_usb_rc_key tbs_rc_keys[] = {
-       { 0xf8, 0x84, KEY_POWER },
-       { 0xf8, 0x94, KEY_MUTE },
-       { 0xf8, 0x87, KEY_1 },
-       { 0xf8, 0x86, KEY_2 },
-       { 0xf8, 0x85, KEY_3 },
-       { 0xf8, 0x8b, KEY_4 },
-       { 0xf8, 0x8a, KEY_5 },
-       { 0xf8, 0x89, KEY_6 },
-       { 0xf8, 0x8f, KEY_7 },
-       { 0xf8, 0x8e, KEY_8 },
-       { 0xf8, 0x8d, KEY_9 },
-       { 0xf8, 0x92, KEY_0 },
-       { 0xf8, 0x96, KEY_CHANNELUP },
-       { 0xf8, 0x91, KEY_CHANNELDOWN },
-       { 0xf8, 0x93, KEY_VOLUMEUP },
-       { 0xf8, 0x8c, KEY_VOLUMEDOWN },
-       { 0xf8, 0x83, KEY_RECORD },
-       { 0xf8, 0x98, KEY_PAUSE  },
-       { 0xf8, 0x99, KEY_OK },
-       { 0xf8, 0x9a, KEY_SHUFFLE },
-       { 0xf8, 0x81, KEY_UP },
-       { 0xf8, 0x90, KEY_LEFT },
-       { 0xf8, 0x82, KEY_RIGHT },
-       { 0xf8, 0x88, KEY_DOWN },
-       { 0xf8, 0x95, KEY_FAVORITES },
-       { 0xf8, 0x97, KEY_SUBTITLE },
-       { 0xf8, 0x9d, KEY_ZOOM },
-       { 0xf8, 0x9f, KEY_EXIT },
-       { 0xf8, 0x9e, KEY_MENU },
-       { 0xf8, 0x9c, KEY_EPG },
-       { 0xf8, 0x80, KEY_PREVIOUS },
-       { 0xf8, 0x9b, KEY_MODE }
+       { 0xf884, KEY_POWER },
+       { 0xf894, KEY_MUTE },
+       { 0xf887, KEY_1 },
+       { 0xf886, KEY_2 },
+       { 0xf885, KEY_3 },
+       { 0xf88b, KEY_4 },
+       { 0xf88a, KEY_5 },
+       { 0xf889, KEY_6 },
+       { 0xf88f, KEY_7 },
+       { 0xf88e, KEY_8 },
+       { 0xf88d, KEY_9 },
+       { 0xf892, KEY_0 },
+       { 0xf896, KEY_CHANNELUP },
+       { 0xf891, KEY_CHANNELDOWN },
+       { 0xf893, KEY_VOLUMEUP },
+       { 0xf88c, KEY_VOLUMEDOWN },
+       { 0xf883, KEY_RECORD },
+       { 0xf898, KEY_PAUSE  },
+       { 0xf899, KEY_OK },
+       { 0xf89a, KEY_SHUFFLE },
+       { 0xf881, KEY_UP },
+       { 0xf890, KEY_LEFT },
+       { 0xf882, KEY_RIGHT },
+       { 0xf888, KEY_DOWN },
+       { 0xf895, KEY_FAVORITES },
+       { 0xf897, KEY_SUBTITLE },
+       { 0xf89d, KEY_ZOOM },
+       { 0xf89f, KEY_EXIT },
+       { 0xf89e, KEY_MENU },
+       { 0xf89c, KEY_EPG },
+       { 0xf880, KEY_PREVIOUS },
+       { 0xf89b, KEY_MODE }
 };
 
 static struct dvb_usb_rc_keys_table keys_tables[] = {
@@ -894,7 +894,7 @@ static int dw2102_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        *state = REMOTE_NO_KEY_PRESSED;
        if (d->props.i2c_algo->master_xfer(&d->i2c_adap, &msg, 1) == 1) {
                for (i = 0; i < keymap_size ; i++) {
-                       if (keymap[i].data == msg.buf[0]) {
+                       if (rc5_data(&keymap[i]) == msg.buf[0]) {
                                *state = REMOTE_KEY_PRESSED;
                                *event = keymap[i].event;
                                break;
index 54626a0..aec7a19 100644 (file)
@@ -140,7 +140,7 @@ static int m920x_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
                goto unlock;
 
        for (i = 0; i < d->props.rc_key_map_size; i++)
-               if (d->props.rc_key_map[i].data == rc_state[1]) {
+               if (rc5_data(&d->props.rc_key_map[i]) == rc_state[1]) {
                        *event = d->props.rc_key_map[i].event;
 
                        switch(rc_state[0]) {
@@ -562,42 +562,42 @@ static struct m920x_inits tvwalkertwin_rc_init [] = {
 
 /* ir keymaps */
 static struct dvb_usb_rc_key megasky_rc_keys [] = {
-       { 0x0, 0x12, KEY_POWER },
-       { 0x0, 0x1e, KEY_CYCLEWINDOWS }, /* min/max */
-       { 0x0, 0x02, KEY_CHANNELUP },
-       { 0x0, 0x05, KEY_CHANNELDOWN },
-       { 0x0, 0x03, KEY_VOLUMEUP },
-       { 0x0, 0x06, KEY_VOLUMEDOWN },
-       { 0x0, 0x04, KEY_MUTE },
-       { 0x0, 0x07, KEY_OK }, /* TS */
-       { 0x0, 0x08, KEY_STOP },
-       { 0x0, 0x09, KEY_MENU }, /* swap */
-       { 0x0, 0x0a, KEY_REWIND },
-       { 0x0, 0x1b, KEY_PAUSE },
-       { 0x0, 0x1f, KEY_FASTFORWARD },
-       { 0x0, 0x0c, KEY_RECORD },
-       { 0x0, 0x0d, KEY_CAMERA }, /* screenshot */
-       { 0x0, 0x0e, KEY_COFFEE }, /* "MTS" */
+       { 0x0012, KEY_POWER },
+       { 0x001e, KEY_CYCLEWINDOWS }, /* min/max */
+       { 0x0002, KEY_CHANNELUP },
+       { 0x0005, KEY_CHANNELDOWN },
+       { 0x0003, KEY_VOLUMEUP },
+       { 0x0006, KEY_VOLUMEDOWN },
+       { 0x0004, KEY_MUTE },
+       { 0x0007, KEY_OK }, /* TS */
+       { 0x0008, KEY_STOP },
+       { 0x0009, KEY_MENU }, /* swap */
+       { 0x000a, KEY_REWIND },
+       { 0x001b, KEY_PAUSE },
+       { 0x001f, KEY_FASTFORWARD },
+       { 0x000c, KEY_RECORD },
+       { 0x000d, KEY_CAMERA }, /* screenshot */
+       { 0x000e, KEY_COFFEE }, /* "MTS" */
 };
 
 static struct dvb_usb_rc_key tvwalkertwin_rc_keys [] = {
-       { 0x0, 0x01, KEY_ZOOM }, /* Full Screen */
-       { 0x0, 0x02, KEY_CAMERA }, /* snapshot */
-       { 0x0, 0x03, KEY_MUTE },
-       { 0x0, 0x04, KEY_REWIND },
-       { 0x0, 0x05, KEY_PLAYPAUSE }, /* Play/Pause */
-       { 0x0, 0x06, KEY_FASTFORWARD },
-       { 0x0, 0x07, KEY_RECORD },
-       { 0x0, 0x08, KEY_STOP },
-       { 0x0, 0x09, KEY_TIME }, /* Timeshift */
-       { 0x0, 0x0c, KEY_COFFEE }, /* Recall */
-       { 0x0, 0x0e, KEY_CHANNELUP },
-       { 0x0, 0x12, KEY_POWER },
-       { 0x0, 0x15, KEY_MENU }, /* source */
-       { 0x0, 0x18, KEY_CYCLEWINDOWS }, /* TWIN PIP */
-       { 0x0, 0x1a, KEY_CHANNELDOWN },
-       { 0x0, 0x1b, KEY_VOLUMEDOWN },
-       { 0x0, 0x1e, KEY_VOLUMEUP },
+       { 0x0001, KEY_ZOOM }, /* Full Screen */
+       { 0x0002, KEY_CAMERA }, /* snapshot */
+       { 0x0003, KEY_MUTE },
+       { 0x0004, KEY_REWIND },
+       { 0x0005, KEY_PLAYPAUSE }, /* Play/Pause */
+       { 0x0006, KEY_FASTFORWARD },
+       { 0x0007, KEY_RECORD },
+       { 0x0008, KEY_STOP },
+       { 0x0009, KEY_TIME }, /* Timeshift */
+       { 0x000c, KEY_COFFEE }, /* Recall */
+       { 0x000e, KEY_CHANNELUP },
+       { 0x0012, KEY_POWER },
+       { 0x0015, KEY_MENU }, /* source */
+       { 0x0018, KEY_CYCLEWINDOWS }, /* TWIN PIP */
+       { 0x001a, KEY_CHANNELDOWN },
+       { 0x001b, KEY_VOLUMEDOWN },
+       { 0x001e, KEY_VOLUMEUP },
 };
 
 /* DVB USB Driver stuff */
index 07fb843..b41d66e 100644 (file)
@@ -22,51 +22,51 @@ DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
 
 /* Hauppauge NOVA-T USB2 keys */
 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 },
+       { 0x1e00, KEY_0 },
+       { 0x1e01, KEY_1 },
+       { 0x1e02, KEY_2 },
+       { 0x1e03, KEY_3 },
+       { 0x1e04, KEY_4 },
+       { 0x1e05, KEY_5 },
+       { 0x1e06, KEY_6 },
+       { 0x1e07, KEY_7 },
+       { 0x1e08, KEY_8 },
+       { 0x1e09, KEY_9 },
+       { 0x1e0a, KEY_KPASTERISK },
+       { 0x1e0b, KEY_RED },
+       { 0x1e0c, KEY_RADIO },
+       { 0x1e0d, KEY_MENU },
+       { 0x1e0e, KEY_GRAVE }, /* # */
+       { 0x1e0f, KEY_MUTE },
+       { 0x1e10, KEY_VOLUMEUP },
+       { 0x1e11, KEY_VOLUMEDOWN },
+       { 0x1e12, KEY_CHANNEL },
+       { 0x1e14, KEY_UP },
+       { 0x1e15, KEY_DOWN },
+       { 0x1e16, KEY_LEFT },
+       { 0x1e17, KEY_RIGHT },
+       { 0x1e18, KEY_VIDEO },
+       { 0x1e19, KEY_AUDIO },
+       { 0x1e1a, KEY_MEDIA },
+       { 0x1e1b, KEY_EPG },
+       { 0x1e1c, KEY_TV },
+       { 0x1e1e, KEY_NEXT },
+       { 0x1e1f, KEY_BACK },
+       { 0x1e20, KEY_CHANNELUP },
+       { 0x1e21, KEY_CHANNELDOWN },
+       { 0x1e24, KEY_LAST }, /* Skip backwards */
+       { 0x1e25, KEY_OK },
+       { 0x1e29, KEY_BLUE},
+       { 0x1e2e, KEY_GREEN },
+       { 0x1e30, KEY_PAUSE },
+       { 0x1e32, KEY_REWIND },
+       { 0x1e34, KEY_FASTFORWARD },
+       { 0x1e35, KEY_PLAY },
+       { 0x1e36, KEY_STOP },
+       { 0x1e37, KEY_RECORD },
+       { 0x1e38, KEY_YELLOW },
+       { 0x1e3b, KEY_GOTO },
+       { 0x1e3d, KEY_POWER },
 };
 
 /* Firmware bug? sometimes, when a new key is pressed, the previous pressed key
@@ -92,10 +92,11 @@ static int nova_t_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
                        deb_rc("raw key code 0x%02x, 0x%02x, 0x%02x to c: %02x d: %02x toggle: %d\n",key[1],key[2],key[3],custom,data,toggle);
 
                        for (i = 0; i < ARRAY_SIZE(haupp_rc_keys); i++) {
-                               if (haupp_rc_keys[i].data == data &&
-                                       haupp_rc_keys[i].custom == custom) {
+                               if (rc5_data(&haupp_rc_keys[i]) == data &&
+                                       rc5_custom(&haupp_rc_keys[i]) == custom) {
 
-                                       deb_rc("c: %x, d: %x\n",haupp_rc_keys[i].data,haupp_rc_keys[i].custom);
+                                       deb_rc("c: %x, d: %x\n", rc5_data(&haupp_rc_keys[i]),
+                                                                rc5_custom(&haupp_rc_keys[i]));
 
                                        *event = haupp_rc_keys[i].event;
                                        *state = REMOTE_KEY_PRESSED;
index 7e32d11..d4e2309 100644 (file)
@@ -332,32 +332,32 @@ static int opera1_pid_filter_control(struct dvb_usb_adapter *adap, int onoff)
 }
 
 static struct dvb_usb_rc_key opera1_rc_keys[] = {
-       {0x5f, 0xa0, KEY_1},
-       {0x51, 0xaf, KEY_2},
-       {0x5d, 0xa2, KEY_3},
-       {0x41, 0xbe, KEY_4},
-       {0x0b, 0xf5, KEY_5},
-       {0x43, 0xbd, KEY_6},
-       {0x47, 0xb8, KEY_7},
-       {0x49, 0xb6, KEY_8},
-       {0x05, 0xfa, KEY_9},
-       {0x45, 0xba, KEY_0},
-       {0x09, 0xf6, KEY_UP},   /*chanup */
-       {0x1b, 0xe5, KEY_DOWN}, /*chandown */
-       {0x5d, 0xa3, KEY_LEFT}, /*voldown */
-       {0x5f, 0xa1, KEY_RIGHT},        /*volup */
-       {0x07, 0xf8, KEY_SPACE},        /*tab */
-       {0x1f, 0xe1, KEY_ENTER},        /*play ok */
-       {0x1b, 0xe4, KEY_Z},    /*zoom */
-       {0x59, 0xa6, KEY_M},    /*mute */
-       {0x5b, 0xa5, KEY_F},    /*tv/f */
-       {0x19, 0xe7, KEY_R},    /*rec */
-       {0x01, 0xfe, KEY_S},    /*Stop */
-       {0x03, 0xfd, KEY_P},    /*pause */
-       {0x03, 0xfc, KEY_W},    /*<- -> */
-       {0x07, 0xf9, KEY_C},    /*capture */
-       {0x47, 0xb9, KEY_Q},    /*exit */
-       {0x43, 0xbc, KEY_O},    /*power */
+       {0x5fa0, KEY_1},
+       {0x51af, KEY_2},
+       {0x5da2, KEY_3},
+       {0x41be, KEY_4},
+       {0x0bf5, KEY_5},
+       {0x43bd, KEY_6},
+       {0x47b8, KEY_7},
+       {0x49b6, KEY_8},
+       {0x05fa, KEY_9},
+       {0x45ba, KEY_0},
+       {0x09f6, KEY_UP},       /*chanup */
+       {0x1be5, KEY_DOWN},     /*chandown */
+       {0x5da3, KEY_LEFT},     /*voldown */
+       {0x5fa1, KEY_RIGHT},    /*volup */
+       {0x07f8, KEY_SPACE},    /*tab */
+       {0x1fe1, KEY_ENTER},    /*play ok */
+       {0x1be4, KEY_Z},        /*zoom */
+       {0x59a6, KEY_M},        /*mute */
+       {0x5ba5, KEY_F},        /*tv/f */
+       {0x19e7, KEY_R},        /*rec */
+       {0x01fe, KEY_S},        /*Stop */
+       {0x03fd, KEY_P},        /*pause */
+       {0x03fc, KEY_W},        /*<- -> */
+       {0x07f9, KEY_C},        /*capture */
+       {0x47b9, KEY_Q},        /*exit */
+       {0x43bc, KEY_O},        /*power */
 
 };
 
@@ -405,8 +405,7 @@ static int opera1_rc_query(struct dvb_usb_device *dev, u32 * event, int *state)
                send_key = (send_key & 0xffff) | 0x0100;
 
                for (i = 0; i < ARRAY_SIZE(opera1_rc_keys); i++) {
-                       if ((opera1_rc_keys[i].custom * 256 +
-                                       opera1_rc_keys[i].data) == (send_key & 0xffff)) {
+                       if (rc5_scan(&opera1_rc_keys[i]) == (send_key & 0xffff)) {
                                *state = REMOTE_KEY_PRESSED;
                                *event = opera1_rc_keys[i].event;
                                opst->last_key_pressed =
index 986fff9..ef4e37d 100644 (file)
@@ -175,8 +175,8 @@ static int vp702x_streaming_ctrl(struct dvb_usb_adapter *adap, int onoff)
 
 /* keys for the enclosed remote control */
 static struct dvb_usb_rc_key vp702x_rc_keys[] = {
-       { 0x00, 0x01, KEY_1 },
-       { 0x00, 0x02, KEY_2 },
+       { 0x0001, KEY_1 },
+       { 0x0002, KEY_2 },
 };
 
 /* remote control stuff (does not work with my box) */
@@ -198,7 +198,7 @@ static int vp702x_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        }
 
        for (i = 0; i < ARRAY_SIZE(vp702x_rc_keys); i++)
-               if (vp702x_rc_keys[i].custom == key[1]) {
+               if (rc5_custom(&vp702x_rc_keys[i]) == key[1]) {
                        *state = REMOTE_KEY_PRESSED;
                        *event = vp702x_rc_keys[i].event;
                        break;
index acb3455..a59faa2 100644 (file)
@@ -100,56 +100,56 @@ 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. */
 static struct dvb_usb_rc_key vp7045_rc_keys[] = {
-       { 0x00, 0x16, KEY_POWER },
-       { 0x00, 0x10, KEY_MUTE },
-       { 0x00, 0x03, KEY_1 },
-       { 0x00, 0x01, KEY_2 },
-       { 0x00, 0x06, KEY_3 },
-       { 0x00, 0x09, KEY_4 },
-       { 0x00, 0x1d, KEY_5 },
-       { 0x00, 0x1f, KEY_6 },
-       { 0x00, 0x0d, KEY_7 },
-       { 0x00, 0x19, KEY_8 },
-       { 0x00, 0x1b, KEY_9 },
-       { 0x00, 0x15, KEY_0 },
-       { 0x00, 0x05, KEY_CHANNELUP },
-       { 0x00, 0x02, KEY_CHANNELDOWN },
-       { 0x00, 0x1e, KEY_VOLUMEUP },
-       { 0x00, 0x0a, KEY_VOLUMEDOWN },
-       { 0x00, 0x11, KEY_RECORD },
-       { 0x00, 0x17, KEY_FAVORITES }, /* Heart symbol - Channel list. */
-       { 0x00, 0x14, KEY_PLAY },
-       { 0x00, 0x1a, KEY_STOP },
-       { 0x00, 0x40, KEY_REWIND },
-       { 0x00, 0x12, KEY_FASTFORWARD },
-       { 0x00, 0x0e, KEY_PREVIOUS }, /* Recall - Previous channel. */
-       { 0x00, 0x4c, KEY_PAUSE },
-       { 0x00, 0x4d, KEY_SCREEN }, /* Full screen mode. */
-       { 0x00, 0x54, KEY_AUDIO }, /* MTS - Switch to secondary audio. */
-       { 0x00, 0x0c, KEY_CANCEL }, /* Cancel */
-       { 0x00, 0x1c, KEY_EPG }, /* EPG */
-       { 0x00, 0x00, KEY_TAB }, /* Tab */
-       { 0x00, 0x48, KEY_INFO }, /* Preview */
-       { 0x00, 0x04, KEY_LIST }, /* RecordList */
-       { 0x00, 0x0f, KEY_TEXT }, /* Teletext */
-       { 0x00, 0x41, KEY_PREVIOUSSONG },
-       { 0x00, 0x42, KEY_NEXTSONG },
-       { 0x00, 0x4b, KEY_UP },
-       { 0x00, 0x51, KEY_DOWN },
-       { 0x00, 0x4e, KEY_LEFT },
-       { 0x00, 0x52, KEY_RIGHT },
-       { 0x00, 0x4f, KEY_ENTER },
-       { 0x00, 0x13, KEY_CANCEL },
-       { 0x00, 0x4a, KEY_CLEAR },
-       { 0x00, 0x54, KEY_PRINT }, /* Capture */
-       { 0x00, 0x43, KEY_SUBTITLE }, /* Subtitle/CC */
-       { 0x00, 0x08, KEY_VIDEO }, /* A/V */
-       { 0x00, 0x07, KEY_SLEEP }, /* Hibernate */
-       { 0x00, 0x45, KEY_ZOOM }, /* Zoom+ */
-       { 0x00, 0x18, KEY_RED},
-       { 0x00, 0x53, KEY_GREEN},
-       { 0x00, 0x5e, KEY_YELLOW},
-       { 0x00, 0x5f, KEY_BLUE}
+       { 0x0016, KEY_POWER },
+       { 0x0010, KEY_MUTE },
+       { 0x0003, KEY_1 },
+       { 0x0001, KEY_2 },
+       { 0x0006, KEY_3 },
+       { 0x0009, KEY_4 },
+       { 0x001d, KEY_5 },
+       { 0x001f, KEY_6 },
+       { 0x000d, KEY_7 },
+       { 0x0019, KEY_8 },
+       { 0x001b, KEY_9 },
+       { 0x0015, KEY_0 },
+       { 0x0005, KEY_CHANNELUP },
+       { 0x0002, KEY_CHANNELDOWN },
+       { 0x001e, KEY_VOLUMEUP },
+       { 0x000a, KEY_VOLUMEDOWN },
+       { 0x0011, KEY_RECORD },
+       { 0x0017, KEY_FAVORITES }, /* Heart symbol - Channel list. */
+       { 0x0014, KEY_PLAY },
+       { 0x001a, KEY_STOP },
+       { 0x0040, KEY_REWIND },
+       { 0x0012, KEY_FASTFORWARD },
+       { 0x000e, KEY_PREVIOUS }, /* Recall - Previous channel. */
+       { 0x004c, KEY_PAUSE },
+       { 0x004d, KEY_SCREEN }, /* Full screen mode. */
+       { 0x0054, KEY_AUDIO }, /* MTS - Switch to secondary audio. */
+       { 0x000c, KEY_CANCEL }, /* Cancel */
+       { 0x001c, KEY_EPG }, /* EPG */
+       { 0x0000, KEY_TAB }, /* Tab */
+       { 0x0048, KEY_INFO }, /* Preview */
+       { 0x0004, KEY_LIST }, /* RecordList */
+       { 0x000f, KEY_TEXT }, /* Teletext */
+       { 0x0041, KEY_PREVIOUSSONG },
+       { 0x0042, KEY_NEXTSONG },
+       { 0x004b, KEY_UP },
+       { 0x0051, KEY_DOWN },
+       { 0x004e, KEY_LEFT },
+       { 0x0052, KEY_RIGHT },
+       { 0x004f, KEY_ENTER },
+       { 0x0013, KEY_CANCEL },
+       { 0x004a, KEY_CLEAR },
+       { 0x0054, KEY_PRINT }, /* Capture */
+       { 0x0043, KEY_SUBTITLE }, /* Subtitle/CC */
+       { 0x0008, KEY_VIDEO }, /* A/V */
+       { 0x0007, KEY_SLEEP }, /* Hibernate */
+       { 0x0045, KEY_ZOOM }, /* Zoom+ */
+       { 0x0018, KEY_RED},
+       { 0x0053, KEY_GREEN},
+       { 0x005e, KEY_YELLOW},
+       { 0x005f, KEY_BLUE}
 };
 
 static int vp7045_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
@@ -166,7 +166,7 @@ static int vp7045_rc_query(struct dvb_usb_device *d, u32 *event, int *state)
        }
 
        for (i = 0; i < ARRAY_SIZE(vp7045_rc_keys); i++)
-               if (vp7045_rc_keys[i].data == key) {
+               if (rc5_data(&vp7045_rc_keys[i]) == key) {
                        *state = REMOTE_KEY_PRESSED;
                        *event = vp7045_rc_keys[i].event;
                        break;