[media] saa7134: use full keycode for BeholdTV
authorDavid Härdeman <david@hardeman.nu>
Fri, 19 Nov 2010 23:42:46 +0000 (20:42 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Wed, 29 Dec 2010 10:16:53 +0000 (08:16 -0200)
Using the full keycode for BeholdTV hardware makes another module
parameter unnecessary.

Signed-off-by: David Härdeman <david@hardeman.nu>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/rc/keymaps/rc-behold.c
drivers/media/video/saa7134/saa7134-input.c

index ae4d2354c7b98197a0b21068461b50abe66d5207..0ee1f149364ce4bf3937f478f11b9d1b7279cb2b 100644 (file)
@@ -29,8 +29,8 @@ static struct rc_map_table behold[] = {
        /*  0x1c            0x12  *
         *  TV/FM          POWER  *
         *                        */
-       { 0x1c, KEY_TUNER },    /* XXX KEY_TV / KEY_RADIO */
-       { 0x12, KEY_POWER },
+       { 0x6b861c, KEY_TUNER },        /* XXX KEY_TV / KEY_RADIO */
+       { 0x6b8612, KEY_POWER },
 
        /*  0x01    0x02    0x03  *
         *   1       2       3    *
@@ -41,28 +41,28 @@ static struct rc_map_table behold[] = {
         *  0x07    0x08    0x09  *
         *   7       8       9    *
         *                        */
-       { 0x01, KEY_1 },
-       { 0x02, KEY_2 },
-       { 0x03, KEY_3 },
-       { 0x04, KEY_4 },
-       { 0x05, KEY_5 },
-       { 0x06, KEY_6 },
-       { 0x07, KEY_7 },
-       { 0x08, KEY_8 },
-       { 0x09, KEY_9 },
+       { 0x6b8601, KEY_1 },
+       { 0x6b8602, KEY_2 },
+       { 0x6b8603, KEY_3 },
+       { 0x6b8604, KEY_4 },
+       { 0x6b8605, KEY_5 },
+       { 0x6b8606, KEY_6 },
+       { 0x6b8607, KEY_7 },
+       { 0x6b8608, KEY_8 },
+       { 0x6b8609, KEY_9 },
 
        /*  0x0a    0x00    0x17  *
         * RECALL    0      MODE  *
         *                        */
-       { 0x0a, KEY_AGAIN },
-       { 0x00, KEY_0 },
-       { 0x17, KEY_MODE },
+       { 0x6b860a, KEY_AGAIN },
+       { 0x6b8600, KEY_0 },
+       { 0x6b8617, KEY_MODE },
 
        /*  0x14          0x10    *
         * ASPECT      FULLSCREEN *
         *                        */
-       { 0x14, KEY_SCREEN },
-       { 0x10, KEY_ZOOM },
+       { 0x6b8614, KEY_SCREEN },
+       { 0x6b8610, KEY_ZOOM },
 
        /*          0x0b          *
         *           Up           *
@@ -73,17 +73,17 @@ static struct rc_map_table behold[] = {
         *         0x015          *
         *         Down           *
         *                        */
-       { 0x0b, KEY_CHANNELUP },
-       { 0x18, KEY_VOLUMEDOWN },
-       { 0x16, KEY_OK },               /* XXX KEY_ENTER */
-       { 0x0c, KEY_VOLUMEUP },
-       { 0x15, KEY_CHANNELDOWN },
+       { 0x6b860b, KEY_CHANNELUP },
+       { 0x6b8618, KEY_VOLUMEDOWN },
+       { 0x6b8616, KEY_OK },           /* XXX KEY_ENTER */
+       { 0x6b860c, KEY_VOLUMEUP },
+       { 0x6b8615, KEY_CHANNELDOWN },
 
        /*  0x11            0x0d  *
         *  MUTE            INFO  *
         *                        */
-       { 0x11, KEY_MUTE },
-       { 0x0d, KEY_INFO },
+       { 0x6b8611, KEY_MUTE },
+       { 0x6b860d, KEY_INFO },
 
        /*  0x0f    0x1b    0x1a  *
         * RECORD PLAY/PAUSE STOP *
@@ -92,26 +92,26 @@ static struct rc_map_table behold[] = {
         *TELETEXT  AUDIO  SOURCE *
         *           RED   YELLOW *
         *                        */
-       { 0x0f, KEY_RECORD },
-       { 0x1b, KEY_PLAYPAUSE },
-       { 0x1a, KEY_STOP },
-       { 0x0e, KEY_TEXT },
-       { 0x1f, KEY_RED },      /*XXX KEY_AUDIO */
-       { 0x1e, KEY_YELLOW },   /*XXX KEY_SOURCE        */
+       { 0x6b860f, KEY_RECORD },
+       { 0x6b861b, KEY_PLAYPAUSE },
+       { 0x6b861a, KEY_STOP },
+       { 0x6b860e, KEY_TEXT },
+       { 0x6b861f, KEY_RED },  /*XXX KEY_AUDIO */
+       { 0x6b861e, KEY_YELLOW },       /*XXX KEY_SOURCE        */
 
        /*  0x1d   0x13     0x19  *
         * SLEEP  PREVIEW   DVB   *
         *         GREEN    BLUE  *
         *                        */
-       { 0x1d, KEY_SLEEP },
-       { 0x13, KEY_GREEN },
-       { 0x19, KEY_BLUE },     /* XXX KEY_SAT  */
+       { 0x6b861d, KEY_SLEEP },
+       { 0x6b8613, KEY_GREEN },
+       { 0x6b8619, KEY_BLUE }, /* XXX KEY_SAT  */
 
        /*  0x58           0x5c   *
         * FREEZE        SNAPSHOT *
         *                        */
-       { 0x58, KEY_SLOW },
-       { 0x5c, KEY_CAMERA },
+       { 0x6b8658, KEY_SLOW },
+       { 0x6b865c, KEY_CAMERA },
 
 };
 
@@ -119,7 +119,7 @@ static struct rc_map_list behold_map = {
        .map = {
                .scan    = behold,
                .size    = ARRAY_SIZE(behold),
-               .rc_type = RC_TYPE_UNKNOWN,     /* Legacy IR type */
+               .rc_type = RC_TYPE_NEC,
                .name    = RC_MAP_BEHOLD,
        }
 };
index 4fdc165663d18bd0f67f093241088e6431cdeb6e..10dc9ad2eae98c10d8846cf5507538a9910e436c 100644 (file)
@@ -41,11 +41,6 @@ static int pinnacle_remote;
 module_param(pinnacle_remote, int, 0644);    /* Choose Pinnacle PCTV remote */
 MODULE_PARM_DESC(pinnacle_remote, "Specify Pinnacle PCTV remote: 0=coloured, 1=grey (defaults to 0)");
 
-static unsigned int disable_other_ir;
-module_param(disable_other_ir, int, 0644);
-MODULE_PARM_DESC(disable_other_ir, "disable full codes of "
-    "alternative remotes from other manufacturers");
-
 #define dprintk(fmt, arg...)   if (ir_debug) \
        printk(KERN_DEBUG "%s/ir: " fmt, dev->name , ## arg)
 #define i2cdprintk(fmt, arg...)    if (ir_debug) \
@@ -282,22 +277,12 @@ static int get_key_beholdm6xx(struct IR_i2c *ir, u32 *ir_key, u32 *ir_raw)
                i2cdprintk("read error\n");
                return -EIO;
        }
-       /* IR of this card normally decode signals NEC-standard from
-        * - Sven IHOO MT 5.1R remote. xxyye718
-        * - Sven DVD HD-10xx remote. xxyyf708
-        * - BBK ...
-        * - mayby others
-        * So, skip not our, if disable full codes mode.
-        */
-       if (data[10] != 0x6b && data[11] != 0x86 && disable_other_ir)
-               return 0;
 
-       /* Wrong data decode fix */
        if (data[9] != (unsigned char)(~data[8]))
                return 0;
 
-       *ir_key = data[9];
-       *ir_raw = data[9];
+       *ir_raw = ((data[10] << 16) | (data[11] << 8) | (data[9] << 0));
+       *ir_key = *ir_raw;
 
        return 1;
 }