1 /* Keytable for the CEC remote control
3 * Copyright (c) 2015 by Kamil Debski
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
11 #include <media/rc-map.h>
12 #include <linux/module.h>
15 * CEC Spec "High-Definition Multimedia Interface Specification" can be obtained
16 * here: http://xtreamerdev.googlecode.com/files/CEC_Specs.pdf
17 * The list of control codes is listed in Table 27: User Control Codes p. 95
20 static struct rc_map_table cec
[] = {
26 { 0x05, KEY_RIGHT_UP
},
27 { 0x06, KEY_RIGHT_DOWN
},
28 { 0x07, KEY_LEFT_UP
},
29 { 0x08, KEY_LEFT_DOWN
},
30 { 0x09, KEY_ROOT_MENU
}, /* CEC Spec: Device Root Menu - see Note 2 */
32 * Note 2: This is the initial display that a device shows. It is
33 * device-dependent and can be, for example, a contents menu, setup
34 * menu, favorite menu or other menu. The actual menu displayed
35 * may also depend on the device's current state.
38 { 0x0b, KEY_MENU
}, /* CEC Spec: Contents Menu */
39 { 0x0c, KEY_FAVORITES
}, /* CEC Spec: Favorite Menu */
41 /* 0x0e-0x0f: Reserved */
42 { 0x10, KEY_MEDIA_TOP_MENU
},
43 { 0x11, KEY_CONTEXT_MENU
},
44 /* 0x12-0x1c: Reserved */
45 { 0x1d, KEY_DIGITS
}, /* CEC Spec: select/toggle a Number Entry Mode */
46 { 0x1e, KEY_NUMERIC_11
},
47 { 0x1f, KEY_NUMERIC_12
},
48 /* 0x20-0x29: Keys 0 to 9 */
49 { 0x20, KEY_NUMERIC_0
},
50 { 0x21, KEY_NUMERIC_1
},
51 { 0x22, KEY_NUMERIC_2
},
52 { 0x23, KEY_NUMERIC_3
},
53 { 0x24, KEY_NUMERIC_4
},
54 { 0x25, KEY_NUMERIC_5
},
55 { 0x26, KEY_NUMERIC_6
},
56 { 0x27, KEY_NUMERIC_7
},
57 { 0x28, KEY_NUMERIC_8
},
58 { 0x29, KEY_NUMERIC_9
},
62 /* 0x2d-0x2e: Reserved */
63 { 0x2f, KEY_NEXT_FAVORITE
}, /* CEC Spec: Next Favorite */
64 { 0x30, KEY_CHANNELUP
},
65 { 0x31, KEY_CHANNELDOWN
},
66 { 0x32, KEY_PREVIOUS
}, /* CEC Spec: Previous Channel */
67 { 0x33, KEY_SOUND
}, /* CEC Spec: Sound Select */
68 { 0x34, KEY_VIDEO
}, /* 0x34: CEC Spec: Input Select */
69 { 0x35, KEY_INFO
}, /* CEC Spec: Display Information */
72 { 0x38, KEY_PAGEDOWN
},
73 /* 0x39-0x3f: Reserved */
75 { 0x41, KEY_VOLUMEUP
},
76 { 0x42, KEY_VOLUMEDOWN
},
80 { 0x46, KEY_PAUSECD
},
83 { 0x49, KEY_FASTFORWARD
},
84 { 0x4a, KEY_EJECTCD
}, /* CEC Spec: Eject */
85 { 0x4b, KEY_FORWARD
},
87 { 0x4d, KEY_STOP_RECORD
}, /* CEC Spec: Stop-Record */
88 { 0x4e, KEY_PAUSE_RECORD
}, /* CEC Spec: Pause-Record */
92 { 0x52, KEY_VOD
}, /* CEC Spec: Video on Demand */
94 { 0x54, KEY_TIME
}, /* CEC Spec: Timer */
97 * The following codes are hard to implement at this moment, as they
98 * carry an additional additional argument. Most likely changes to RC
99 * framework are necessary.
100 * For now they are interpreted by the CEC framework as non keycodes
101 * and are passed as messages enabling user application to parse them.
103 /* 0x56: CEC Spec: Select Broadcast Type */
104 /* 0x57: CEC Spec: Select Sound presentation */
105 { 0x58, KEY_AUDIO_DESC
}, /* CEC 2.0 and up */
106 { 0x59, KEY_WWW
}, /* CEC 2.0 and up */
107 { 0x5a, KEY_3D_MODE
}, /* CEC 2.0 and up */
108 /* 0x5b-0x5f: Reserved */
109 { 0x60, KEY_PLAYCD
}, /* CEC Spec: Play Function */
110 { 0x6005, KEY_FASTFORWARD
},
111 { 0x6006, KEY_FASTFORWARD
},
112 { 0x6007, KEY_FASTFORWARD
},
113 { 0x6015, KEY_SLOW
},
114 { 0x6016, KEY_SLOW
},
115 { 0x6017, KEY_SLOW
},
116 { 0x6009, KEY_FASTREVERSE
},
117 { 0x600a, KEY_FASTREVERSE
},
118 { 0x600b, KEY_FASTREVERSE
},
119 { 0x6019, KEY_SLOWREVERSE
},
120 { 0x601a, KEY_SLOWREVERSE
},
121 { 0x601b, KEY_SLOWREVERSE
},
122 { 0x6020, KEY_REWIND
},
123 { 0x6024, KEY_PLAYCD
},
124 { 0x6025, KEY_PAUSECD
},
125 { 0x61, KEY_PLAYPAUSE
}, /* CEC Spec: Pause-Play Function */
126 { 0x62, KEY_RECORD
}, /* Spec: Record Function */
127 { 0x63, KEY_PAUSE_RECORD
}, /* CEC Spec: Pause-Record Function */
128 { 0x64, KEY_STOPCD
}, /* CEC Spec: Stop Function */
129 { 0x65, KEY_MUTE
}, /* CEC Spec: Mute Function */
130 { 0x66, KEY_UNMUTE
}, /* CEC Spec: Restore the volume */
132 * The following codes are hard to implement at this moment, as they
133 * carry an additional additional argument. Most likely changes to RC
134 * framework are necessary.
135 * For now they are interpreted by the CEC framework as non keycodes
136 * and are passed as messages enabling user application to parse them.
138 /* 0x67: CEC Spec: Tune Function */
139 /* 0x68: CEC Spec: Seleect Media Function */
140 /* 0x69: CEC Spec: Select A/V Input Function */
141 /* 0x6a: CEC Spec: Select Audio Input Function */
142 { 0x6b, KEY_POWER
}, /* CEC Spec: Power Toggle Function */
143 { 0x6c, KEY_SLEEP
}, /* CEC Spec: Power Off Function */
144 { 0x6d, KEY_WAKEUP
}, /* CEC Spec: Power On Function */
145 /* 0x6e-0x70: Reserved */
146 { 0x71, KEY_BLUE
}, /* CEC Spec: F1 (Blue) */
147 { 0x72, KEY_RED
}, /* CEC Spec: F2 (Red) */
148 { 0x73, KEY_GREEN
}, /* CEC Spec: F3 (Green) */
149 { 0x74, KEY_YELLOW
}, /* CEC Spec: F4 (Yellow) */
151 { 0x76, KEY_DATA
}, /* CEC Spec: Data - see Note 3 */
153 * Note 3: This is used, for example, to enter or leave a digital TV
154 * data broadcast application.
156 /* 0x77-0xff: Reserved */
159 static struct rc_map_list cec_map
= {
162 .size
= ARRAY_SIZE(cec
),
163 .rc_proto
= RC_PROTO_CEC
,
168 static int __init
init_rc_map_cec(void)
170 return rc_map_register(&cec_map
);
173 static void __exit
exit_rc_map_cec(void)
175 rc_map_unregister(&cec_map
);
178 module_init(init_rc_map_cec
);
179 module_exit(exit_rc_map_cec
);
181 MODULE_LICENSE("GPL");
182 MODULE_AUTHOR("Kamil Debski");