X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=include%2Fcectypes.h;h=941b5427bcdfaaa5adc68805beb6304c6920096d;hb=e36035adeeab088655508cf6c2aa492e8eea7cc3;hp=eee055264b8fbc7a2854bab53465dc3fd721a4de;hpb=cb9157778536cfca3ab8e4b98d60e08072887dd5;p=deb_libcec.git diff --git a/include/cectypes.h b/include/cectypes.h index eee0552..941b542 100644 --- a/include/cectypes.h +++ b/include/cectypes.h @@ -37,10 +37,6 @@ #include #include -#if !defined(_WIN32) && !defined(_WIN64) -#include -#endif - #if !defined(DECLSPEC) #if defined(_WIN32) || defined(_WIN64) #include @@ -155,13 +151,13 @@ typedef enum CEC_DEVICE_TYPE_AUDIO_SYSTEM = 5 } ECecDeviceType; -typedef enum +typedef enum cec_display_control { CEC_DISPLAY_CONTROL_DISPLAY_FOR_DEFAULT_TIME = 0x00, CEC_DISPLAY_CONTROL_DISPLAY_UNTIL_CLEARED = 0x40, CEC_DISPLAY_CONTROL_CLEAR_PREVIOUS_MESSAGE = 0x80, CEC_DISPLAY_CONTROL_RESERVED_FOR_FUTURE_USE = 0xC0 -} ECecDisplayControl; +} cec_display_control; typedef enum { @@ -438,6 +434,11 @@ typedef enum cec_user_control_code 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 @@ -646,11 +647,11 @@ typedef struct cec_command { cec_logical_address initiator; cec_logical_address destination; - bool ack; - bool eom; + int8_t ack; + int8_t eom; cec_opcode opcode; cec_datapacket parameters; - bool opcode_set; + int8_t opcode_set; #ifdef __cplusplus static void format(cec_command &command, cec_logical_address initiator, cec_logical_address destination, cec_opcode opcode) @@ -659,14 +660,19 @@ typedef struct cec_command command.initiator = initiator; command.destination = destination; command.opcode = opcode; - command.opcode_set = true; + command.opcode_set = 1; } void push_back(uint8_t data) { - if (!opcode_set) + if (initiator == CECDEVICE_UNKNOWN && destination == CECDEVICE_UNKNOWN) + { + initiator = (cec_logical_address) (data >> 4); + destination = (cec_logical_address) (data & 0xF); + } + else if (!opcode_set) { - opcode_set = true; + opcode_set = 1; opcode = (cec_opcode) data; } else @@ -677,9 +683,9 @@ typedef struct cec_command { initiator = CECDEVICE_UNKNOWN; destination = CECDEVICE_UNKNOWN; - ack = false; - eom = false; - opcode_set = false; + ack = 0; + eom = 0; + opcode_set = 0; opcode = CEC_OPCODE_FEATURE_ABORT; parameters.clear(); }; @@ -688,19 +694,19 @@ typedef struct cec_command typedef enum cec_vendor_id { - CEC_VENDOR_SAMSUNG = 240, + CEC_VENDOR_SAMSUNG = 0x00F0, + CEC_VENDOR_LG = 0xE091, CEC_VENDOR_UNKNOWN = 0 } vendor_id; -//default physical address 1.0.0.0 +//default physical address 1.0.0.0, HDMI port 1 #define CEC_DEFAULT_PHYSICAL_ADDRESS 0x1000 #define MSGSTART 0xFF #define MSGEND 0xFE #define MSGESC 0xFD #define ESCOFFSET 3 #define CEC_MIN_VERSION 6 -#define CEC_LIB_VERSION 7 -#define CEC_SETTLE_DOWN_TIME 1500 +#define CEC_LIB_VERSION 8 #define CEC_BUTTON_TIMEOUT 500 #ifdef __cplusplus