Re: [PATCH 2/3] v4l: saa7134: enable ir-remote for 10moons TM300 card

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Tony. Very nice patch, thanks.

В Чтв, 10/05/2007 в 11:04 +0800, Tony Wan пишет:
> Enable the IR-remote of the 10moons TM300 card and add the key-codes for
> it's remote. But to enable all the keys, "IR_KEYTAB_SIZE", the size of
> code tables should be at least 256.

> It has been tested using lirc. All the key codes are accepted.
> 
> This patch depends on the "[PATCH 1/3] v4l: Support 10moons TM300
> (saa7130) Card"
> 
> Signed-off-by: Tony Wan <[email protected]>
> ---
>  drivers/media/common/ir-keymaps.c           |   71
> +++++++++++++++++++++++++++
>  drivers/media/video/saa7134/saa7134-cards.c |    1 +
>  drivers/media/video/saa7134/saa7134-input.c |    6 ++
>  include/media/ir-common.h                   |    1 +
>  4 files changed, 79 insertions(+), 0 deletions(-)
> 
> diff --git a/drivers/media/common/ir-keymaps.c
> b/drivers/media/common/ir-keymaps.c
> index cbd1184..df11ed4 100644
> --- a/drivers/media/common/ir-keymaps.c
> +++ b/drivers/media/common/ir-keymaps.c
> @@ -1783,3 +1783,74 @@ IR_KEYTAB_TYPE ir_codes_tt_1500[IR_KEYTAB_SIZE] =
> {
>  };
>  
>  EXPORT_SYMBOL_GPL(ir_codes_tt_1500);
> +
> +/* 10MOONS TM300 */
> +IR_KEYTAB_TYPE ir_codes_10moonstm3[IR_KEYTAB_SIZE] = {
> +	[ 0x10 ] = KEY_POWER,           // Power
> +	[ 0x0d ] = KEY_MUTE,            // Mute
> +	[ 0x1e ] = KEY_TUNER,           // Cable
> +	[ 0x00 ] = KEY_VIDEO,           // Composite / S-Video
> +	[ 0x01 ] = KEY_RADIO,           // Music
> +	[ 0x02 ] = KEY_TEXT,            // Photo
> +
> +	[ 0x1f ] = KEY_1,
> +	[ 0x03 ] = KEY_2,
> +	[ 0x04 ] = KEY_3,
> +	[ 0x05 ] = KEY_4,
> +	[ 0x1c ] = KEY_5,
> +	[ 0x06 ] = KEY_6,
> +	[ 0x07 ] = KEY_7,
> +	[ 0x08 ] = KEY_8,
> +	[ 0x1d ] = KEY_9,
> +	[ 0x09 ] = KEY_SELECT,          // 2 digit select (-/--)
> +	[ 0x0a ] = KEY_0,
> +	[ 0x0b ] = KEY_AGAIN,           // Recall
> +
> +	[ 0x14 ] = KEY_F1,              // Begin
> +	[ 0x15 ] = KEY_F2,              // End
> +
> +	[ 0x16 ] = KEY_CHANNELUP,       // CH+
> +	[ 0x12 ] = KEY_CHANNELDOWN,     // CH-
> +	[ 0x0c ] = KEY_VOLUMEUP,        // VOL+
> +	[ 0x17 ] = KEY_VOLUMEDOWN,      // VOL-
> +	[ 0x18 ] = KEY_OK,              // OK
> +
> +	[ 0x0e ] = KEY_EXIT,            // Exit
> +	[ 0x13 ] = KEY_COMPUTER,        // Desktop
> +	[ 0x11 ] = KEY_TAB,             // TAB
> +	[ 0x19 ] = KEY_CYCLEWINDOWS,    // Switch task
> +
> +	[ 0x1a ] = KEY_MENU,            // Menu
> +	[ 0x1b ] = KEY_ZOOM,            // Fullscreen
> +#if IR_KEYTAB_SIZE>=256
> +	[ 0x84 ] = KEY_ARCHIVE,         // Time shifting
> +	[ 0x80 ] = KEY_SWITCHVIDEOMODE, // Selcect source
> +
> +	[ 0x9a ] = KEY_RECORD,          // Record
> +	[ 0x82 ] = KEY_PLAY,            // Play/Pause
> +	[ 0x85 ] = KEY_STOP,            // Stop
> +	[ 0x83 ] = KEY_CAMERA,          // Snapshot
> +
> +	[ 0x88 ] = KEY_BACK,            // Backward <<
> +	[ 0x8a ] = KEY_FORWARD,         // Forward >>
> +	[ 0x89 ] = KEY_PREVIOUS,        // Back |<<
> +	[ 0x8b ] = KEY_NEXT,            // End >>|
> +
> +	[ 0x8c ] = KEY_PROGRAM,         // Multi-view
> +	[ 0x8d ] = KEY_AUDIO,           // Audio Tracks
> +	[ 0x8e ] = KEY_SOUND,           // Sound
> +	[ 0x8f ] = KEY_SUBTITLE,        // Subtitles
> +
> +	[ 0x90 ] = KEY_TIME,            // Set timer
> +	[ 0x91 ] = KEY_CHANNEL,         // Stereo
> +	[ 0x92 ] = KEY_LANGUAGE,        // Language
> +	[ 0x93 ] = KEY_TEXT,            // Text
> +
> +	[ 0x99 ] = KEY_RED,             // RED
> +	[ 0x81 ] = KEY_GREEN,           // GREEN
> +	[ 0x87 ] = KEY_YELLOW,          // YELLOW
> +	[ 0x97 ] = KEY_BLUE,            // BLUE
> +#endif /* IR_KEYTAB_SIZE>=256 */
> +};
> +

Size of 256 is not required. You've just selected incorrect keymask,
that's why you have so big values. Look through your values, in the
upper 4 bits only two bits are used - 0x80 and 0x10. So you should
probably use mask_keycode with 0x47800000 instead of mask_keycode =
0x7f80000. Or even smaller mask. Include only bits which change the
values, nothing more.


Attachment: signature.asc
Description: =?koi8-r?Q?=FC=D4=C1?= =?koi8-r?Q?_=DE=C1=D3=D4=D8?= =?koi8-r?Q?_=D3=CF=CF=C2=DD=C5=CE=C9=D1?= =?koi8-r?Q?_=D0=CF=C4=D0=C9=D3=C1=CE=C1?= =?koi8-r?Q?_=C3=C9=C6=D2=CF=D7=CF=CA?= =?koi8-r?Q?_=D0=CF=C4=D0=C9=D3=D8=C0?=


[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux