В Птн, 11/05/2007 в 11:02 +0800, Tony Wan пишет: > Enable the IR-remote of the 10moons TM300 card and add the key-codes for > it's remote. > > It has been tested using lirc. All the key codes are accepted. > > Signed-off-by: Tony Wan <[email protected]> > --- > drivers/media/common/ir-keymaps.c | 69 > +++++++++++++++++++++++++++ > 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, 77 insertions(+), 0 deletions(-) > > diff --git a/drivers/media/common/ir-keymaps.c > b/drivers/media/common/ir-keymaps.c > index cbd1184..5aa293e 100644 > --- a/drivers/media/common/ir-keymaps.c > +++ b/drivers/media/common/ir-keymaps.c > @@ -1783,3 +1783,72 @@ 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 > + [ 0x24 ] = KEY_ARCHIVE, // Time shifting > + [ 0x20 ] = KEY_SWITCHVIDEOMODE, // Selcect source > + > + [ 0x3a ] = KEY_RECORD, // Record > + [ 0x22 ] = KEY_PLAY, // Play/Pause > + [ 0x25 ] = KEY_STOP, // Stop > + [ 0x23 ] = KEY_CAMERA, // Snapshot > + > + [ 0x28 ] = KEY_BACK, // Backward << > + [ 0x2a ] = KEY_FORWARD, // Forward >> > + [ 0x29 ] = KEY_PREVIOUS, // Back |<< > + [ 0x2b ] = KEY_NEXT, // End >>| > + > + [ 0x2c ] = KEY_PROGRAM, // Multi-view > + [ 0x2d ] = KEY_AUDIO, // Audio Tracks > + [ 0x2e ] = KEY_SOUND, // Sound > + [ 0x2f ] = KEY_SUBTITLE, // Subtitles > + > + [ 0x30 ] = KEY_TIME, // Set timer > + [ 0x31 ] = KEY_CHANNEL, // Stereo > + [ 0x32 ] = KEY_LANGUAGE, // Language > + [ 0x33 ] = KEY_TEXT, // Text > + > + [ 0x39 ] = KEY_RED, // RED > + [ 0x21 ] = KEY_GREEN, // GREEN > + [ 0x27 ] = KEY_YELLOW, // YELLOW > + [ 0x37 ] = KEY_BLUE, // BLUE > +}; > + > +EXPORT_SYMBOL_GPL(ir_codes_10moonstm3); > diff --git a/drivers/media/video/saa7134/saa7134-cards.c > b/drivers/media/video/saa7134/saa7134-cards.c > index 44f2077..5813509 100644 > --- a/drivers/media/video/saa7134/saa7134-cards.c > +++ b/drivers/media/video/saa7134/saa7134-cards.c > @@ -4368,6 +4368,7 @@ int saa7134_board_init1(struct saa7134_dev *dev) > case SAA7134_BOARD_AVERMEDIA_A16AR: > case SAA7134_BOARD_ENCORE_ENLTV: > case SAA7134_BOARD_ENCORE_ENLTV_FM: > + case SAA7134_BOARD_10MOONSTVMASTER3: > dev->has_remote = SAA7134_REMOTE_GPIO; > break; > case SAA7134_BOARD_FLYDVBS_LR300: > diff --git a/drivers/media/video/saa7134/saa7134-input.c > b/drivers/media/video/saa7134/saa7134-input.c > index c0de37e..c87755b 100644 > --- a/drivers/media/video/saa7134/saa7134-input.c > +++ b/drivers/media/video/saa7134/saa7134-input.c > @@ -333,6 +333,12 @@ int saa7134_input_init1(struct saa7134_dev *dev) > mask_keyup = 0x040000; > polling = 50; // ms > break; > + case SAA7134_BOARD_10MOONSTVMASTER3: > + ir_codes = ir_codes_10moonstm3; > + mask_keycode = 0x4f80000; > + mask_keyup = 0x8000000; > + polling = 50; //ms > + break; > } > if (NULL == ir_codes) { > printk("%s: Oops: IR config error [card=%d]\n", > diff --git a/include/media/ir-common.h b/include/media/ir-common.h > index 9807a7c..4e4d207 100644 > --- a/include/media/ir-common.h > +++ b/include/media/ir-common.h > @@ -140,6 +140,7 @@ extern IR_KEYTAB_TYPE > ir_codes_budget_ci_old[IR_KEYTAB_SIZE]; > extern IR_KEYTAB_TYPE ir_codes_asus_pc39[IR_KEYTAB_SIZE]; > extern IR_KEYTAB_TYPE ir_codes_encore_enltv[IR_KEYTAB_SIZE]; > extern IR_KEYTAB_TYPE ir_codes_tt_1500[IR_KEYTAB_SIZE]; > +extern IR_KEYTAB_TYPE ir_codes_10moonstm3[IR_KEYTAB_SIZE]; > > #endif > Great, now another correction, sorry for not noticing it before. With correction of bit 0x4 -> 0x2 your remote is exactly the same as ir_codes_encore_enltv so probably there is sense just to reuse old codes. Elencore mask should be reduced too. I also wonder aren't we talking about the same card here.
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?=
- Follow-Ups:
- References:
- Prev by Date: Re: [PATCH] UDF: check for allocated memory for inode data
- Next by Date: Re: [PATCH 1/2] Eliminate references to new_client in i2c documentation
- Previous by thread: [PATCH] v4l: saa7134: support ir-remote for 10moons TM300
- Next by thread: Re: [PATCH] v4l: saa7134: support ir-remote for 10moons TM300
- Index(es):