1688c73c6SMauro Carvalho Chehab // SPDX-License-Identifier: GPL-2.0+
2688c73c6SMauro Carvalho Chehab // pv951.h - Keytable for pv951 Remote Controller
3688c73c6SMauro Carvalho Chehab //
4688c73c6SMauro Carvalho Chehab // keymap imported from ir-keymaps.c
5688c73c6SMauro Carvalho Chehab //
6688c73c6SMauro Carvalho Chehab // Copyright (c) 2010 by Mauro Carvalho Chehab
732cf86f6SMauro Carvalho Chehab
832cf86f6SMauro Carvalho Chehab #include <media/rc-map.h>
97a707b89SPaul Gortmaker #include <linux/module.h>
1032cf86f6SMauro Carvalho Chehab
1132cf86f6SMauro Carvalho Chehab /* Mark Phalan <phalanm@o2.ie> */
1232cf86f6SMauro Carvalho Chehab
132f4f58d6SMauro Carvalho Chehab static struct rc_map_table pv951[] = {
14*1910ea42SBastien Nocera { 0x00, KEY_NUMERIC_0 },
15*1910ea42SBastien Nocera { 0x01, KEY_NUMERIC_1 },
16*1910ea42SBastien Nocera { 0x02, KEY_NUMERIC_2 },
17*1910ea42SBastien Nocera { 0x03, KEY_NUMERIC_3 },
18*1910ea42SBastien Nocera { 0x04, KEY_NUMERIC_4 },
19*1910ea42SBastien Nocera { 0x05, KEY_NUMERIC_5 },
20*1910ea42SBastien Nocera { 0x06, KEY_NUMERIC_6 },
21*1910ea42SBastien Nocera { 0x07, KEY_NUMERIC_7 },
22*1910ea42SBastien Nocera { 0x08, KEY_NUMERIC_8 },
23*1910ea42SBastien Nocera { 0x09, KEY_NUMERIC_9 },
2432cf86f6SMauro Carvalho Chehab
2532cf86f6SMauro Carvalho Chehab { 0x12, KEY_POWER },
2632cf86f6SMauro Carvalho Chehab { 0x10, KEY_MUTE },
2732cf86f6SMauro Carvalho Chehab { 0x1f, KEY_VOLUMEDOWN },
2832cf86f6SMauro Carvalho Chehab { 0x1b, KEY_VOLUMEUP },
2932cf86f6SMauro Carvalho Chehab { 0x1a, KEY_CHANNELUP },
3032cf86f6SMauro Carvalho Chehab { 0x1e, KEY_CHANNELDOWN },
3132cf86f6SMauro Carvalho Chehab { 0x0e, KEY_PAGEUP },
3232cf86f6SMauro Carvalho Chehab { 0x1d, KEY_PAGEDOWN },
3332cf86f6SMauro Carvalho Chehab { 0x13, KEY_SOUND },
3432cf86f6SMauro Carvalho Chehab
3532cf86f6SMauro Carvalho Chehab { 0x18, KEY_KPPLUSMINUS }, /* CH +/- */
3632cf86f6SMauro Carvalho Chehab { 0x16, KEY_SUBTITLE }, /* CC */
3732cf86f6SMauro Carvalho Chehab { 0x0d, KEY_TEXT }, /* TTX */
3832cf86f6SMauro Carvalho Chehab { 0x0b, KEY_TV }, /* AIR/CBL */
3932cf86f6SMauro Carvalho Chehab { 0x11, KEY_PC }, /* PC/TV */
4032cf86f6SMauro Carvalho Chehab { 0x17, KEY_OK }, /* CH RTN */
4132cf86f6SMauro Carvalho Chehab { 0x19, KEY_MODE }, /* FUNC */
4232cf86f6SMauro Carvalho Chehab { 0x0c, KEY_SEARCH }, /* AUTOSCAN */
4332cf86f6SMauro Carvalho Chehab
4432cf86f6SMauro Carvalho Chehab /* Not sure what to do with these ones! */
456f9e46b4SMauro Carvalho Chehab { 0x0f, KEY_VIDEO }, /* SOURCE */
4632cf86f6SMauro Carvalho Chehab { 0x0a, KEY_KPPLUS }, /* +100 */
4732cf86f6SMauro Carvalho Chehab { 0x14, KEY_EQUAL }, /* SYNC */
486f9e46b4SMauro Carvalho Chehab { 0x1c, KEY_TV }, /* PC/TV */
4932cf86f6SMauro Carvalho Chehab };
5032cf86f6SMauro Carvalho Chehab
51d100e659SMauro Carvalho Chehab static struct rc_map_list pv951_map = {
5232cf86f6SMauro Carvalho Chehab .map = {
5332cf86f6SMauro Carvalho Chehab .scan = pv951,
5432cf86f6SMauro Carvalho Chehab .size = ARRAY_SIZE(pv951),
556d741bfeSSean Young .rc_proto = RC_PROTO_UNKNOWN, /* Legacy IR type */
5632cf86f6SMauro Carvalho Chehab .name = RC_MAP_PV951,
5732cf86f6SMauro Carvalho Chehab }
5832cf86f6SMauro Carvalho Chehab };
5932cf86f6SMauro Carvalho Chehab
init_rc_map_pv951(void)6032cf86f6SMauro Carvalho Chehab static int __init init_rc_map_pv951(void)
6132cf86f6SMauro Carvalho Chehab {
62d100e659SMauro Carvalho Chehab return rc_map_register(&pv951_map);
6332cf86f6SMauro Carvalho Chehab }
6432cf86f6SMauro Carvalho Chehab
exit_rc_map_pv951(void)6532cf86f6SMauro Carvalho Chehab static void __exit exit_rc_map_pv951(void)
6632cf86f6SMauro Carvalho Chehab {
67d100e659SMauro Carvalho Chehab rc_map_unregister(&pv951_map);
6832cf86f6SMauro Carvalho Chehab }
6932cf86f6SMauro Carvalho Chehab
7032cf86f6SMauro Carvalho Chehab module_init(init_rc_map_pv951)
7132cf86f6SMauro Carvalho Chehab module_exit(exit_rc_map_pv951)
7232cf86f6SMauro Carvalho Chehab
7332cf86f6SMauro Carvalho Chehab MODULE_LICENSE("GPL");
7437e59f87SMauro Carvalho Chehab MODULE_AUTHOR("Mauro Carvalho Chehab");
75