1a10e763bSThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
2517b5007SSean Young /*
3517b5007SSean Young  * keymap imported from cxusb.c
4517b5007SSean Young  *
5517b5007SSean Young  * Copyright (C) 2016 Sean Young
6517b5007SSean Young  */
7517b5007SSean Young 
8517b5007SSean Young #include <media/rc-map.h>
9517b5007SSean Young #include <linux/module.h>
10517b5007SSean Young 
11517b5007SSean Young static struct rc_map_table rc_map_d680_dmb_table[] = {
12517b5007SSean Young 	{ 0x0038, KEY_SWITCHVIDEOMODE },	/* TV/AV */
13517b5007SSean Young 	{ 0x080c, KEY_ZOOM },
141910ea42SBastien Nocera 	{ 0x0800, KEY_NUMERIC_0 },
151910ea42SBastien Nocera 	{ 0x0001, KEY_NUMERIC_1 },
161910ea42SBastien Nocera 	{ 0x0802, KEY_NUMERIC_2 },
171910ea42SBastien Nocera 	{ 0x0003, KEY_NUMERIC_3 },
181910ea42SBastien Nocera 	{ 0x0804, KEY_NUMERIC_4 },
191910ea42SBastien Nocera 	{ 0x0005, KEY_NUMERIC_5 },
201910ea42SBastien Nocera 	{ 0x0806, KEY_NUMERIC_6 },
211910ea42SBastien Nocera 	{ 0x0007, KEY_NUMERIC_7 },
221910ea42SBastien Nocera 	{ 0x0808, KEY_NUMERIC_8 },
231910ea42SBastien Nocera 	{ 0x0009, KEY_NUMERIC_9 },
24517b5007SSean Young 	{ 0x000a, KEY_MUTE },
25517b5007SSean Young 	{ 0x0829, KEY_BACK },
26517b5007SSean Young 	{ 0x0012, KEY_CHANNELUP },
27517b5007SSean Young 	{ 0x0813, KEY_CHANNELDOWN },
28517b5007SSean Young 	{ 0x002b, KEY_VOLUMEUP },
29517b5007SSean Young 	{ 0x082c, KEY_VOLUMEDOWN },
30517b5007SSean Young 	{ 0x0020, KEY_UP },
31517b5007SSean Young 	{ 0x0821, KEY_DOWN },
32517b5007SSean Young 	{ 0x0011, KEY_LEFT },
33517b5007SSean Young 	{ 0x0810, KEY_RIGHT },
34517b5007SSean Young 	{ 0x000d, KEY_OK },
35517b5007SSean Young 	{ 0x081f, KEY_RECORD },
36517b5007SSean Young 	{ 0x0017, KEY_PLAYPAUSE },
37517b5007SSean Young 	{ 0x0816, KEY_PLAYPAUSE },
38517b5007SSean Young 	{ 0x000b, KEY_STOP },
39517b5007SSean Young 	{ 0x0827, KEY_FASTFORWARD },
40517b5007SSean Young 	{ 0x0026, KEY_REWIND },
41517b5007SSean Young 	{ 0x081e, KEY_UNKNOWN },    /* Time Shift */
42517b5007SSean Young 	{ 0x000e, KEY_UNKNOWN },    /* Snapshot */
43517b5007SSean Young 	{ 0x082d, KEY_UNKNOWN },    /* Mouse Cursor */
44517b5007SSean Young 	{ 0x000f, KEY_UNKNOWN },    /* Minimize/Maximize */
45517b5007SSean Young 	{ 0x0814, KEY_SHUFFLE },    /* Shuffle */
46517b5007SSean Young 	{ 0x0025, KEY_POWER },
47517b5007SSean Young };
48517b5007SSean Young 
49517b5007SSean Young static struct rc_map_list d680_dmb_map = {
50517b5007SSean Young 	.map = {
51517b5007SSean Young 		.scan     = rc_map_d680_dmb_table,
52517b5007SSean Young 		.size     = ARRAY_SIZE(rc_map_d680_dmb_table),
536d741bfeSSean Young 		.rc_proto = RC_PROTO_UNKNOWN,	/* Legacy IR type */
54517b5007SSean Young 		.name     = RC_MAP_D680_DMB,
55517b5007SSean Young 	}
56517b5007SSean Young };
57517b5007SSean Young 
init_rc_map_d680_dmb(void)58517b5007SSean Young static int __init init_rc_map_d680_dmb(void)
59517b5007SSean Young {
60517b5007SSean Young 	return rc_map_register(&d680_dmb_map);
61517b5007SSean Young }
62517b5007SSean Young 
exit_rc_map_d680_dmb(void)63517b5007SSean Young static void __exit exit_rc_map_d680_dmb(void)
64517b5007SSean Young {
65517b5007SSean Young 	rc_map_unregister(&d680_dmb_map);
66517b5007SSean Young }
67517b5007SSean Young 
68517b5007SSean Young module_init(init_rc_map_d680_dmb)
69517b5007SSean Young module_exit(exit_rc_map_d680_dmb)
70517b5007SSean Young 
71517b5007SSean Young MODULE_LICENSE("GPL");
72517b5007SSean Young MODULE_AUTHOR("Mauro Carvalho Chehab");
73