X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=include%2Fcectypes.h;h=ae8db71ecc7527d0c6442645befc250e09aee5b4;hb=0b71487197ed7281dda06f53ecaf846f1fd7e942;hp=0fed3b56723e76053de3c367a7e058513e96f9ca;hpb=d2f1c15733e3f6f2c8a17abfd3c6612ea93ce734;p=deb_libcec.git diff --git a/include/cectypes.h b/include/cectypes.h index 0fed3b5..ae8db71 100644 --- a/include/cectypes.h +++ b/include/cectypes.h @@ -2,7 +2,7 @@ /* * This file is part of the libCEC(R) library. * - * libCEC(R) is Copyright (C) 2011 Pulse-Eight Limited. All rights reserved. + * libCEC(R) is Copyright (C) 2011-2012 Pulse-Eight Limited. All rights reserved. * libCEC(R) is an original work, containing original code. * * libCEC(R) is a trademark of Pulse-Eight Limited. @@ -37,6 +37,12 @@ #include #include +#if defined(_WIN32) || defined(_WIN64) +#define CEC_CDECL __cdecl +#else +#define CEC_CDECL +#endif + #if !defined(DECLSPEC) #if defined(_WIN32) || defined(_WIN64) #include @@ -64,10 +70,28 @@ namespace CEC { #define MSGESC 0xFD #define ESCOFFSET 3 #define CEC_BUTTON_TIMEOUT 500 +#define CEC_POWER_STATE_REFRESH_TIME 30000 +#define CEC_FW_VERSION_UNKNOWN 0xFFFF +#define CEC_CONNECT_TRIES 3 + +#define CEC_DEFAULT_SETTING_USE_TV_MENU_LANGUAGE 1 +#define CEC_DEFAULT_SETTING_ACTIVATE_SOURCE 1 +#define CEC_DEFAULT_SETTING_POWER_OFF_SHUTDOWN 1 +#define CEC_DEFAULT_SETTING_POWER_OFF_SCREENSAVER 1 +#define CEC_DEFAULT_SETTING_POWER_OFF_ON_STANDBY 1 +#define CEC_DEFAULT_SETTING_SHUTDOWN_ON_STANDBY 0 +#define CEC_DEFAULT_SETTING_SEND_INACTIVE_SOURCE 1 +#define CEC_DEFAULT_SETTING_POWER_OFF_DEVICES_STANDBY 1 +#define CEC_DEFAULT_DEVICE_LANGUAGE "eng" + +#define CEC_DEFAULT_TRANSMIT_RETRY_WAIT 500 +#define CEC_DEFAULT_TRANSMIT_TIMEOUT 1000 +#define CEC_DEFAULT_TRANSMIT_WAIT 2000 +#define CEC_DEFAULT_TRANSMIT_RETRIES 1 #define CEC_MIN_LIB_VERSION 1 #define CEC_LIB_VERSION_MAJOR 1 -#define CEC_LIB_VERSION_MINOR 2 +#define CEC_LIB_VERSION_MINOR 6 typedef enum cec_abort_reason { @@ -154,7 +178,8 @@ typedef enum cec_deck_info CEC_DECK_INFO_SKIP_REVERSE_REWIND = 0x1C, CEC_DECK_INFO_INDEX_SEARCH_FORWARD = 0x1D, CEC_DECK_INFO_INDEX_SEARCH_REVERSE = 0x1E, - CEC_DECK_INFO_OTHER_STATUS = 0x1F + CEC_DECK_INFO_OTHER_STATUS = 0x1F, + CEC_DECK_INFO_OTHER_STATUS_LG = 0x20 } cec_deck_info; typedef enum cec_device_type @@ -446,15 +471,12 @@ typedef enum cec_user_control_code CEC_USER_CONTROL_CODE_F4_YELLOW = 0x74, CEC_USER_CONTROL_CODE_F5 = 0x75, CEC_USER_CONTROL_CODE_DATA = 0x76, - CEC_USER_CONTROL_CODE_MAX = 0x76, + CEC_USER_CONTROL_CODE_AN_RETURN = 0x91, + CEC_USER_CONTROL_CODE_AN_CHANNELS_LIST = 0x96, + CEC_USER_CONTROL_CODE_MAX = 0x96, CEC_USER_CONTROL_CODE_UNKNOWN } cec_user_control_code; -typedef enum cec_an_user_control_code -{ - CEC_AN_USER_CONTROL_CODE_RETURN = 0x91 -} cec_an_user_control_code; - typedef enum cec_logical_address { CECDEVICE_UNKNOWN = -1, //not a valid logical address @@ -580,6 +602,23 @@ typedef enum cec_adapter_messagecode MSGCODE_TRANSMIT_FAILED_TIMEOUT_LINE, MSGCODE_FIRMWARE_VERSION, MSGCODE_START_BOOTLOADER, + MSGCODE_SET_POWERSTATE, + MSGCODE_SET_CONTROLLED, + MSGCODE_GET_AUTO_ENABLED, + MSGCODE_SET_AUTO_ENABLED, + MSGCODE_GET_DEFAULT_LOGICAL_ADDRESS, + MSGCODE_SET_DEFAULT_LOGICAL_ADDRESS, + MSGCODE_GET_LOGICAL_ADDRESS_MASK, + MSGCODE_SET_LOGICAL_ADDRESS_MASK, + MSGCODE_GET_PHYSICAL_ADDRESS, + MSGCODE_SET_PHYSICAL_ADDRESS, + MSGCODE_GET_DEVICE_TYPE, + MSGCODE_SET_DEVICE_TYPE, + MSGCODE_GET_HDMI_VERSION, + MSGCODE_SET_HDMI_VERSION, + MSGCODE_GET_OSD_NAME, + MSGCODE_SET_OSD_NAME, + MSGCODE_WRITE_EEPROM, MSGCODE_FRAME_EOM = 0x80, MSGCODE_FRAME_ACK = 0x40, } cec_adapter_messagecode; @@ -594,51 +633,53 @@ typedef enum cec_bus_device_status typedef enum cec_vendor_id { - CEC_VENDOR_SAMSUNG = 0x00F0, - CEC_VENDOR_LG = 0xE091, - CEC_VENDOR_PANASONIC = 0x8045, - CEC_VENDOR_PIONEER = 0xE036, - CEC_VENDOR_ONKYO = 0x09B0, - CEC_VENDOR_YAMAHA = 0xA0DE, - CEC_VENDOR_PHILIPS = 0x903E, + CEC_VENDOR_SAMSUNG = 0x0000F0, + CEC_VENDOR_LG = 0x00E091, + CEC_VENDOR_PANASONIC = 0x008045, + CEC_VENDOR_PIONEER = 0x00E036, + CEC_VENDOR_ONKYO = 0x0009B0, + CEC_VENDOR_YAMAHA = 0x00A0DE, + CEC_VENDOR_PHILIPS = 0x00903E, + CEC_VENDOR_SONY = 0x080046, + CEC_VENDOR_TOSHIBA = 0x000039, CEC_VENDOR_UNKNOWN = 0 } cec_vendor_id; typedef struct cec_menu_language { - char language[4]; - cec_logical_address device; + char language[4]; /**< the iso language code. @bug the language code is only 3 chars long, not 4. will be changed in v2.0, because changing it now would break backwards compat */ + cec_logical_address device; /**< the logical address of the device */ } cec_menu_language; typedef struct cec_osd_name { - char name[14]; - cec_logical_address device; + char name[14]; /**< the name of the device */ + cec_logical_address device; /**< the logical address of the device */ } cec_osd_name; typedef struct cec_log_message { - char message[1024]; - cec_log_level level; - int64_t time; + char message[1024]; /**< the actual message */ + cec_log_level level; /**< log level of the message */ + int64_t time; /**< the timestamp of this message */ } cec_log_message; typedef struct cec_keypress { - cec_user_control_code keycode; - unsigned int duration; + cec_user_control_code keycode; /**< the keycode */ + unsigned int duration; /**< the duration of the keypress */ } cec_keypress; typedef struct cec_adapter { - char path[1024]; - char comm[1024]; + char path[1024]; /**< the path to the com port */ + char comm[1024]; /**< the name of the com port */ } cec_adapter; typedef struct cec_datapacket { - uint8_t data[100]; - uint8_t size; + uint8_t data[100]; /**< the actual data */ + uint8_t size; /**< the size of the data */ #ifdef __cplusplus cec_datapacket &operator =(const struct cec_datapacket &packet) @@ -650,11 +691,26 @@ typedef struct cec_datapacket return *this; } - bool IsEmpty(void) const { return size == 0; } - bool IsFull(void) const { return size == 100; } + bool IsEmpty(void) const { return size == 0; } /**< @return True when this packet is empty, false otherwise. */ + bool IsFull(void) const { return size == 100; } /**< @return True when this packet is false, false otherwise. */ + + /*! + * @brief Get the byte at the requested position. + * @param pos The position. + * @return The byte, or 0 when out of bounds. + */ uint8_t operator[](uint8_t pos) const { return pos < size ? data[pos] : 0; } + /*! + * @brief Get the byte at the requested position. + * @param pos The position. + * @return The byte, or 0 when out of bounds. + */ uint8_t At(uint8_t pos) const { return pos < size ? data[pos] : 0; } + /*! + * @brief Shift the contents of this packet. + * @param iShiftBy The number of positions to shift. + */ void Shift(uint8_t iShiftBy) { if (iShiftBy >= size) @@ -669,12 +725,19 @@ typedef struct cec_datapacket } } + /*! + * @brief Push a byte to the end of this packet. + * @param add The byte to add. + */ void PushBack(uint8_t add) { if (size < 100) data[size++] = add; } + /*! + * @brief Clear this packet. + */ void Clear(void) { memset(data, 0, sizeof(data)); @@ -686,14 +749,14 @@ typedef struct cec_datapacket typedef struct cec_command { - cec_logical_address initiator; - cec_logical_address destination; - int8_t ack; - int8_t eom; - cec_opcode opcode; - cec_datapacket parameters; - int8_t opcode_set; - int32_t transmit_timeout; + cec_logical_address initiator; /**< the logical address of the initiator of this message */ + cec_logical_address destination; /**< the logical address of the destination of this message */ + int8_t ack; /**< 1 when the ACK bit is set, 0 otherwise */ + int8_t eom; /**< 1 when the EOM bit is set, 0 otherwise */ + cec_opcode opcode; /**< the opcode of this message */ + cec_datapacket parameters; /**< the parameters attached to this message */ + int8_t opcode_set; /**< 1 when an opcode is set, 0 otherwise (POLL message) */ + int32_t transmit_timeout; /**< the timeout to use in ms */ #ifdef __cplusplus cec_command &operator =(const struct cec_command &command) @@ -710,11 +773,20 @@ typedef struct cec_command return *this; } - static void Format(cec_command &command, cec_logical_address initiator, cec_logical_address destination, cec_opcode opcode) + /*! + * @brief Formats a cec_command. + * @param command The command to format. + * @param initiator The logical address of the initiator. + * @param destination The logical addres of the destination. + * @param opcode The opcode of the command. + * @param timeout The transmission timeout. + */ + static void Format(cec_command &command, cec_logical_address initiator, cec_logical_address destination, cec_opcode opcode, int32_t timeout = CEC_DEFAULT_TRANSMIT_TIMEOUT) { command.Clear(); - command.initiator = initiator; - command.destination = destination; + command.initiator = initiator; + command.destination = destination; + command.transmit_timeout = timeout; if (opcode != CEC_OPCODE_NONE) { command.opcode = opcode; @@ -722,6 +794,10 @@ typedef struct cec_command } } + /*! + * @brief Push a byte to the back of this command. + * @param data The byte to push. + */ void PushBack(uint8_t data) { if (initiator == CECDEVICE_UNKNOWN && destination == CECDEVICE_UNKNOWN) @@ -738,6 +814,9 @@ typedef struct cec_command parameters.PushBack(data); } + /*! + * @brief Clear this command, resetting everything to the default values. + */ void Clear(void) { initiator = CECDEVICE_UNKNOWN; @@ -746,7 +825,7 @@ typedef struct cec_command eom = 0; opcode_set = 0; opcode = CEC_OPCODE_FEATURE_ABORT; - transmit_timeout = 1000; + transmit_timeout = CEC_DEFAULT_TRANSMIT_TIMEOUT; parameters.Clear(); }; #endif @@ -754,24 +833,34 @@ typedef struct cec_command typedef struct cec_device_type_list { - cec_device_type types[5]; + cec_device_type types[5]; /**< the list of device types */ #ifdef __cplusplus /*! - * @deprecated + * @deprecated Use Clear() instead. + * @brief Clear this list. */ void clear(void) { Clear(); } /*! - * @deprecated + * @deprecated Use Add() instead. + * @brief Add a type to this list. + * @param type The type to add. */ void add(const cec_device_type type) { Add(type); } + /*! + * @brief Clear this list. + */ void Clear(void) { for (unsigned int iPtr = 0; iPtr < 5; iPtr++) types[iPtr] = CEC_DEVICE_TYPE_RESERVED; } + /*! + * @brief Add a type to this list. + * @param type The type to add. + */ void Add(const cec_device_type type) { for (unsigned int iPtr = 0; iPtr < 5; iPtr++) @@ -784,6 +873,11 @@ typedef struct cec_device_type_list } } + /*! + * @brief Check whether a type is set in this list. + * @param type The type to check. + * @return True when set, false otherwise. + */ bool IsSet(cec_device_type type) { bool bReturn(false); @@ -795,7 +889,10 @@ typedef struct cec_device_type_list return bReturn; } - bool IsEmpty() + /*! + * @return True when this list is empty, false otherwise. + */ + bool IsEmpty() const { bool bReturn(true); for (unsigned int iPtr = 0; bReturn && iPtr < 5; iPtr++) @@ -806,16 +903,37 @@ typedef struct cec_device_type_list return bReturn; } + /*! + * @brief Get the type at the requested position. + * @param pos The position. + * @return The type, or CEC_DEVICE_TYPE_RESERVED when out of bounds. + */ cec_device_type operator[](uint8_t pos) const { return pos < 5 ? types[pos] : CEC_DEVICE_TYPE_RESERVED; } + + bool operator==(const cec_device_type_list &other) const + { + bool bEqual(true); + for (uint8_t iPtr = 0; iPtr < 5; iPtr++) + bEqual &= (types[iPtr] == other[iPtr]); + return bEqual; + } + + bool operator!=(const cec_device_type_list &other) const + { + return !(*this == other); + } #endif } cec_device_type_list; typedef struct cec_logical_addresses { - cec_logical_address primary; - int addresses[16]; + cec_logical_address primary; /**< the primary logical address to use */ + int addresses[16]; /**< the list of addresses */ #ifdef __cplusplus + /*! + * @brief Clear this list. + */ void Clear(void) { primary = CECDEVICE_UNKNOWN; @@ -823,11 +941,18 @@ typedef struct cec_logical_addresses addresses[iPtr] = 0; } + /*! + * @return True when empty, false otherwise. + */ bool IsEmpty(void) const { return primary == CECDEVICE_UNKNOWN; } + /*! + * @brief Calculate the ack-mask for this list, the mask to use when determining whether to send an ack message or not. + * @return The ack-mask. + */ uint16_t AckMask(void) const { uint16_t mask = 0; @@ -837,6 +962,10 @@ typedef struct cec_logical_addresses return mask; } + /*! + * @brief Mark a logical address as 'set' + * @param address The logical address to add to this list. + */ void Set(cec_logical_address address) { if (primary == CECDEVICE_UNKNOWN) @@ -845,6 +974,10 @@ typedef struct cec_logical_addresses addresses[(int) address] = 1; } + /*! + * @brief Mark a logical address as 'unset' + * @param address The logical address to remove from this list. + */ void Unset(cec_logical_address address) { if (primary == address) @@ -853,11 +986,235 @@ typedef struct cec_logical_addresses addresses[(int) address] = 0; } + /*! + * @brief Check whether an address is set in this list. + * @param address The address to check. + * @return True when set, false otherwise. + */ bool IsSet(cec_logical_address address) const { return addresses[(int) address] == 1; } + + /*! + * @brief Check whether an address is set in this list. + * @param pos The address to check. + * @return True when set, false otherwise. + */ bool operator[](uint8_t pos) const { return pos < 16 ? IsSet((cec_logical_address) pos) : false; } + + bool operator==(const cec_logical_addresses &other) const + { + bool bEqual(true); + for (uint8_t iPtr = 0; iPtr < 16; iPtr++) + bEqual &= ((addresses[(int)iPtr] == 1) == other[iPtr]); + return bEqual; + } + + bool operator!=(const cec_logical_addresses &other) const + { + return !(*this == other); + } #endif } cec_logical_addresses; +typedef enum libcec_alert +{ + CEC_ALERT_SERVICE_DEVICE, + CEC_ALERT_CONNECTION_LOST +} libcec_alert; + +typedef enum libcec_parameter_type +{ + CEC_PARAMETER_TYPE_STRING +} libcec_parameter_type; + +struct libcec_parameter +{ + libcec_parameter_type paramType; /**< the type of this parameter */ + void* paramData; /**< the value of this parameter */ +}; + +struct libcec_configuration; + +typedef int (CEC_CDECL* CBCecLogMessageType)(void *param, const cec_log_message &); +typedef int (CEC_CDECL* CBCecKeyPressType)(void *param, const cec_keypress &); +typedef int (CEC_CDECL* CBCecCommandType)(void *param, const cec_command &); +typedef int (CEC_CDECL* CBCecConfigurationChangedType)(void *param, const libcec_configuration &); +typedef int (CEC_CDECL* CBCecAlertType)(void *param, const libcec_alert, const libcec_parameter &); +typedef int (CEC_CDECL* CBCecMenuStateChangedType)(void *param, const cec_menu_state newVal); + +typedef struct ICECCallbacks +{ + /*! + * @brief Transfer a log message from libCEC to the client. + * @param message The message to transfer. + * @return 1 when ok, 0 otherwise. + */ + CBCecLogMessageType CBCecLogMessage; + + /*! + * @brief Transfer a keypress from libCEC to the client. + * @param key The keypress to transfer. + * @return 1 when ok, 0 otherwise. + */ + CBCecKeyPressType CBCecKeyPress; + + /*! + * @brief Transfer a CEC command from libCEC to the client. + * @param command The command to transfer. + * @return 1 when ok, 0 otherwise. + */ + CBCecCommandType CBCecCommand; + + /*! + * @brief Transfer a changed configuration from libCEC to the client + * @param configuration The configuration to transfer + * @return 1 when ok, 0 otherwise + */ + CBCecConfigurationChangedType CBCecConfigurationChanged; + + /*! + * @brief Transfer a libcec alert message from libCEC to the client + * @param alert The alert type transfer. + * @param data Misc. additional information. + * @return 1 when ok, 0 otherwise + */ + CBCecAlertType CBCecAlert; + + /*! + * @brief Transfer a menu state change to the client. + * Transfer a menu state change to the client. If the command returns 1, then the change will be processed by + * the busdevice. If 0, then the state of the busdevice won't be changed, and will always be kept 'activated', + * so keypresses are always routed. + * @param newVal The new value. + * @return 1 when this change should be processed by the CCECBusDevice, false otherwise. + */ + CBCecMenuStateChangedType CBCecMenuStateChanged; + +#ifdef __cplusplus + ICECCallbacks(void) { Clear(); } + ~ICECCallbacks(void) { Clear(); }; + + void Clear(void) + { + CBCecLogMessage = NULL; + CBCecKeyPress = NULL; + CBCecCommand = NULL; + CBCecConfigurationChanged = NULL; + CBCecAlert = NULL; + CBCecMenuStateChanged = NULL; + } +#endif +} ICECCallbacks; + +typedef enum cec_client_version +{ + CEC_CLIENT_VERSION_PRE_1_5 = 0, + CEC_CLIENT_VERSION_1_5_0 = 0x1500, + CEC_CLIENT_VERSION_1_5_1 = 0x1501, + CEC_CLIENT_VERSION_1_5_2 = 0x1502, + CEC_CLIENT_VERSION_1_5_3 = 0x1503, + CEC_CLIENT_VERSION_1_6_0 = 0x1600, + CEC_CLIENT_VERSION_1_6_1 = 0x1601, + CEC_CLIENT_VERSION_1_6_2 = 0x1602 +} cec_client_version; + +typedef enum cec_server_version +{ + CEC_SERVER_VERSION_PRE_1_5 = 0, + CEC_SERVER_VERSION_1_5_0 = 0x1500, + CEC_SERVER_VERSION_1_5_1 = 0x1501, + CEC_SERVER_VERSION_1_5_2 = 0x1502, + CEC_SERVER_VERSION_1_5_3 = 0x1503, + CEC_SERVER_VERSION_1_6_0 = 0x1600, + CEC_SERVER_VERSION_1_6_1 = 0x1601, + CEC_SERVER_VERSION_1_6_2 = 0x1602 +} cec_server_version; + +typedef struct libcec_configuration +{ + uint32_t clientVersion; /*!< the version of the client that is connecting */ + char strDeviceName[13]; /*!< how to name the device on the CEC bus */ + cec_device_type_list deviceTypes; /*!< the CEC device types to emulate */ + uint8_t bAutodetectAddress; /*!< try to autodetect the physical address when 1 */ + uint16_t iPhysicalAddress; /*!< the physical address of the CEC adapter. only used when bAutodetectAddress = 0 or when the adapter doesn't support autodetection */ + cec_logical_address baseDevice; /*!< the logical address of the device to which the adapter is connected. only used when iPhysicalAddress = 0 and bAutodetectAddress = 0 or when the adapter doesn't support autodetection */ + uint8_t iHDMIPort; /*!< the HDMI port to which the adapter is connected. only used when iPhysicalAddress = 0 and bAutodetectAddress = 0 or when the adapter doesn't support autodetection */ + uint64_t tvVendor; /*!< override the vendor ID of the TV. leave this untouched to autodetect */ + cec_logical_addresses wakeDevices; /*!< wake these CEC devices when initialising libCEC or when calling PowerOnDevices() without any parameter */ + cec_logical_addresses powerOffDevices; /*!< power off these devices when calling StandbyDevices() without any parameter */ + + uint32_t serverVersion; /*!< the version number of the server. read-only */ + + // player specific settings + uint8_t bGetSettingsFromROM; /*!< true to get the settings from the ROM (if set, and a v2 ROM is present), false to use these settings. */ + uint8_t bUseTVMenuLanguage; /*!< use the menu language of the TV in the player application */ + uint8_t bActivateSource; /*!< make libCEC the active source on the bus when starting the player application */ + uint8_t bPowerOffScreensaver; /*!< put devices in standby mode when activating the screensaver */ + uint8_t bPowerOffOnStandby; /*!< put this PC in standby mode when the TV is switched off. only used when bShutdownOnStandby = 0 */ + uint8_t bSendInactiveSource; /*!< send an 'inactive source' message when stopping the player. added in 1.5.1 */ + + void * callbackParam; /*!< the object to pass along with a call of the callback methods. NULL to ignore */ + ICECCallbacks * callbacks; /*!< the callback methods to use. set this to NULL when not using callbacks */ + + cec_logical_addresses logicalAddresses; /*!< the current logical addresses. read-only. added in 1.5.3 */ + uint16_t iFirmwareVersion; /*!< the firmware version of the adapter. added in 1.6.0 */ + uint8_t bPowerOffDevicesOnStandby; /*!< put devices in standby when the PC/player is put in standby. added in 1.6.0 */ + uint8_t bShutdownOnStandby; /*!< shutdown this PC when the TV is switched off. only used when bPowerOffOnStandby = 0. added in 1.6.0 */ + char strDeviceLanguage[3]; /*!< the menu language used by the client. 3 character ISO 639-2 country code. see http://http://www.loc.gov/standards/iso639-2/ */ + +#ifdef __cplusplus + libcec_configuration(void) { Clear(); } + ~libcec_configuration(void) { Clear(); } + + /*! + * @brief Reset this configution struct to the default values. + */ + void Clear(void) + { + memset(strDeviceName, 0, 13); + deviceTypes.clear(); + iPhysicalAddress = 0; + baseDevice = (cec_logical_address)CEC_DEFAULT_BASE_DEVICE; + iHDMIPort = CEC_DEFAULT_HDMI_PORT; + tvVendor = (uint64_t)CEC_VENDOR_UNKNOWN; + clientVersion = (uint32_t)CEC_CLIENT_VERSION_PRE_1_5; + serverVersion = (uint32_t)CEC_SERVER_VERSION_PRE_1_5; + wakeDevices.Clear(); + powerOffDevices.Clear(); + + bAutodetectAddress = 1; + bGetSettingsFromROM = 0; + bUseTVMenuLanguage = CEC_DEFAULT_SETTING_USE_TV_MENU_LANGUAGE; + bActivateSource = CEC_DEFAULT_SETTING_ACTIVATE_SOURCE; + #if CEC_DEFAULT_SETTING_POWER_OFF_SHUTDOWN == 1 + powerOffDevices.Set(CECDEVICE_BROADCAST); + #endif + #if CEC_DEFAULT_SETTING_ACTIVATE_SOURCE == 1 + wakeDevices.Set(CECDEVICE_TV); + #endif + bPowerOffScreensaver = CEC_DEFAULT_SETTING_POWER_OFF_SCREENSAVER; + bPowerOffOnStandby = CEC_DEFAULT_SETTING_POWER_OFF_ON_STANDBY; + bShutdownOnStandby = CEC_DEFAULT_SETTING_SHUTDOWN_ON_STANDBY; + bSendInactiveSource = CEC_DEFAULT_SETTING_SEND_INACTIVE_SOURCE; + logicalAddresses.Clear(); + iFirmwareVersion = CEC_FW_VERSION_UNKNOWN; + bPowerOffDevicesOnStandby = CEC_DEFAULT_SETTING_POWER_OFF_DEVICES_STANDBY; + memcpy(strDeviceLanguage, CEC_DEFAULT_DEVICE_LANGUAGE, 3); + + callbackParam = NULL; + callbacks = NULL; + } +#endif +} libcec_configuration; + +#ifdef UNUSED +#elif defined(__GNUC__) +#define UNUSED(x) UNUSED_ ## x __attribute__((unused)) +#elif defined(__LCLINT__) +#define UNUSED(x) /*@unused@*/ x +#else +#define UNUSED(x) x +#endif + #ifdef __cplusplus }; };