xref: /OK3568_Linux_fs/kernel/drivers/media/rc/keymaps/rc-cec.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0-or-later
2*4882a593Smuzhiyun /* Keytable for the CEC remote control
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * This keymap is unusual in that it can't be built as a module,
5*4882a593Smuzhiyun  * instead it is registered directly in rc-main.c if CONFIG_MEDIA_CEC_RC
6*4882a593Smuzhiyun  * is set. This is because it can be called from drm_dp_cec_set_edid() via
7*4882a593Smuzhiyun  * cec_register_adapter() in an asynchronous context, and it is not
8*4882a593Smuzhiyun  * allowed to use request_module() to load rc-cec.ko in that case.
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  * Since this keymap is only used if CONFIG_MEDIA_CEC_RC is set, we
11*4882a593Smuzhiyun  * just compile this keymap into the rc-core module and never as a
12*4882a593Smuzhiyun  * separate module.
13*4882a593Smuzhiyun  *
14*4882a593Smuzhiyun  * Copyright (c) 2015 by Kamil Debski
15*4882a593Smuzhiyun  */
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #include <media/rc-map.h>
18*4882a593Smuzhiyun #include <linux/module.h>
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun /*
21*4882a593Smuzhiyun  * CEC Spec "High-Definition Multimedia Interface Specification" can be obtained
22*4882a593Smuzhiyun  * here: http://xtreamerdev.googlecode.com/files/CEC_Specs.pdf
23*4882a593Smuzhiyun  * The list of control codes is listed in Table 27: User Control Codes p. 95
24*4882a593Smuzhiyun  */
25*4882a593Smuzhiyun 
26*4882a593Smuzhiyun static struct rc_map_table cec[] = {
27*4882a593Smuzhiyun 	{ 0x00, KEY_OK },
28*4882a593Smuzhiyun 	{ 0x01, KEY_UP },
29*4882a593Smuzhiyun 	{ 0x02, KEY_DOWN },
30*4882a593Smuzhiyun 	{ 0x03, KEY_LEFT },
31*4882a593Smuzhiyun 	{ 0x04, KEY_RIGHT },
32*4882a593Smuzhiyun 	{ 0x05, KEY_RIGHT_UP },
33*4882a593Smuzhiyun 	{ 0x06, KEY_RIGHT_DOWN },
34*4882a593Smuzhiyun 	{ 0x07, KEY_LEFT_UP },
35*4882a593Smuzhiyun 	{ 0x08, KEY_LEFT_DOWN },
36*4882a593Smuzhiyun 	{ 0x09, KEY_ROOT_MENU }, /* CEC Spec: Device Root Menu - see Note 2 */
37*4882a593Smuzhiyun 	/*
38*4882a593Smuzhiyun 	 * Note 2: This is the initial display that a device shows. It is
39*4882a593Smuzhiyun 	 * device-dependent and can be, for example, a contents menu, setup
40*4882a593Smuzhiyun 	 * menu, favorite menu or other menu. The actual menu displayed
41*4882a593Smuzhiyun 	 * may also depend on the device's current state.
42*4882a593Smuzhiyun 	 */
43*4882a593Smuzhiyun 	{ 0x0a, KEY_SETUP },
44*4882a593Smuzhiyun 	{ 0x0b, KEY_MENU }, /* CEC Spec: Contents Menu */
45*4882a593Smuzhiyun 	{ 0x0c, KEY_FAVORITES }, /* CEC Spec: Favorite Menu */
46*4882a593Smuzhiyun 	{ 0x0d, KEY_EXIT },
47*4882a593Smuzhiyun 	/* 0x0e-0x0f: Reserved */
48*4882a593Smuzhiyun 	{ 0x10, KEY_MEDIA_TOP_MENU },
49*4882a593Smuzhiyun 	{ 0x11, KEY_CONTEXT_MENU },
50*4882a593Smuzhiyun 	/* 0x12-0x1c: Reserved */
51*4882a593Smuzhiyun 	{ 0x1d, KEY_DIGITS }, /* CEC Spec: select/toggle a Number Entry Mode */
52*4882a593Smuzhiyun 	{ 0x1e, KEY_NUMERIC_11 },
53*4882a593Smuzhiyun 	{ 0x1f, KEY_NUMERIC_12 },
54*4882a593Smuzhiyun 	/* 0x20-0x29: Keys 0 to 9 */
55*4882a593Smuzhiyun 	{ 0x20, KEY_NUMERIC_0 },
56*4882a593Smuzhiyun 	{ 0x21, KEY_NUMERIC_1 },
57*4882a593Smuzhiyun 	{ 0x22, KEY_NUMERIC_2 },
58*4882a593Smuzhiyun 	{ 0x23, KEY_NUMERIC_3 },
59*4882a593Smuzhiyun 	{ 0x24, KEY_NUMERIC_4 },
60*4882a593Smuzhiyun 	{ 0x25, KEY_NUMERIC_5 },
61*4882a593Smuzhiyun 	{ 0x26, KEY_NUMERIC_6 },
62*4882a593Smuzhiyun 	{ 0x27, KEY_NUMERIC_7 },
63*4882a593Smuzhiyun 	{ 0x28, KEY_NUMERIC_8 },
64*4882a593Smuzhiyun 	{ 0x29, KEY_NUMERIC_9 },
65*4882a593Smuzhiyun 	{ 0x2a, KEY_DOT },
66*4882a593Smuzhiyun 	{ 0x2b, KEY_ENTER },
67*4882a593Smuzhiyun 	{ 0x2c, KEY_CLEAR },
68*4882a593Smuzhiyun 	/* 0x2d-0x2e: Reserved */
69*4882a593Smuzhiyun 	{ 0x2f, KEY_NEXT_FAVORITE }, /* CEC Spec: Next Favorite */
70*4882a593Smuzhiyun 	{ 0x30, KEY_CHANNELUP },
71*4882a593Smuzhiyun 	{ 0x31, KEY_CHANNELDOWN },
72*4882a593Smuzhiyun 	{ 0x32, KEY_PREVIOUS }, /* CEC Spec: Previous Channel */
73*4882a593Smuzhiyun 	{ 0x33, KEY_SOUND }, /* CEC Spec: Sound Select */
74*4882a593Smuzhiyun 	{ 0x34, KEY_VIDEO }, /* 0x34: CEC Spec: Input Select */
75*4882a593Smuzhiyun 	{ 0x35, KEY_INFO }, /* CEC Spec: Display Information */
76*4882a593Smuzhiyun 	{ 0x36, KEY_HELP },
77*4882a593Smuzhiyun 	{ 0x37, KEY_PAGEUP },
78*4882a593Smuzhiyun 	{ 0x38, KEY_PAGEDOWN },
79*4882a593Smuzhiyun 	/* 0x39-0x3f: Reserved */
80*4882a593Smuzhiyun 	{ 0x40, KEY_POWER },
81*4882a593Smuzhiyun 	{ 0x41, KEY_VOLUMEUP },
82*4882a593Smuzhiyun 	{ 0x42, KEY_VOLUMEDOWN },
83*4882a593Smuzhiyun 	{ 0x43, KEY_MUTE },
84*4882a593Smuzhiyun 	{ 0x44, KEY_PLAYCD },
85*4882a593Smuzhiyun 	{ 0x45, KEY_STOPCD },
86*4882a593Smuzhiyun 	{ 0x46, KEY_PAUSECD },
87*4882a593Smuzhiyun 	{ 0x47, KEY_RECORD },
88*4882a593Smuzhiyun 	{ 0x48, KEY_REWIND },
89*4882a593Smuzhiyun 	{ 0x49, KEY_FASTFORWARD },
90*4882a593Smuzhiyun 	{ 0x4a, KEY_EJECTCD }, /* CEC Spec: Eject */
91*4882a593Smuzhiyun 	{ 0x4b, KEY_FORWARD },
92*4882a593Smuzhiyun 	{ 0x4c, KEY_BACK },
93*4882a593Smuzhiyun 	{ 0x4d, KEY_STOP_RECORD }, /* CEC Spec: Stop-Record */
94*4882a593Smuzhiyun 	{ 0x4e, KEY_PAUSE_RECORD }, /* CEC Spec: Pause-Record */
95*4882a593Smuzhiyun 	/* 0x4f: Reserved */
96*4882a593Smuzhiyun 	{ 0x50, KEY_ANGLE },
97*4882a593Smuzhiyun 	{ 0x51, KEY_TV2 },
98*4882a593Smuzhiyun 	{ 0x52, KEY_VOD }, /* CEC Spec: Video on Demand */
99*4882a593Smuzhiyun 	{ 0x53, KEY_EPG },
100*4882a593Smuzhiyun 	{ 0x54, KEY_TIME }, /* CEC Spec: Timer */
101*4882a593Smuzhiyun 	{ 0x55, KEY_CONFIG },
102*4882a593Smuzhiyun 	/*
103*4882a593Smuzhiyun 	 * The following codes are hard to implement at this moment, as they
104*4882a593Smuzhiyun 	 * carry an additional additional argument. Most likely changes to RC
105*4882a593Smuzhiyun 	 * framework are necessary.
106*4882a593Smuzhiyun 	 * For now they are interpreted by the CEC framework as non keycodes
107*4882a593Smuzhiyun 	 * and are passed as messages enabling user application to parse them.
108*4882a593Smuzhiyun 	 */
109*4882a593Smuzhiyun 	/* 0x56: CEC Spec: Select Broadcast Type */
110*4882a593Smuzhiyun 	/* 0x57: CEC Spec: Select Sound presentation */
111*4882a593Smuzhiyun 	{ 0x58, KEY_AUDIO_DESC }, /* CEC 2.0 and up */
112*4882a593Smuzhiyun 	{ 0x59, KEY_WWW }, /* CEC 2.0 and up */
113*4882a593Smuzhiyun 	{ 0x5a, KEY_3D_MODE }, /* CEC 2.0 and up */
114*4882a593Smuzhiyun 	/* 0x5b-0x5f: Reserved */
115*4882a593Smuzhiyun 	{ 0x60, KEY_PLAYCD }, /* CEC Spec: Play Function */
116*4882a593Smuzhiyun 	{ 0x6005, KEY_FASTFORWARD },
117*4882a593Smuzhiyun 	{ 0x6006, KEY_FASTFORWARD },
118*4882a593Smuzhiyun 	{ 0x6007, KEY_FASTFORWARD },
119*4882a593Smuzhiyun 	{ 0x6015, KEY_SLOW },
120*4882a593Smuzhiyun 	{ 0x6016, KEY_SLOW },
121*4882a593Smuzhiyun 	{ 0x6017, KEY_SLOW },
122*4882a593Smuzhiyun 	{ 0x6009, KEY_FASTREVERSE },
123*4882a593Smuzhiyun 	{ 0x600a, KEY_FASTREVERSE },
124*4882a593Smuzhiyun 	{ 0x600b, KEY_FASTREVERSE },
125*4882a593Smuzhiyun 	{ 0x6019, KEY_SLOWREVERSE },
126*4882a593Smuzhiyun 	{ 0x601a, KEY_SLOWREVERSE },
127*4882a593Smuzhiyun 	{ 0x601b, KEY_SLOWREVERSE },
128*4882a593Smuzhiyun 	{ 0x6020, KEY_REWIND },
129*4882a593Smuzhiyun 	{ 0x6024, KEY_PLAYCD },
130*4882a593Smuzhiyun 	{ 0x6025, KEY_PAUSECD },
131*4882a593Smuzhiyun 	{ 0x61, KEY_PLAYPAUSE }, /* CEC Spec: Pause-Play Function */
132*4882a593Smuzhiyun 	{ 0x62, KEY_RECORD }, /* Spec: Record Function */
133*4882a593Smuzhiyun 	{ 0x63, KEY_PAUSE_RECORD }, /* CEC Spec: Pause-Record Function */
134*4882a593Smuzhiyun 	{ 0x64, KEY_STOPCD }, /* CEC Spec: Stop Function */
135*4882a593Smuzhiyun 	{ 0x65, KEY_MUTE }, /* CEC Spec: Mute Function */
136*4882a593Smuzhiyun 	{ 0x66, KEY_UNMUTE }, /* CEC Spec: Restore the volume */
137*4882a593Smuzhiyun 	/*
138*4882a593Smuzhiyun 	 * The following codes are hard to implement at this moment, as they
139*4882a593Smuzhiyun 	 * carry an additional additional argument. Most likely changes to RC
140*4882a593Smuzhiyun 	 * framework are necessary.
141*4882a593Smuzhiyun 	 * For now they are interpreted by the CEC framework as non keycodes
142*4882a593Smuzhiyun 	 * and are passed as messages enabling user application to parse them.
143*4882a593Smuzhiyun 	 */
144*4882a593Smuzhiyun 	/* 0x67: CEC Spec: Tune Function */
145*4882a593Smuzhiyun 	/* 0x68: CEC Spec: Seleect Media Function */
146*4882a593Smuzhiyun 	/* 0x69: CEC Spec: Select A/V Input Function */
147*4882a593Smuzhiyun 	/* 0x6a: CEC Spec: Select Audio Input Function */
148*4882a593Smuzhiyun 	{ 0x6b, KEY_POWER }, /* CEC Spec: Power Toggle Function */
149*4882a593Smuzhiyun 	{ 0x6c, KEY_SLEEP }, /* CEC Spec: Power Off Function */
150*4882a593Smuzhiyun 	{ 0x6d, KEY_WAKEUP }, /* CEC Spec: Power On Function */
151*4882a593Smuzhiyun 	/* 0x6e-0x70: Reserved */
152*4882a593Smuzhiyun 	{ 0x71, KEY_BLUE }, /* CEC Spec: F1 (Blue) */
153*4882a593Smuzhiyun 	{ 0x72, KEY_RED }, /* CEC Spec: F2 (Red) */
154*4882a593Smuzhiyun 	{ 0x73, KEY_GREEN }, /* CEC Spec: F3 (Green) */
155*4882a593Smuzhiyun 	{ 0x74, KEY_YELLOW }, /* CEC Spec: F4 (Yellow) */
156*4882a593Smuzhiyun 	{ 0x75, KEY_F5 },
157*4882a593Smuzhiyun 	{ 0x76, KEY_DATA }, /* CEC Spec: Data - see Note 3 */
158*4882a593Smuzhiyun 	/*
159*4882a593Smuzhiyun 	 * Note 3: This is used, for example, to enter or leave a digital TV
160*4882a593Smuzhiyun 	 * data broadcast application.
161*4882a593Smuzhiyun 	 */
162*4882a593Smuzhiyun 	/* 0x77-0xff: Reserved */
163*4882a593Smuzhiyun };
164*4882a593Smuzhiyun 
165*4882a593Smuzhiyun struct rc_map_list cec_map = {
166*4882a593Smuzhiyun 	.map = {
167*4882a593Smuzhiyun 		.scan		= cec,
168*4882a593Smuzhiyun 		.size		= ARRAY_SIZE(cec),
169*4882a593Smuzhiyun 		.rc_proto	= RC_PROTO_CEC,
170*4882a593Smuzhiyun 		.name		= RC_MAP_CEC,
171*4882a593Smuzhiyun 	}
172*4882a593Smuzhiyun };
173