You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
210 lines
6.0 KiB
210 lines
6.0 KiB
13 years ago
|
/*
|
||
|
* Copyright@ Samsung Electronics Co. LTD
|
||
|
*
|
||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
* you may not use this file except in compliance with the License.
|
||
|
* You may obtain a copy of the License at
|
||
|
*
|
||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
*
|
||
|
* Unless required by applicable law or agreed to in writing, software
|
||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
* See the License for the specific language governing permissions and
|
||
|
* limitations under the License.
|
||
|
*/
|
||
|
|
||
|
#ifndef _LIBCEC_H_
|
||
|
#define _LIBCEC_H_
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/** Maximum CEC frame size */
|
||
|
#define CEC_MAX_FRAME_SIZE 16
|
||
|
/** Not valid CEC physical address */
|
||
|
#define CEC_NOT_VALID_PHYSICAL_ADDRESS 0xFFFF
|
||
|
|
||
|
/** CEC broadcast address (as destination address) */
|
||
|
#define CEC_MSG_BROADCAST 0x0F
|
||
|
/** CEC unregistered address (as initiator address) */
|
||
|
#define CEC_LADDR_UNREGISTERED 0x0F
|
||
|
|
||
|
/*
|
||
|
* CEC Messages
|
||
|
*/
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the One Touch Play Feature */
|
||
|
#define CEC_OPCODE_ACTIVE_SOURCE 0x82
|
||
|
#define CEC_OPCODE_IMAGE_VIEW_ON 0x04
|
||
|
#define CEC_OPCODE_TEXT_VIEW_ON 0x0D
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Routing Control Feature */
|
||
|
#define CEC_OPCODE_INACTIVE_SOURCE 0x9D
|
||
|
#define CEC_OPCODE_REQUEST_ACTIVE_SOURCE 0x85
|
||
|
#define CEC_OPCODE_ROUTING_CHANGE 0x80
|
||
|
#define CEC_OPCODE_ROUTING_INFORMATION 0x81
|
||
|
#define CEC_OPCODE_SET_STREAM_PATH 0x86
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Standby Feature */
|
||
|
#define CEC_OPCODE_STANDBY 0x36
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the One Touch Record Feature */
|
||
|
#define CEC_OPCODE_RECORD_OFF 0x0B
|
||
|
#define CEC_OPCODE_RECORD_ON 0x09
|
||
|
#define CEC_OPCODE_RECORD_STATUS 0x0A
|
||
|
#define CEC_OPCODE_RECORD_TV_SCREEN 0x0F
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Timer Programming Feature */
|
||
|
#define CEC_OPCODE_CLEAR_ANALOGUE_TIMER 0x33
|
||
|
#define CEC_OPCODE_CLEAR_DIGITAL_TIMER 0x99
|
||
|
#define CEC_OPCODE_CLEAR_EXTERNAL_TIMER 0xA1
|
||
|
#define CEC_OPCODE_SET_ANALOGUE_TIMER 0x34
|
||
|
#define CEC_OPCODE_SET_DIGITAL_TIMER 0x97
|
||
|
#define CEC_OPCODE_SET_EXTERNAL_TIMER 0xA2
|
||
|
#define CEC_OPCODE_SET_TIMER_PROGRAM_TITLE 0x67
|
||
|
#define CEC_OPCODE_TIMER_CLEARED_STATUS 0x43
|
||
|
#define CEC_OPCODE_TIMER_STATUS 0x35
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the System Information Feature */
|
||
|
#define CEC_OPCODE_CEC_VERSION 0x9E
|
||
|
#define CEC_OPCODE_GET_CEC_VERSION 0x9F
|
||
|
#define CEC_OPCODE_GIVE_PHYSICAL_ADDRESS 0x83
|
||
|
#define CEC_OPCODE_GET_MENU_LANGUAGE 0x91
|
||
|
//#define CEC_OPCODE_POLLING_MESSAGE
|
||
|
#define CEC_OPCODE_REPORT_PHYSICAL_ADDRESS 0x84
|
||
|
#define CEC_OPCODE_SET_MENU_LANGUAGE 0x32
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Deck Control Feature */
|
||
|
#define CEC_OPCODE_DECK_CONTROL 0x42
|
||
|
#define CEC_OPCODE_DECK_STATUS 0x1B
|
||
|
#define CEC_OPCODE_GIVE_DECK_STATUS 0x1A
|
||
|
#define CEC_OPCODE_PLAY 0x41
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Tuner Control Feature */
|
||
|
#define CEC_OPCODE_GIVE_TUNER_DEVICE_STATUS 0x08
|
||
|
#define CEC_OPCODE_SELECT_ANALOGUE_SERVICE 0x92
|
||
|
#define CEC_OPCODE_SELECT_DIGITAL_SERVICE 0x93
|
||
|
#define CEC_OPCODE_TUNER_DEVICE_STATUS 0x07
|
||
|
#define CEC_OPCODE_TUNER_STEP_DECREMENT 0x06
|
||
|
#define CEC_OPCODE_TUNER_STEP_INCREMENT 0x05
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Vendor Specific Commands Feature */
|
||
|
#define CEC_OPCODE_DEVICE_VENDOR_ID 0x87
|
||
|
#define CEC_OPCODE_GET_DEVICE_VENDOR_ID 0x8C
|
||
|
#define CEC_OPCODE_VENDOR_COMMAND 0x89
|
||
|
#define CEC_OPCODE_VENDOR_COMMAND_WITH_ID 0xA0
|
||
|
#define CEC_OPCODE_VENDOR_REMOTE_BUTTON_DOWN 0x8A
|
||
|
#define CEC_OPCODE_VENDOR_REMOVE_BUTTON_UP 0x8B
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the OSD Display Feature */
|
||
|
#define CEC_OPCODE_SET_OSD_STRING 0x64
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Device OSD Transfer Feature */
|
||
|
#define CEC_OPCODE_GIVE_OSD_NAME 0x46
|
||
|
#define CEC_OPCODE_SET_OSD_NAME 0x47
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Device Menu Control Feature */
|
||
|
#define CEC_OPCODE_MENU_REQUEST 0x8D
|
||
|
#define CEC_OPCODE_MENU_STATUS 0x8E
|
||
|
#define CEC_OPCODE_USER_CONTROL_PRESSED 0x44
|
||
|
#define CEC_OPCODE_USER_CONTROL_RELEASED 0x45
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Remote Control Passthrough Feature */
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Power Status Feature */
|
||
|
#define CEC_OPCODE_GIVE_DEVICE_POWER_STATUS 0x8F
|
||
|
#define CEC_OPCODE_REPORT_POWER_STATUS 0x90
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for General Protocol messages */
|
||
|
#define CEC_OPCODE_FEATURE_ABORT 0x00
|
||
|
#define CEC_OPCODE_ABORT 0xFF
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the System Audio Control Feature */
|
||
|
#define CEC_OPCODE_GIVE_AUDIO_STATUS 0x71
|
||
|
#define CEC_OPCODE_GIVE_SYSTEM_AUDIO_MODE_STATUS 0x7D
|
||
|
#define CEC_OPCODE_REPORT_AUDIO_STATUS 0x7A
|
||
|
#define CEC_OPCODE_SET_SYSTEM_AUDIO_MODE 0x72
|
||
|
#define CEC_OPCODE_SYSTEM_AUDIO_MODE_REQUEST 0x70
|
||
|
#define CEC_OPCODE_SYSTEM_AUDIO_MODE_STATUS 0x7E
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name Messages for the Audio Rate Control Feature */
|
||
|
#define CEC_OPCODE_SET_AUDIO_RATE 0x9A
|
||
|
//@}
|
||
|
|
||
|
//@{
|
||
|
/** @name CEC Operands */
|
||
|
|
||
|
//TODO: not finished
|
||
|
|
||
|
#define CEC_DECK_CONTROL_MODE_STOP 0x03
|
||
|
#define CEC_PLAY_MODE_PLAY_FORWARD 0x24
|
||
|
//@}
|
||
|
|
||
|
/**
|
||
|
* @enum CECDeviceType
|
||
|
* Type of CEC device
|
||
|
*/
|
||
|
enum CECDeviceType {
|
||
|
/** TV */
|
||
|
CEC_DEVICE_TV,
|
||
|
/** Recording Device */
|
||
|
CEC_DEVICE_RECODER,
|
||
|
/** Tuner */
|
||
|
CEC_DEVICE_TUNER,
|
||
|
/** Playback Device */
|
||
|
CEC_DEVICE_PLAYER,
|
||
|
/** Audio System */
|
||
|
CEC_DEVICE_AUDIO,
|
||
|
};
|
||
|
|
||
|
int CECOpen();
|
||
|
int CECClose();
|
||
|
int CECAllocLogicalAddress(int paddr, enum CECDeviceType devtype);
|
||
|
int CECSendMessage(unsigned char *buffer, int size);
|
||
|
int CECReceiveMessage(unsigned char *buffer, int size, long timeout);
|
||
|
|
||
|
int CECIgnoreMessage(unsigned char opcode, unsigned char lsrc);
|
||
|
int CECCheckMessageSize(unsigned char opcode, int size);
|
||
|
int CECCheckMessageMode(unsigned char opcode, int broadcast);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* _LIBCEC_H_ */
|