Re: [PATCH v2] media: rc: add keymap for Videostrong KII Pro

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

 



On Thu, Jan 02, 2020 at 09:02:58PM +0300, Mohammad Rasim wrote:
> On 19/12/31 10:44AM, Sean Young wrote:
> > Hi Mohammad,
> >
> > On Wed, Nov 20, 2019 at 02:41:53PM +0300, Mohammad Rasim wrote:
> > > Changes since v1:
> > > - fix styling issues
> > > Signed-off-by: Mohammad Rasim <mohammad.rasim96@xxxxxxxxx>
> > > ---
> > >  drivers/media/rc/keymaps/Makefile             |  1 +
> > >  .../media/rc/keymaps/rc-videostrong-kii-pro.c | 84 +++++++++++++++++++
> > >  include/media/rc-map.h                        |  1 +
> > >  3 files changed, 86 insertions(+)
> > >  create mode 100644 drivers/media/rc/keymaps/rc-videostrong-kii-pro.c
> > >
> > > diff --git a/drivers/media/rc/keymaps/Makefile b/drivers/media/rc/keymaps/Makefile
> > > index a56fc634d2d6..ea91a9afa6a0 100644
> > > --- a/drivers/media/rc/keymaps/Makefile
> > > +++ b/drivers/media/rc/keymaps/Makefile
> > > @@ -117,6 +117,7 @@ obj-$(CONFIG_RC_MAP) += rc-adstech-dvb-t-pci.o \
> > >  			rc-videomate-m1f.o \
> > >  			rc-videomate-s350.o \
> > >  			rc-videomate-tv-pvr.o \
> > > +			rc-videostrong-kii-pro.o \
> > >  			rc-wetek-hub.o \
> > >  			rc-wetek-play2.o \
> > >  			rc-winfast.o \
> > > diff --git a/drivers/media/rc/keymaps/rc-videostrong-kii-pro.c b/drivers/media/rc/keymaps/rc-videostrong-kii-pro.c
> > > new file mode 100644
> > > index 000000000000..2b94c28ed5d7
> > > --- /dev/null
> > > +++ b/drivers/media/rc/keymaps/rc-videostrong-kii-pro.c
> > > @@ -0,0 +1,84 @@
> > > +// SPDX-License-Identifier: GPL-2.0+
> > > +//
> > > +// Copyright (C) 2019 Mohammad Rasim <mohammad.rasim96@xxxxxxxxx>
> > > +
> > > +#include <media/rc-map.h>
> > > +#include <linux/module.h>
> > > +
> > > +//
> > > +// Keytable for the Videostrong KII Pro STB remote control
> > > +//
> > > +
> >
> > I assume it's this remote:
> >
> > https://i1.wp.com/www.eyalo.com/wp-content/uploads/2016/10/KIIPro-items1.jpg
> >
> > or
> >
> > https://www.cnx-software.com/2016/08/26/videostrong-kii-pro-android-set-top-box-with-dvb-t2-dvb-s2-tuners-comes-with-2gb-ram/
> >
> Yes, your assumption is right
> 
> The vendor driver uses this file to setup keymaps
> https://github.com/OpenVisionE2/amremote/blob/master/k1pro.conf
> 
> > > +static struct rc_map_table kii_pro[] = {
> > > +	{ 0x59, KEY_POWER },
> > > +	{ 0x19, KEY_MUTE },
> > > +	{ 0x42, KEY_RED },
> > > +	{ 0x40, KEY_GREEN },
> > > +	{ 0x00, KEY_YELLOW },
> > > +	{ 0x03, KEY_BLUE },
> > > +	{ 0x4a, KEY_BACK },
> > > +	{ 0x48, KEY_FORWARD },
> > > +	{ 0x08, KEY_PREVIOUSSONG},
> > > +	{ 0x0b, KEY_NEXTSONG},
> > > +	{ 0x46, KEY_PLAYPAUSE },
> > > +	{ 0x44, KEY_STOP },
> > > +	{ 0x1f, KEY_FAVORITES},	//KEY_F5?
> > > +	{ 0x04, KEY_RECORD},
> >
> > KEY_PVR?
> What's the difference between the two ? on vendor dtv app this button
> starts recording the current program

A PVR is a personal video recorder. When pressing the button you expect
the PVR app to open or start recording. The remote does say PVR.

> >
> > > +	{ 0x4d, KEY_EPG},
> > > +	{ 0x02, KEY_INFO},
> > > +	{ 0x09, KEY_SUBTITLE},
> > > +	{ 0x01, KEY_AUDIO},
> > > +	{ 0x0d, KEY_HOMEPAGE},
> > > +	{ 0x11, KEY_G},		// DTV ?
> >
> > KEY_TV?
> Ok, will use this in the next version.
> >
> > > +	{ 0x06, KEY_UP},
> > > +	{ 0x5a, KEY_LEFT},
> > > +	{ 0x1a, KEY_ENTER},	// KEY_OK ?
> > > +	{ 0x1b, KEY_RIGHT},
> > > +	{ 0x16, KEY_DOWN},
> > > +	{ 0x45, KEY_MENU},
> > > +	{ 0x05, KEY_ESC},
> > > +	{ 0x13, KEY_VOLUMEUP },
> > > +	{ 0x17, KEY_VOLUMEDOWN },
> > > +	{ 0x58, KEY_F6},
> >
> > KEY_APPSELECT?
> Ok.
> >
> > > +	{ 0x12, KEY_KATAKANA},	// mouse
> >
> > I realise mouse doesn't have a good mapping. However katakana, the
> > Japanese script, seems a little odd.
> >
> What do you suggest ? I was thinking of using KEY_VENDOR but i don't
> really know what that code does

KEY_VENDOR is for a vendor-specific key. Since this button doesn't have
a good mapping, KEY_VENDOR is fine. Keep the comment though, so it can
be updated once there is a good mapping for the mouse key.

> > > +	{ 0x55, KEY_PAGEUP},	// KEY_CHANNELUP ?
> > > +	{ 0x15, KEY_PAGEDOWN},	//KEY_CHANNELDOWN ?
> > > +	{ 0x52, KEY_1},
> > > +	{ 0x50, KEY_2},
> > > +	{ 0x10, KEY_3},
> > > +	{ 0x56, KEY_4},
> > > +	{ 0x54, KEY_5},
> > > +	{ 0x14, KEY_6},
> > > +	{ 0x4e, KEY_7},
> > > +	{ 0x4c, KEY_8},
> > > +	{ 0x0c, KEY_9},
> > > +	{ 0x18, KEY_F7},
> > > +	{ 0x0f, KEY_0},
> > > +	{ 0x51, KEY_BACKSPACE},
> > > +
> >
> > Please remove this blank line.
> Ok
> >
> > > +};
> > > +
> > > +static struct rc_map_list kii_pro_map = {
> > > +	.map = {
> > > +		.scan     = kii_pro,
> > > +		.size     = ARRAY_SIZE(kii_pro),
> > > +		.rc_proto = RC_PROTO_NEC,
> > > +		.name     = RC_MAP_KII_PRO,
> > > +	}
> > > +};
> > > +
> > > +static int __init init_rc_map_kii_pro(void)
> > > +{
> > > +	return rc_map_register(&kii_pro_map);
> > > +}
> > > +
> > > +static void __exit exit_rc_map_kii_pro(void)
> > > +{
> > > +	rc_map_unregister(&kii_pro_map);
> > > +}
> > > +
> > > +module_init(init_rc_map_kii_pro)
> > > +module_exit(exit_rc_map_kii_pro)
> > > +
> > > +MODULE_LICENSE("GPL");
> > > +MODULE_AUTHOR("Mohammad Rasim <mohammad.rasim96@xxxxxxxxx>");
> > > diff --git a/include/media/rc-map.h b/include/media/rc-map.h
> > > index afd2ab31bdf2..c2ef3906e1cd 100644
> > > --- a/include/media/rc-map.h
> > > +++ b/include/media/rc-map.h
> > > @@ -271,6 +271,7 @@ struct rc_map *rc_map_get(const char *name);
> > >  #define RC_MAP_VIDEOMATE_K100            "rc-videomate-k100"
> > >  #define RC_MAP_VIDEOMATE_S350            "rc-videomate-s350"
> > >  #define RC_MAP_VIDEOMATE_TV_PVR          "rc-videomate-tv-pvr"
> > > +#define RC_MAP_KII_PRO                   "rc-videostrong-kii-pro"
> > >  #define RC_MAP_WETEK_HUB                 "rc-wetek-hub"
> > >  #define RC_MAP_WETEK_PLAY2               "rc-wetek-play2"
> > >  #define RC_MAP_WINFAST                   "rc-winfast"
> > > --
> > > 2.24.0


Thanks
Sean



[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux