bc661a8d2d7e1840462af64357337a02cb4de8ec
[deb_libcec.git] / include / cectypes.h
1 #pragma once
2 /*
3 * This file is part of the libCEC(R) library.
4 *
5 * libCEC(R) is Copyright (C) 2011 Pulse-Eight Limited. All rights reserved.
6 * libCEC(R) is an original work, containing original code.
7 *
8 * libCEC(R) is a trademark of Pulse-Eight Limited.
9 *
10 * This program is dual-licensed; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 *
24 *
25 * Alternatively, you can license this library under a commercial license,
26 * please contact Pulse-Eight Licensing for more information.
27 *
28 * For more information contact:
29 * Pulse-Eight Licensing <license@pulse-eight.com>
30 * http://www.pulse-eight.com/
31 * http://www.pulse-eight.net/
32 */
33
34 #ifndef CECTYPES_H_
35 #define CECTYPES_H_
36
37 #include <stdint.h>
38 #include <string.h>
39
40 #if !defined(DECLSPEC)
41 #if defined(_WIN32) || defined(_WIN64)
42 #include <windows.h>
43 #if defined DLL_EXPORT
44 #define DECLSPEC __declspec(dllexport)
45 #else
46 #define DECLSPEC __declspec(dllimport)
47 #endif
48 #else
49 #define DECLSPEC
50 #endif
51 #endif
52
53 #ifdef __cplusplus
54 extern "C" {
55 namespace CEC {
56 #endif
57
58 //default physical address 1.0.0.0, HDMI port 1
59 #define CEC_DEFAULT_PHYSICAL_ADDRESS 0x1000
60 #define MSGSTART 0xFF
61 #define MSGEND 0xFE
62 #define MSGESC 0xFD
63 #define ESCOFFSET 3
64 #define CEC_BUTTON_TIMEOUT 500
65
66 #define CEC_MIN_LIB_VERSION 1
67 #define CEC_LIB_VERSION_MAJOR 1
68 #define CEC_LIB_VERSION_MINOR 2
69
70 typedef enum cec_abort_reason
71 {
72 CEC_ABORT_REASON_UNRECOGNIZED_OPCODE = 0,
73 CEC_ABORT_REASON_NOT_IN_CORRECT_MODE_TO_RESPOND = 1,
74 CEC_ABORT_REASON_CANNOT_PROVIDE_SOURCE = 2,
75 CEC_ABORT_REASON_INVALID_OPERAND = 3,
76 CEC_ABORT_REASON_REFUSED = 4
77 } cec_abort_reason;
78
79 typedef enum cec_analogue_broadcast_type
80 {
81 CEC_ANALOGUE_BROADCAST_TYPE_CABLE = 0x00,
82 CEC_ANALOGUE_BROADCAST_TYPE_SATELLITE = 0x01,
83 CEC_ANALOGUE_BROADCAST_TYPE_TERRESTIAL = 0x02
84 } cec_analogue_broadcast_type;
85
86 typedef enum cec_audio_rate
87 {
88 CEC_AUDIO_RATE_RATE_CONTROL_OFF = 0,
89 CEC_AUDIO_RATE_STANDARD_RATE_100 = 1,
90 CEC_AUDIO_RATE_FAST_RATE_MAX_101 = 2,
91 CEC_AUDIO_RATE_SLOW_RATE_MIN_99 = 3,
92 CEC_AUDIO_RATE_STANDARD_RATE_100_0 = 4,
93 CEC_AUDIO_RATE_FAST_RATE_MAX_100_1 = 5,
94 CEC_AUDIO_RATE_SLOW_RATE_MIN_99_9 = 6
95 } cec_audio_rate;
96
97 typedef enum cec_audio_status
98 {
99 CEC_AUDIO_MUTE_STATUS_MASK = 0x80,
100 CEC_AUDIO_VOLUME_STATUS_MASK = 0x7F,
101 CEC_AUDIO_VOLUME_MIN = 0x00,
102 CEC_AUDIO_VOLUME_MAX = 0x64,
103 CEC_AUDIO_VOLUME_STATUS_UNKNOWN = 0x7F
104 } cec_audio_status;
105
106 typedef enum cec_boolean
107 {
108 CEC_FALSE = 0,
109 CEC_TRUE = 1
110 } cec_boolean;
111
112 typedef enum cec_version
113 {
114 CEC_VERSION_UNKNOWN = 0x00,
115 CEC_VERSION_1_2 = 0x01,
116 CEC_VERSION_1_2A = 0x02,
117 CEC_VERSION_1_3 = 0x03,
118 CEC_VERSION_1_3A = 0x04,
119 CEC_VERSION_1_4 = 0x05
120 } cec_version;
121
122 typedef enum cec_channel_identifier
123 {
124 CEC_CHANNEL_NUMBER_FORMAT_MASK = 0xFC000000,
125 CEC_1_PART_CHANNEL_NUMBER = 0x04000000,
126 CEC_2_PART_CHANNEL_NUMBER = 0x08000000,
127 CEC_MAJOR_CHANNEL_NUMBER_MASK = 0x3FF0000,
128 CEC_MINOR_CHANNEL_NUMBER_MASK = 0xFFFF
129 } cec_channel_identifier;
130
131 typedef enum cec_deck_control_mode
132 {
133 CEC_DECK_CONTROL_MODE_SKIP_FORWARD_WIND = 1,
134 CEC_DECK_CONTROL_MODE_SKIP_REVERSE_REWIND = 2,
135 CEC_DECK_CONTROL_MODE_STOP = 3,
136 CEC_DECK_CONTROL_MODE_EJECT = 4
137 } cec_deck_control_mode;
138
139 typedef enum cec_deck_info
140 {
141 CEC_DECK_INFO_PLAY = 0x11,
142 CEC_DECK_INFO_RECORD = 0x12,
143 CEC_DECK_INFO_PLAY_REVERSE = 0x13,
144 CEC_DECK_INFO_STILL = 0x14,
145 CEC_DECK_INFO_SLOW = 0x15,
146 CEC_DECK_INFO_SLOW_REVERSE = 0x16,
147 CEC_DECK_INFO_FAST_FORWARD = 0x17,
148 CEC_DECK_INFO_FAST_REVERSE = 0x18,
149 CEC_DECK_INFO_NO_MEDIA = 0x19,
150 CEC_DECK_INFO_STOP = 0x1A,
151 CEC_DECK_INFO_SKIP_FORWARD_WIND = 0x1B,
152 CEC_DECK_INFO_SKIP_REVERSE_REWIND = 0x1C,
153 CEC_DECK_INFO_INDEX_SEARCH_FORWARD = 0x1D,
154 CEC_DECK_INFO_INDEX_SEARCH_REVERSE = 0x1E,
155 CEC_DECK_INFO_OTHER_STATUS = 0x1F
156 } cec_deck_info;
157
158 typedef enum cec_device_type
159 {
160 CEC_DEVICE_TYPE_TV = 0,
161 CEC_DEVICE_TYPE_RECORDING_DEVICE = 1,
162 CEC_DEVICE_TYPE_RESERVED = 2,
163 CEC_DEVICE_TYPE_TUNER = 3,
164 CEC_DEVICE_TYPE_PLAYBACK_DEVICE = 4,
165 CEC_DEVICE_TYPE_AUDIO_SYSTEM = 5
166 } cec_device_type;
167
168 typedef enum cec_display_control
169 {
170 CEC_DISPLAY_CONTROL_DISPLAY_FOR_DEFAULT_TIME = 0x00,
171 CEC_DISPLAY_CONTROL_DISPLAY_UNTIL_CLEARED = 0x40,
172 CEC_DISPLAY_CONTROL_CLEAR_PREVIOUS_MESSAGE = 0x80,
173 CEC_DISPLAY_CONTROL_RESERVED_FOR_FUTURE_USE = 0xC0
174 } cec_display_control;
175
176 typedef enum cec_external_source_specifier
177 {
178 CEC_EXTERNAL_SOURCE_SPECIFIER_EXTERNAL_PLUG = 4,
179 CEC_EXTERNAL_SOURCE_SPECIFIER_EXTERNAL_PHYSICAL_ADDRESS = 5
180 } cec_external_source_specifier;
181
182 typedef enum cec_menu_request_type
183 {
184 CEC_MENU_REQUEST_TYPE_ACTIVATE = 0,
185 CEC_MENU_REQUEST_TYPE_DEACTIVATE = 1,
186 CEC_MENU_REQUEST_TYPE_QUERY = 2
187 } cec_menu_request_type;
188
189 typedef enum cec_menu_state
190 {
191 CEC_MENU_STATE_ACTIVATED = 0,
192 CEC_MENU_STATE_DEACTIVATED = 1
193 } cec_menu_state;
194
195 typedef enum cec_play_mode
196 {
197 CEC_PLAY_MODE_PLAY_FORWARD = 0x24,
198 CEC_PLAY_MODE_PLAY_REVERSE = 0x20,
199 CEC_PLAY_MODE_PLAY_STILL = 0x25,
200 CEC_PLAY_MODE_FAST_FORWARD_MIN_SPEED = 0x05,
201 CEC_PLAY_MODE_FAST_FORWARD_MEDIUM_SPEED = 0x06,
202 CEC_PLAY_MODE_FAST_FORWARD_MAX_SPEED = 0x07,
203 CEC_PLAY_MODE_FAST_REVERSE_MIN_SPEED = 0x09,
204 CEC_PLAY_MODE_FAST_REVERSE_MEDIUM_SPEED = 0x0A,
205 CEC_PLAY_MODE_FAST_REVERSE_MAX_SPEED = 0x0B,
206 CEC_PLAY_MODE_SLOW_FORWARD_MIN_SPEED = 0x15,
207 CEC_PLAY_MODE_SLOW_FORWARD_MEDIUM_SPEED = 0x16,
208 CEC_PLAY_MODE_SLOW_FORWARD_MAX_SPEED = 0x17,
209 CEC_PLAY_MODE_SLOW_REVERSE_MIN_SPEED = 0x19,
210 CEC_PLAY_MODE_SLOW_REVERSE_MEDIUM_SPEED = 0x1A,
211 CEC_PLAY_MODE_SLOW_REVERSE_MAX_SPEED = 0x1B
212 } cec_play_mode;
213
214 typedef enum cec_power_status
215 {
216 CEC_POWER_STATUS_ON = 0x00,
217 CEC_POWER_STATUS_STANDBY = 0x01,
218 CEC_POWER_STATUS_IN_TRANSITION_STANDBY_TO_ON = 0x02,
219 CEC_POWER_STATUS_IN_TRANSITION_ON_TO_STANDBY = 0x03,
220 CEC_POWER_STATUS_UNKNOWN = 0x99
221 } cec_power_status;
222
223 typedef enum cec_record_source_type
224 {
225 CEC_RECORD_SOURCE_TYPE_OWN_SOURCE = 1,
226 CEC_RECORD_SOURCE_TYPE_DIGITAL_SERVICE = 2,
227 CEC_RECORD_SOURCE_TYPE_ANALOGUE_SERVICE = 3,
228 CEC_RECORD_SOURCE_TYPE_EXTERNAL_PLUS = 4,
229 CEC_RECORD_SOURCE_TYPE_EXTERNAL_PHYSICAL_ADDRESS = 5
230 } cec_record_source_type;
231
232 typedef enum cec_record_status_info
233 {
234 CEC_RECORD_STATUS_INFO_RECORDING_CURRENTLY_SELECTED_SOURCE = 0x01,
235 CEC_RECORD_STATUS_INFO_RECORDING_DIGITAL_SERVICE = 0x02,
236 CEC_RECORD_STATUS_INFO_RECORDING_ANALOGUE_SERVICE = 0x03,
237 CEC_RECORD_STATUS_INFO_RECORDING_EXTERNAL_INPUT = 0x04,
238 CEC_RECORD_STATUS_INFO_NO_RECORDING_UNABLE_TO_RECORD_DIGITAL_SERVICE = 0x05,
239 CEC_RECORD_STATUS_INFO_NO_RECORDING_UNABLE_TO_RECORD_ANALOGUE_SERVICE = 0x06,
240 CEC_RECORD_STATUS_INFO_NO_RECORDING_UNABLE_TO_SELECT_REQUIRED_SERVICE = 0x07,
241 CEC_RECORD_STATUS_INFO_NO_RECORDING_INVALID_EXTERNAL_PLUG_NUMBER = 0x09,
242 CEC_RECORD_STATUS_INFO_NO_RECORDING_INVALID_EXTERNAL_ADDRESS = 0x0A,
243 CEC_RECORD_STATUS_INFO_NO_RECORDING_CA_SYSTEM_NOT_SUPPORTED = 0x0B,
244 CEC_RECORD_STATUS_INFO_NO_RECORDING_NO_OR_INSUFFICIENT_ENTITLEMENTS = 0x0C,
245 CEC_RECORD_STATUS_INFO_NO_RECORDING_NOT_ALLOWED_TO_COPY_SOURCE = 0x0D,
246 CEC_RECORD_STATUS_INFO_NO_RECORDING_NO_FURTHER_COPIES_ALLOWED = 0x0E,
247 CEC_RECORD_STATUS_INFO_NO_RECORDING_NO_MEDIA = 0x10,
248 CEC_RECORD_STATUS_INFO_NO_RECORDING_PLAYING = 0x11,
249 CEC_RECORD_STATUS_INFO_NO_RECORDING_ALREADY_RECORDING = 0x12,
250 CEC_RECORD_STATUS_INFO_NO_RECORDING_MEDIA_PROTECTED = 0x13,
251 CEC_RECORD_STATUS_INFO_NO_RECORDING_NO_SOURCE_SIGNAL = 0x14,
252 CEC_RECORD_STATUS_INFO_NO_RECORDING_MEDIA_PROBLEM = 0x15,
253 CEC_RECORD_STATUS_INFO_NO_RECORDING_NOT_ENOUGH_SPACE_AVAILABLE = 0x16,
254 CEC_RECORD_STATUS_INFO_NO_RECORDING_PARENTAL_LOCK_ON = 0x17,
255 CEC_RECORD_STATUS_INFO_RECORDING_TERMINATED_NORMALLY = 0x1A,
256 CEC_RECORD_STATUS_INFO_RECORDING_HAS_ALREADY_TERMINATED = 0x1B,
257 CEC_RECORD_STATUS_INFO_NO_RECORDING_OTHER_REASON = 0x1F
258 } cec_record_status_info;
259
260 typedef enum cec_recording_sequence
261 {
262 CEC_RECORDING_SEQUENCE_SUNDAY = 0x01,
263 CEC_RECORDING_SEQUENCE_MONDAY = 0x02,
264 CEC_RECORDING_SEQUENCE_TUESDAY = 0x04,
265 CEC_RECORDING_SEQUENCE_WEDNESDAY = 0x08,
266 CEC_RECORDING_SEQUENCE_THURSDAY = 0x10,
267 CEC_RECORDING_SEQUENCE_FRIDAY = 0x20,
268 CEC_RECORDING_SEQUENCE_SATURDAY = 0x40,
269 CEC_RECORDING_SEQUENCE_ONCE_ONLY = 0x00
270 } cec_recording_sequence;
271
272 typedef enum cec_status_request
273 {
274 CEC_STATUS_REQUEST_ON = 1,
275 CEC_STATUS_REQUEST_OFF = 2,
276 CEC_STATUS_REQUEST_ONCE = 3
277 } cec_status_request;
278
279 typedef enum cec_system_audio_status
280 {
281 CEC_SYSTEM_AUDIO_STATUS_OFF = 0,
282 CEC_SYSTEM_AUDIO_STATUS_ON = 1
283 } cec_system_audio_status;
284
285 typedef enum cec_timer_cleared_status_data
286 {
287 CEC_TIMER_CLEARED_STATUS_DATA_TIMER_NOT_CLEARED_RECORDING = 0x00,
288 CEC_TIMER_CLEARED_STATUS_DATA_TIMER_NOT_CLEARED_NO_MATCHING = 0x01,
289 CEC_TIMER_CLEARED_STATUS_DATA_TIMER_NOT_CLEARED_NO_INF0_AVAILABLE = 0x02,
290 CEC_TIMER_CLEARED_STATUS_DATA_TIMER_CLEARED = 0x80
291 } cec_timer_cleared_status_data;
292
293 typedef enum cec_timer_overlap_warning
294 {
295 CEC_TIMER_OVERLAP_WARNING_NO_OVERLAP = 0,
296 CEC_TIMER_OVERLAP_WARNING_TIMER_BLOCKS_OVERLAP = 1
297 } cec_timer_overlap_warning;
298
299 typedef enum cec_media_info
300 {
301 CEC_MEDIA_INFO_MEDIA_PRESENT_AND_NOT_PROTECTED = 0x00,
302 CEC_MEDIA_INFO_MEDIA_PRESENT_BUT_PROTECTED = 0x01,
303 CEC_MEDIA_INFO_MEDIA_NOT_PRESENT = 0x02,
304 CEC_MEDIA_INFO_FUTURE_USE = 0x03
305 } cec_media_info;
306
307 typedef enum cec_programmed_indicator
308 {
309 CEC_PROGRAMMED_INDICATOR_NOT_PROGRAMMED = 0,
310 CEC_PROGRAMMED_INDICATOR_PROGRAMMED = 1
311 } cec_programmed_indicator;
312
313 typedef enum cec_programmed_info
314 {
315 CEC_PROGRAMMED_INFO_FUTURE_USE = 0x0,
316 CEC_PROGRAMMED_INFO_ENOUGH_SPACE_AVAILABLE_FOR_RECORDING = 0x08,
317 CEC_PROGRAMMED_INFO_NOT_ENOUGH_SPACE_AVAILABLE_FOR_RECORDING = 0x09,
318 CEC_PROGRAMMED_INFO_MAY_NOT_BE_ENOUGH_SPACE_AVAILABLE = 0x0B,
319 CEC_PROGRAMMED_INFO_NO_MEDIA_INFO_AVAILABLE = 0x0A
320 } cec_programmed_info;
321
322 typedef enum cec_not_programmed_error_info
323 {
324 CEC_NOT_PROGRAMMED_ERROR_INFO_FUTURE_USE = 0x0,
325 CEC_NOT_PROGRAMMED_ERROR_INFO_NO_FREE_TIMER_AVAILABLE = 0x01,
326 CEC_NOT_PROGRAMMED_ERROR_INFO_DATE_OUT_OF_RANGE = 0x02,
327 CEC_NOT_PROGRAMMED_ERROR_INFO_RECORDING_SEQUENCE_ERROR = 0x03,
328 CEC_NOT_PROGRAMMED_ERROR_INFO_INVALID_EXTERNAL_PLUG_NUMBER = 0x04,
329 CEC_NOT_PROGRAMMED_ERROR_INFO_INVALID_EXTERNAL_PHYSICAL_ADDRESS = 0x05,
330 CEC_NOT_PROGRAMMED_ERROR_INFO_CA_SYSTEM_NOT_SUPPORTED = 0x06,
331 CEC_NOT_PROGRAMMED_ERROR_INFO_NO_OR_INSUFFICIENT_CA_ENTITLEMENTS = 0x07,
332 CEC_NOT_PROGRAMMED_ERROR_INFO_DOES_NOT_SUPPORT_RESOLUTION = 0x08,
333 CEC_NOT_PROGRAMMED_ERROR_INFO_PARENTAL_LOCK_ON = 0x09,
334 CEC_NOT_PROGRAMMED_ERROR_INFO_CLOCK_FAILURE = 0x0A,
335 CEC_NOT_PROGRAMMED_ERROR_INFO_RESERVED_FOR_FUTURE_USE_START = 0x0B,
336 CEC_NOT_PROGRAMMED_ERROR_INFO_RESERVED_FOR_FUTURE_USE_END = 0x0D,
337 CEC_NOT_PROGRAMMED_ERROR_INFO_DUPLICATE_ALREADY_PROGRAMMED = 0x0E
338 } cec_not_programmed_error_info;
339
340 typedef enum cec_recording_flag
341 {
342 CEC_RECORDING_FLAG_NOT_BEING_USED_FOR_RECORDING = 0,
343 CEC_RECORDING_FLAG_BEING_USED_FOR_RECORDING = 1
344 } cec_recording_flag;
345
346 typedef enum cec_tuner_display_info
347 {
348 CEC_TUNER_DISPLAY_INFO_DISPLAYING_DIGITAL_TUNER = 0,
349 CEC_TUNER_DISPLAY_INFO_NOT_DISPLAYING_TUNER = 1,
350 CEC_TUNER_DISPLAY_INFO_DISPLAYING_ANALOGUE_TUNER = 2
351 } cec_tuner_display_info;
352
353 typedef enum cec_broadcast_system
354 {
355 CEC_BROADCAST_SYSTEM_PAL_B_G = 0,
356 CEC_BROADCAST_SYSTEM_SECAM_L1 = 1,
357 CEC_BROADCAST_SYSTEM_PAL_M = 2,
358 CEC_BROADCAST_SYSTEM_NTSC_M = 3,
359 CEC_BROADCAST_SYSTEM_PAL_I = 4,
360 CEC_BROADCAST_SYSTEM_SECAM_DK = 5,
361 CEC_BROADCAST_SYSTEM_SECAM_B_G = 6,
362 CEC_BROADCAST_SYSTEM_SECAM_L2 = 7,
363 CEC_BROADCAST_SYSTEM_PAL_DK = 8,
364 CEC_BROADCAST_SYSTEM_OTHER_SYSTEM = 30
365 } cec_broadcast_system;
366
367 typedef enum cec_user_control_code
368 {
369 CEC_USER_CONTROL_CODE_SELECT = 0x00,
370 CEC_USER_CONTROL_CODE_UP = 0x01,
371 CEC_USER_CONTROL_CODE_DOWN = 0x02,
372 CEC_USER_CONTROL_CODE_LEFT = 0x03,
373 CEC_USER_CONTROL_CODE_RIGHT = 0x04,
374 CEC_USER_CONTROL_CODE_RIGHT_UP = 0x05,
375 CEC_USER_CONTROL_CODE_RIGHT_DOWN = 0x06,
376 CEC_USER_CONTROL_CODE_LEFT_UP = 0x07,
377 CEC_USER_CONTROL_CODE_LEFT_DOWN = 0x08,
378 CEC_USER_CONTROL_CODE_ROOT_MENU = 0x09,
379 CEC_USER_CONTROL_CODE_SETUP_MENU = 0x0A,
380 CEC_USER_CONTROL_CODE_CONTENTS_MENU = 0x0B,
381 CEC_USER_CONTROL_CODE_FAVORITE_MENU = 0x0C,
382 CEC_USER_CONTROL_CODE_EXIT = 0x0D,
383 CEC_USER_CONTROL_CODE_NUMBER0 = 0x20,
384 CEC_USER_CONTROL_CODE_NUMBER1 = 0x21,
385 CEC_USER_CONTROL_CODE_NUMBER2 = 0x22,
386 CEC_USER_CONTROL_CODE_NUMBER3 = 0x23,
387 CEC_USER_CONTROL_CODE_NUMBER4 = 0x24,
388 CEC_USER_CONTROL_CODE_NUMBER5 = 0x25,
389 CEC_USER_CONTROL_CODE_NUMBER6 = 0x26,
390 CEC_USER_CONTROL_CODE_NUMBER7 = 0x27,
391 CEC_USER_CONTROL_CODE_NUMBER8 = 0x28,
392 CEC_USER_CONTROL_CODE_NUMBER9 = 0x29,
393 CEC_USER_CONTROL_CODE_DOT = 0x2A,
394 CEC_USER_CONTROL_CODE_ENTER = 0x2B,
395 CEC_USER_CONTROL_CODE_CLEAR = 0x2C,
396 CEC_USER_CONTROL_CODE_NEXT_FAVORITE = 0x2F,
397 CEC_USER_CONTROL_CODE_CHANNEL_UP = 0x30,
398 CEC_USER_CONTROL_CODE_CHANNEL_DOWN = 0x31,
399 CEC_USER_CONTROL_CODE_PREVIOUS_CHANNEL = 0x32,
400 CEC_USER_CONTROL_CODE_SOUND_SELECT = 0x33,
401 CEC_USER_CONTROL_CODE_INPUT_SELECT = 0x34,
402 CEC_USER_CONTROL_CODE_DISPLAY_INFORMATION = 0x35,
403 CEC_USER_CONTROL_CODE_HELP = 0x36,
404 CEC_USER_CONTROL_CODE_PAGE_UP = 0x37,
405 CEC_USER_CONTROL_CODE_PAGE_DOWN = 0x38,
406 CEC_USER_CONTROL_CODE_POWER = 0x40,
407 CEC_USER_CONTROL_CODE_VOLUME_UP = 0x41,
408 CEC_USER_CONTROL_CODE_VOLUME_DOWN = 0x42,
409 CEC_USER_CONTROL_CODE_MUTE = 0x43,
410 CEC_USER_CONTROL_CODE_PLAY = 0x44,
411 CEC_USER_CONTROL_CODE_STOP = 0x45,
412 CEC_USER_CONTROL_CODE_PAUSE = 0x46,
413 CEC_USER_CONTROL_CODE_RECORD = 0x47,
414 CEC_USER_CONTROL_CODE_REWIND = 0x48,
415 CEC_USER_CONTROL_CODE_FAST_FORWARD = 0x49,
416 CEC_USER_CONTROL_CODE_EJECT = 0x4A,
417 CEC_USER_CONTROL_CODE_FORWARD = 0x4B,
418 CEC_USER_CONTROL_CODE_BACKWARD = 0x4C,
419 CEC_USER_CONTROL_CODE_STOP_RECORD = 0x4D,
420 CEC_USER_CONTROL_CODE_PAUSE_RECORD = 0x4E,
421 CEC_USER_CONTROL_CODE_ANGLE = 0x50,
422 CEC_USER_CONTROL_CODE_SUB_PICTURE = 0x51,
423 CEC_USER_CONTROL_CODE_VIDEO_ON_DEMAND = 0x52,
424 CEC_USER_CONTROL_CODE_ELECTRONIC_PROGRAM_GUIDE = 0x53,
425 CEC_USER_CONTROL_CODE_TIMER_PROGRAMMING = 0x54,
426 CEC_USER_CONTROL_CODE_INITIAL_CONFIGURATION = 0x55,
427 CEC_USER_CONTROL_CODE_PLAY_FUNCTION = 0x60,
428 CEC_USER_CONTROL_CODE_PAUSE_PLAY_FUNCTION = 0x61,
429 CEC_USER_CONTROL_CODE_RECORD_FUNCTION = 0x62,
430 CEC_USER_CONTROL_CODE_PAUSE_RECORD_FUNCTION = 0x63,
431 CEC_USER_CONTROL_CODE_STOP_FUNCTION = 0x64,
432 CEC_USER_CONTROL_CODE_MUTE_FUNCTION = 0x65,
433 CEC_USER_CONTROL_CODE_RESTORE_VOLUME_FUNCTION = 0x66,
434 CEC_USER_CONTROL_CODE_TUNE_FUNCTION = 0x67,
435 CEC_USER_CONTROL_CODE_SELECT_MEDIA_FUNCTION = 0x68,
436 CEC_USER_CONTROL_CODE_SELECT_AV_INPUT_FUNCTION = 0x69,
437 CEC_USER_CONTROL_CODE_SELECT_AUDIO_INPUT_FUNCTION = 0x6A,
438 CEC_USER_CONTROL_CODE_POWER_TOGGLE_FUNCTION = 0x6B,
439 CEC_USER_CONTROL_CODE_POWER_OFF_FUNCTION = 0x6C,
440 CEC_USER_CONTROL_CODE_POWER_ON_FUNCTION = 0x6D,
441 CEC_USER_CONTROL_CODE_F1_BLUE = 0x71,
442 CEC_USER_CONTROL_CODE_F2_RED = 0X72,
443 CEC_USER_CONTROL_CODE_F3_GREEN = 0x73,
444 CEC_USER_CONTROL_CODE_F4_YELLOW = 0x74,
445 CEC_USER_CONTROL_CODE_F5 = 0x75,
446 CEC_USER_CONTROL_CODE_DATA = 0x76,
447 CEC_USER_CONTROL_CODE_MAX = 0x76,
448 CEC_USER_CONTROL_CODE_UNKNOWN
449 } cec_user_control_code;
450
451 typedef enum cec_an_user_control_code
452 {
453 CEC_AN_USER_CONTROL_CODE_RETURN = 0x91
454 } cec_an_user_control_code;
455
456 typedef enum cec_logical_address
457 {
458 CECDEVICE_UNKNOWN = -1, //not a valid logical address
459 CECDEVICE_TV = 0,
460 CECDEVICE_RECORDINGDEVICE1 = 1,
461 CECDEVICE_RECORDINGDEVICE2 = 2,
462 CECDEVICE_TUNER1 = 3,
463 CECDEVICE_PLAYBACKDEVICE1 = 4,
464 CECDEVICE_AUDIOSYSTEM = 5,
465 CECDEVICE_TUNER2 = 6,
466 CECDEVICE_TUNER3 = 7,
467 CECDEVICE_PLAYBACKDEVICE2 = 8,
468 CECDEVICE_RECORDINGDEVICE3 = 9,
469 CECDEVICE_TUNER4 = 10,
470 CECDEVICE_PLAYBACKDEVICE3 = 11,
471 CECDEVICE_RESERVED1 = 12,
472 CECDEVICE_RESERVED2 = 13,
473 CECDEVICE_FREEUSE = 14,
474 CECDEVICE_UNREGISTERED = 15,
475 CECDEVICE_BROADCAST = 15
476 } cec_logical_address;
477
478 typedef enum cec_opcode
479 {
480 CEC_OPCODE_ACTIVE_SOURCE = 0x82,
481 CEC_OPCODE_IMAGE_VIEW_ON = 0x04,
482 CEC_OPCODE_TEXT_VIEW_ON = 0x0D,
483 CEC_OPCODE_INACTIVE_SOURCE = 0x9D,
484 CEC_OPCODE_REQUEST_ACTIVE_SOURCE = 0x85,
485 CEC_OPCODE_ROUTING_CHANGE = 0x80,
486 CEC_OPCODE_ROUTING_INFORMATION = 0x81,
487 CEC_OPCODE_SET_STREAM_PATH = 0x86,
488 CEC_OPCODE_STANDBY = 0x36,
489 CEC_OPCODE_RECORD_OFF = 0x0B,
490 CEC_OPCODE_RECORD_ON = 0x09,
491 CEC_OPCODE_RECORD_STATUS = 0x0A,
492 CEC_OPCODE_RECORD_TV_SCREEN = 0x0F,
493 CEC_OPCODE_CLEAR_ANALOGUE_TIMER = 0x33,
494 CEC_OPCODE_CLEAR_DIGITAL_TIMER = 0x99,
495 CEC_OPCODE_CLEAR_EXTERNAL_TIMER = 0xA1,
496 CEC_OPCODE_SET_ANALOGUE_TIMER = 0x34,
497 CEC_OPCODE_SET_DIGITAL_TIMER = 0x97,
498 CEC_OPCODE_SET_EXTERNAL_TIMER = 0xA2,
499 CEC_OPCODE_SET_TIMER_PROGRAM_TITLE = 0x67,
500 CEC_OPCODE_TIMER_CLEARED_STATUS = 0x43,
501 CEC_OPCODE_TIMER_STATUS = 0x35,
502 CEC_OPCODE_CEC_VERSION = 0x9E,
503 CEC_OPCODE_GET_CEC_VERSION = 0x9F,
504 CEC_OPCODE_GIVE_PHYSICAL_ADDRESS = 0x83,
505 CEC_OPCODE_GET_MENU_LANGUAGE = 0x91,
506 CEC_OPCODE_REPORT_PHYSICAL_ADDRESS = 0x84,
507 CEC_OPCODE_SET_MENU_LANGUAGE = 0x32,
508 CEC_OPCODE_DECK_CONTROL = 0x42,
509 CEC_OPCODE_DECK_STATUS = 0x1B,
510 CEC_OPCODE_GIVE_DECK_STATUS = 0x1A,
511 CEC_OPCODE_PLAY = 0x41,
512 CEC_OPCODE_GIVE_TUNER_DEVICE_STATUS = 0x08,
513 CEC_OPCODE_SELECT_ANALOGUE_SERVICE = 0x92,
514 CEC_OPCODE_SELECT_DIGITAL_SERVICE = 0x93,
515 CEC_OPCODE_TUNER_DEVICE_STATUS = 0x07,
516 CEC_OPCODE_TUNER_STEP_DECREMENT = 0x06,
517 CEC_OPCODE_TUNER_STEP_INCREMENT = 0x05,
518 CEC_OPCODE_DEVICE_VENDOR_ID = 0x87,
519 CEC_OPCODE_GIVE_DEVICE_VENDOR_ID = 0x8C,
520 CEC_OPCODE_VENDOR_COMMAND = 0x89,
521 CEC_OPCODE_VENDOR_COMMAND_WITH_ID = 0xA0,
522 CEC_OPCODE_VENDOR_REMOTE_BUTTON_DOWN = 0x8A,
523 CEC_OPCODE_VENDOR_REMOTE_BUTTON_UP = 0x8B,
524 CEC_OPCODE_SET_OSD_STRING = 0x64,
525 CEC_OPCODE_GIVE_OSD_NAME = 0x46,
526 CEC_OPCODE_SET_OSD_NAME = 0x47,
527 CEC_OPCODE_MENU_REQUEST = 0x8D,
528 CEC_OPCODE_MENU_STATUS = 0x8E,
529 CEC_OPCODE_USER_CONTROL_PRESSED = 0x44,
530 CEC_OPCODE_USER_CONTROL_RELEASE = 0x45,
531 CEC_OPCODE_GIVE_DEVICE_POWER_STATUS = 0x8F,
532 CEC_OPCODE_REPORT_POWER_STATUS = 0x90,
533 CEC_OPCODE_FEATURE_ABORT = 0x00,
534 CEC_OPCODE_ABORT = 0xFF,
535 CEC_OPCODE_GIVE_AUDIO_STATUS = 0x71,
536 CEC_OPCODE_GIVE_SYSTEM_AUDIO_MODE_STATUS = 0x7D,
537 CEC_OPCODE_REPORT_AUDIO_STATUS = 0x7A,
538 CEC_OPCODE_SET_SYSTEM_AUDIO_MODE = 0x72,
539 CEC_OPCODE_SYSTEM_AUDIO_MODE_REQUEST = 0x70,
540 CEC_OPCODE_SYSTEM_AUDIO_MODE_STATUS = 0x7E,
541 CEC_OPCODE_SET_AUDIO_RATE = 0x9A,
542 /* when this opcode is set, no opcode will be sent to the device. this is one of the reserved numbers */
543 CEC_OPCODE_NONE = 0xFD
544 } cec_opcode;
545
546 typedef enum cec_log_level
547 {
548 CEC_LOG_ERROR = 1,
549 CEC_LOG_WARNING = 2,
550 CEC_LOG_NOTICE = 4,
551 CEC_LOG_TRAFFIC = 8,
552 CEC_LOG_DEBUG = 16,
553 CEC_LOG_ALL = 31
554 } cec_log_level;
555
556 typedef enum cec_adapter_messagecode
557 {
558 MSGCODE_NOTHING = 0,
559 MSGCODE_PING,
560 MSGCODE_TIMEOUT_ERROR,
561 MSGCODE_HIGH_ERROR,
562 MSGCODE_LOW_ERROR,
563 MSGCODE_FRAME_START,
564 MSGCODE_FRAME_DATA,
565 MSGCODE_RECEIVE_FAILED,
566 MSGCODE_COMMAND_ACCEPTED,
567 MSGCODE_COMMAND_REJECTED,
568 MSGCODE_SET_ACK_MASK,
569 MSGCODE_TRANSMIT,
570 MSGCODE_TRANSMIT_EOM,
571 MSGCODE_TRANSMIT_IDLETIME,
572 MSGCODE_TRANSMIT_ACK_POLARITY,
573 MSGCODE_TRANSMIT_LINE_TIMEOUT,
574 MSGCODE_TRANSMIT_SUCCEEDED,
575 MSGCODE_TRANSMIT_FAILED_LINE,
576 MSGCODE_TRANSMIT_FAILED_ACK,
577 MSGCODE_TRANSMIT_FAILED_TIMEOUT_DATA,
578 MSGCODE_TRANSMIT_FAILED_TIMEOUT_LINE,
579 MSGCODE_FIRMWARE_VERSION,
580 MSGCODE_START_BOOTLOADER,
581 MSGCODE_FRAME_EOM = 0x80,
582 MSGCODE_FRAME_ACK = 0x40,
583 } cec_adapter_messagecode;
584
585 typedef enum cec_bus_device_status
586 {
587 CEC_DEVICE_STATUS_UNKNOWN,
588 CEC_DEVICE_STATUS_PRESENT,
589 CEC_DEVICE_STATUS_NOT_PRESENT,
590 CEC_DEVICE_STATUS_HANDLED_BY_LIBCEC
591 } cec_bus_device_status;
592
593 typedef enum cec_vendor_id
594 {
595 CEC_VENDOR_SAMSUNG = 0x00F0,
596 CEC_VENDOR_LG = 0xE091,
597 CEC_VENDOR_PANASONIC = 0x8045,
598 CEC_VENDOR_PIONEER = 0xE036,
599 CEC_VENDOR_ONKYO = 0x09B0,
600 CEC_VENDOR_UNKNOWN = 0
601 } cec_vendor_id;
602
603 typedef struct cec_menu_language
604 {
605 char language[4];
606 cec_logical_address device;
607 } cec_menu_language;
608
609 typedef struct cec_log_message
610 {
611 char message[1024];
612 cec_log_level level;
613 int64_t time;
614 } cec_log_message;
615
616 typedef struct cec_keypress
617 {
618 cec_user_control_code keycode;
619 unsigned int duration;
620 } cec_keypress;
621
622 typedef struct cec_adapter
623 {
624 char path[1024];
625 char comm[1024];
626 } cec_adapter;
627
628 typedef struct cec_datapacket
629 {
630 uint8_t data[100];
631 uint8_t size;
632
633 #ifdef __cplusplus
634 cec_datapacket &operator =(const struct cec_datapacket &packet)
635 {
636 Clear();
637 for (uint8_t iPtr = 0; iPtr < packet.size; iPtr++)
638 PushBack(packet[iPtr]);
639
640 return *this;
641 }
642
643 bool IsEmpty(void) const { return size == 0; }
644 bool IsFull(void) const { return size == 100; }
645 uint8_t operator[](uint8_t pos) const { return pos < size ? data[pos] : 0; }
646 uint8_t At(uint8_t pos) const { return pos < size ? data[pos] : 0; }
647
648 void Shift(uint8_t iShiftBy)
649 {
650 if (iShiftBy >= size)
651 {
652 Clear();
653 }
654 else
655 {
656 for (uint8_t iPtr = 0; iPtr < size; iPtr++)
657 data[iPtr] = (iPtr + iShiftBy < size) ? data[iPtr + iShiftBy] : 0;
658 size = (uint8_t) (size - iShiftBy);
659 }
660 }
661
662 void PushBack(uint8_t add)
663 {
664 if (size < 100)
665 data[size++] = add;
666 }
667
668 void Clear(void)
669 {
670 memset(data, 0, sizeof(data));
671 size = 0;
672 }
673 #endif
674
675 } cec_datapacket;
676
677 typedef struct cec_command
678 {
679 cec_logical_address initiator;
680 cec_logical_address destination;
681 int8_t ack;
682 int8_t eom;
683 cec_opcode opcode;
684 cec_datapacket parameters;
685 int8_t opcode_set;
686 int32_t transmit_timeout;
687
688 #ifdef __cplusplus
689 cec_command &operator =(const struct cec_command &command)
690 {
691 initiator = command.initiator;
692 destination = command.destination;
693 ack = command.ack;
694 eom = command.eom;
695 opcode = command.opcode;
696 opcode_set = command.opcode_set;
697 transmit_timeout = command.transmit_timeout;
698 parameters = command.parameters;
699
700 return *this;
701 }
702
703 static void Format(cec_command &command, cec_logical_address initiator, cec_logical_address destination, cec_opcode opcode)
704 {
705 command.Clear();
706 command.initiator = initiator;
707 command.destination = destination;
708 if (opcode != CEC_OPCODE_NONE)
709 {
710 command.opcode = opcode;
711 command.opcode_set = 1;
712 }
713 }
714
715 void PushBack(uint8_t data)
716 {
717 if (initiator == CECDEVICE_UNKNOWN && destination == CECDEVICE_UNKNOWN)
718 {
719 initiator = (cec_logical_address) (data >> 4);
720 destination = (cec_logical_address) (data & 0xF);
721 }
722 else if (!opcode_set)
723 {
724 opcode_set = 1;
725 opcode = (cec_opcode) data;
726 }
727 else
728 parameters.PushBack(data);
729 }
730
731 void Clear(void)
732 {
733 initiator = CECDEVICE_UNKNOWN;
734 destination = CECDEVICE_UNKNOWN;
735 ack = 0;
736 eom = 0;
737 opcode_set = 0;
738 opcode = CEC_OPCODE_FEATURE_ABORT;
739 transmit_timeout = 1000;
740 parameters.Clear();
741 };
742 #endif
743 } cec_command;
744
745 typedef struct cec_device_type_list
746 {
747 cec_device_type types[5];
748
749 #ifdef __cplusplus
750 /*!
751 * @deprecated
752 */
753 void clear(void) { Clear(); }
754 /*!
755 * @deprecated
756 */
757 void add(const cec_device_type type) { Add(type); }
758
759 void Clear(void)
760 {
761 for (unsigned int iPtr = 0; iPtr < 5; iPtr++)
762 types[iPtr] = CEC_DEVICE_TYPE_RESERVED;
763 }
764
765 void Add(const cec_device_type type)
766 {
767 for (unsigned int iPtr = 0; iPtr < 5; iPtr++)
768 {
769 if (types[iPtr] == CEC_DEVICE_TYPE_RESERVED)
770 {
771 types[iPtr] = type;
772 break;
773 }
774 }
775 }
776
777 bool IsSet(cec_device_type type)
778 {
779 bool bReturn(false);
780 for (unsigned int iPtr = 0; !bReturn && iPtr < 5; iPtr++)
781 {
782 if (types[iPtr] == type)
783 bReturn = true;
784 }
785 return bReturn;
786 }
787
788 bool IsEmpty()
789 {
790 bool bReturn(true);
791 for (unsigned int iPtr = 0; bReturn && iPtr < 5; iPtr++)
792 {
793 if (types[iPtr] != CEC_DEVICE_TYPE_RESERVED)
794 bReturn = false;
795 }
796 return bReturn;
797 }
798
799 cec_device_type operator[](uint8_t pos) const { return pos < 5 ? types[pos] : CEC_DEVICE_TYPE_RESERVED; }
800 #endif
801 } cec_device_type_list;
802
803 typedef struct cec_logical_addresses
804 {
805 cec_logical_address primary;
806 int addresses[16];
807
808 #ifdef __cplusplus
809 void Clear(void)
810 {
811 primary = CECDEVICE_UNKNOWN;
812 for (unsigned int iPtr = 0; iPtr < 16; iPtr++)
813 addresses[iPtr] = 0;
814 }
815
816 bool IsEmpty(void) const
817 {
818 return primary == CECDEVICE_UNKNOWN;
819 }
820
821 uint16_t AckMask(void) const
822 {
823 uint16_t mask = 0;
824 for (unsigned int iPtr = 0; iPtr < 16; iPtr++)
825 if (addresses[iPtr] == 1)
826 mask |= 0x1 << iPtr;
827 return mask;
828 }
829
830 void Set(cec_logical_address address)
831 {
832 if (primary == CECDEVICE_UNKNOWN)
833 primary = address;
834
835 addresses[(int) address] = 1;
836 }
837
838 void Unset(cec_logical_address address)
839 {
840 if (primary == address)
841 primary = CECDEVICE_UNKNOWN;
842
843 addresses[(int) address] = 0;
844 }
845
846 bool IsSet(cec_logical_address address) const { return addresses[(int) address] == 1; }
847 bool operator[](uint8_t pos) const { return pos < 16 ? IsSet((cec_logical_address) pos) : false; }
848 #endif
849 } cec_logical_addresses;
850
851 #ifdef __cplusplus
852 };
853 };
854 #endif
855
856 #endif /* CECTYPES_H_ */