summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_callback.h7
-rw-r--r--tv_input.cpp96
-rw-r--r--tvapi/android/include/ITv.h34
-rw-r--r--tvapi/android/include/ITvClient.h12
-rw-r--r--tvapi/android/include/ITvService.h18
-rw-r--r--tvapi/android/include/TvClient.h5
-rw-r--r--tvapi/android/include/tvcmd.h1180
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp64
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp666
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp246
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp78
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp56
-rw-r--r--tvapi/android/libtvbinder/TvClient.cpp54
-rw-r--r--tvapi/android/tv/TvPlay.cpp36
-rw-r--r--tvapi/android/tv/TvPlay.h2
-rw-r--r--tvapi/android/tvserver/TvService.cpp8700
-rw-r--r--tvapi/android/tvserver/TvService.h107
-rw-r--r--tvapi/android/tvserver/main.cpp12
-rw-r--r--tvapi/android/tvserver/tv_callback.h25
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp170
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h32
-rw-r--r--tvapi/libtv/audio/CTvAudio.h52
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp1004
-rw-r--r--tvapi/libtv/audio/audio_alsa.h164
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp82
-rw-r--r--tvapi/libtv/audio/audio_effect.h34
-rw-r--r--tvapi/libtv/include/amstream.h142
-rw-r--r--tvapi/libtv/include/cm.h188
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h492
-rw-r--r--tvapi/libtv/include/ve.h342
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp280
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h44
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp172
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h26
-rw-r--r--tvapi/libtv/tv/CAv.cpp612
-rw-r--r--tvapi/libtv/tv/CAv.h188
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2670
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h716
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp964
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h236
-rw-r--r--tvapi/libtv/tv/CTv.cpp2174
-rw-r--r--tvapi/libtv/tv/CTv.h1470
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp170
-rw-r--r--tvapi/libtv/tv/CTvBooking.h94
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h12
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp258
-rw-r--r--tvapi/libtv/tv/CTvEpg.h276
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h322
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp368
-rw-r--r--tvapi/libtv/tv/CTvRecord.h70
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1934
-rw-r--r--tvapi/libtv/tv/CTvScanner.h418
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1228
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h142
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp708
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h430
-rw-r--r--tvapi/libtv/tv/CTvTime.h134
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h40
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h104
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp638
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp558
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h76
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp28
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp408
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h478
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp302
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h112
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h134
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp322
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h112
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp4
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h14
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1322
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h988
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp228
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h30
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp438
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h76
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4452
-rw-r--r--tvapi/libtv/tvin/CTvin.h2116
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp6
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h72
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp12
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h48
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp66
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h20
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp146
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h40
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2168
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h8
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1792
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp958
-rw-r--r--tvapi/libtv/tvutils/CCondition.h84
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp261
-rw-r--r--tvapi/libtv/tvutils/CFile.h50
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h6
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp146
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h40
-rw-r--r--tvapi/libtv/tvutils/CMutex.h112
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h60
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h42
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h288
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h76
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp204
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h46
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h42
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp2813
-rw-r--r--tvapi/libtv/tvutils/tvutils.h44
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h54
-rw-r--r--tvapi/libtv/version/version.cpp50
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp618
-rw-r--r--tvapi/libtv/vpp/CPQdb.h232
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp724
-rw-r--r--tvapi/libtv/vpp/CVpp.h676
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp320
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp560
134 files changed, 31073 insertions, 30287 deletions
diff --git a/tvapi/libtv/tvin/CHDMIRxCEC.cpp b/tvapi/libtv/tvin/CHDMIRxCEC.cpp
index 22906a3..6583fe0 100644
--- a/tvapi/libtv/tvin/CHDMIRxCEC.cpp
+++ b/tvapi/libtv/tvin/CHDMIRxCEC.cpp
@@ -13,32 +13,32 @@
CTvin::CHDMIRxCEC::CHDMIRxCEC(CTvin *pTvin)
{
- int i = 0;
+ int i = 0;
- for (i = 0; i < CC_REQUEST_LIST_SIZE; i++) {
- ClrReplyListItem(&mReplyList[i]);
- memset((void *) &mMsgBuf[i], 0, sizeof(struct _cec_msg));
- }
+ for (i = 0; i < CC_REQUEST_LIST_SIZE; i++) {
+ ClrReplyListItem(&mReplyList[i]);
+ memset((void *) &mMsgBuf[i], 0, sizeof(struct _cec_msg));
+ }
- mModuleEnableFlag = -1;
- mRequestPause = false;
- mState = STATE_STOPED;
+ mModuleEnableFlag = -1;
+ mRequestPause = false;
+ mState = STATE_STOPED;
- mpObserver = NULL;
- mpTvin = pTvin;
+ mpObserver = NULL;
+ mpTvin = pTvin;
- for (i = 0; i < CC_SOURCE_DEV_REFRESH_CNT; i++) {
- mSourceDevLogicAddrBuf[i] = -1;
- mSourceDevRefreshBuf[i] = -1;
- }
+ for (i = 0; i < CC_SOURCE_DEV_REFRESH_CNT; i++) {
+ mSourceDevLogicAddrBuf[i] = -1;
+ mSourceDevRefreshBuf[i] = -1;
+ }
- mSourceDevLogicAddrBuf[0] = E_LA_TV;
- mSourceDevLogicAddrBuf[1] = E_LA_TV;
- mSourceDevLogicAddrBuf[2] = E_LA_TV;
+ mSourceDevLogicAddrBuf[0] = E_LA_TV;
+ mSourceDevLogicAddrBuf[1] = E_LA_TV;
+ mSourceDevLogicAddrBuf[2] = E_LA_TV;
- mSourceDevRefreshBuf[0] = E_LA_PLAYBACK1;
- mSourceDevRefreshBuf[1] = E_LA_PLAYBACK2;
- mSourceDevRefreshBuf[2] = E_LA_PLYBACK3;
+ mSourceDevRefreshBuf[0] = E_LA_PLAYBACK1;
+ mSourceDevRefreshBuf[1] = E_LA_PLAYBACK2;
+ mSourceDevRefreshBuf[2] = E_LA_PLYBACK3;
}
CTvin::CHDMIRxCEC::~CHDMIRxCEC()
@@ -47,608 +47,608 @@ CTvin::CHDMIRxCEC::~CHDMIRxCEC()
int CTvin::CHDMIRxCEC::start()
{
- CMutex::Autolock _l (mLock);
+ CMutex::Autolock _l (mLock);
- if (GetModuleEnableFlag() == 0) {
- return -1;
- }
+ if (GetModuleEnableFlag() == 0) {
+ return -1;
+ }
- if (mState == STATE_STOPED) {
- this->run();
- }
+ if (mState == STATE_STOPED) {
+ this->run();
+ }
- return mState;
+ return mState;
}
int CTvin::CHDMIRxCEC::stop()
{
- CMutex::Autolock _l (mLock);
+ CMutex::Autolock _l (mLock);
- if (GetModuleEnableFlag() == 0) {
- return -1;
- }
+ if (GetModuleEnableFlag() == 0) {
+ return -1;
+ }
- if (mState == STATE_PAUSE) {
- resume();
- }
+ if (mState == STATE_PAUSE) {
+ resume();
+ }
- requestExit();
- mState = STATE_STOPED;
- return mState;
+ requestExit();
+ mState = STATE_STOPED;
+ return mState;
}
int CTvin::CHDMIRxCEC::pause()
{
- CMutex::Autolock _l (mLock);
+ CMutex::Autolock _l (mLock);
- if (GetModuleEnableFlag() == 0) {
- return -1;
- }
+ if (GetModuleEnableFlag() == 0) {
+ return -1;
+ }
- mRequestPause = true;
- return 0;
+ mRequestPause = true;
+ return 0;
}
int CTvin::CHDMIRxCEC::resume()
{
- CMutex::Autolock _l (mLock);
+ CMutex::Autolock _l (mLock);
- if (GetModuleEnableFlag() == 0) {
- return -1;
- }
+ if (GetModuleEnableFlag() == 0) {
+ return -1;
+ }
- ClearRxMessageBuffer();
+ ClearRxMessageBuffer();
- mRequestPause = false;
- mPauseCondition.signal();
+ mRequestPause = false;
+ mPauseCondition.signal();
- ClearRxMessageBuffer();
- return 0;
+ ClearRxMessageBuffer();
+ return 0;
}
int CTvin::CHDMIRxCEC::isAllowOperate(int source_input)
{
- if (GetModuleEnableFlag() == 0) {
- return -1;
- }
+ if (GetModuleEnableFlag() == 0) {
+ return -1;
+ }
- int source_port = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
- if (mpTvin->VDIN_GetPortConnect(source_port) == false) {
- return -1;
- }
+ int source_port = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
+ if (mpTvin->VDIN_GetPortConnect(source_port) == false) {
+ return -1;
+ }
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::GetModuleEnableFlag()
{
- const char *config_value = NULL;
-
- if (mModuleEnableFlag < 0) {
- config_value = config_get_str(CFG_SECTION_TV, "tvin.hdmirx.cec.enable", "null");
- if (strcasecmp(config_value, "null") == 0) {
- mModuleEnableFlag = 0;
- } else if (strcasecmp(config_value, "1") == 0 || strcasecmp(config_value, "true") == 0) {
- mModuleEnableFlag = 1;
- } else {
- mModuleEnableFlag = 0;
- }
- }
-
- return mModuleEnableFlag;
+ const char *config_value = NULL;
+
+ if (mModuleEnableFlag < 0) {
+ config_value = config_get_str(CFG_SECTION_TV, "tvin.hdmirx.cec.enable", "null");
+ if (strcasecmp(config_value, "null") == 0) {
+ mModuleEnableFlag = 0;
+ } else if (strcasecmp(config_value, "1") == 0 || strcasecmp(config_value, "true") == 0) {
+ mModuleEnableFlag = 1;
+ } else {
+ mModuleEnableFlag = 0;
+ }
+ }
+
+ return mModuleEnableFlag;
}
int CTvin::CHDMIRxCEC::PrintMessage(const char *func_name, int data_type, struct _cec_msg *msg)
{
#ifdef CC_ENABLE_PRINT_MESSAGE
- if (msg == NULL) {
- LOGE("%s, msg is NULL\n", func_name);
- return -1;
- }
-
- LOGD("%s, msg_len = %d\n", func_name, msg->msg_len);
- LOGD("%s, msg addr 0x%02X\n", func_name, msg->addr);
- LOGD("%s, msg cmd 0x%02X\n", func_name, msg->cmd);
- for (int i = 0; i < msg->msg_len - 2; i++) {
- if (data_type == 0) {
- LOGD("%s, msg data[%d] = 0x%02X\n", func_name, i, msg->msg_data[i]);
- } else {
- LOGD("%s, msg data[%d] = %c\n", func_name, i, msg->msg_data[i]);
- }
- }
+ if (msg == NULL) {
+ LOGE("%s, msg is NULL\n", func_name);
+ return -1;
+ }
+
+ LOGD("%s, msg_len = %d\n", func_name, msg->msg_len);
+ LOGD("%s, msg addr 0x%02X\n", func_name, msg->addr);
+ LOGD("%s, msg cmd 0x%02X\n", func_name, msg->cmd);
+ for (int i = 0; i < msg->msg_len - 2; i++) {
+ if (data_type == 0) {
+ LOGD("%s, msg data[%d] = 0x%02X\n", func_name, i, msg->msg_data[i]);
+ } else {
+ LOGD("%s, msg data[%d] = %c\n", func_name, i, msg->msg_data[i]);
+ }
+ }
#endif
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::ClrReplyListItem(HDMIRxRequestReplyItem *reply_item)
{
- if (reply_item == NULL) {
- return -1;
- }
-
- reply_item->WaitCmd = 0;
- reply_item->WaitLogicAddr = 0;
- reply_item->WaitTimeOut = 0;
- reply_item->WaitFlag = 0;
- reply_item->DataFlag = 0;
- memset((void *) & (reply_item->msg), 0, sizeof(struct _cec_msg));
-
- return 0;
+ if (reply_item == NULL) {
+ return -1;
+ }
+
+ reply_item->WaitCmd = 0;
+ reply_item->WaitLogicAddr = 0;
+ reply_item->WaitTimeOut = 0;
+ reply_item->WaitFlag = 0;
+ reply_item->DataFlag = 0;
+ memset((void *) & (reply_item->msg), 0, sizeof(struct _cec_msg));
+
+ return 0;
}
int CTvin::CHDMIRxCEC::CopyMessageData(unsigned char data_buf[], unsigned char msg_data[], int msg_len)
{
- if (data_buf == NULL) {
- return 0;
- }
+ if (data_buf == NULL) {
+ return 0;
+ }
- memset((void *)data_buf, 0, CC_CEC_STREAM_SIZE);
+ memset((void *)data_buf, 0, CC_CEC_STREAM_SIZE);
- if (msg_len > CC_CEC_STREAM_SIZE) {
- return 0;
- }
+ if (msg_len > CC_CEC_STREAM_SIZE) {
+ return 0;
+ }
- if (msg_len <= 2) {
- return 0;
- }
+ if (msg_len <= 2) {
+ return 0;
+ }
- msg_len -= 2;
+ msg_len -= 2;
- memcpy(data_buf, msg_data, msg_len);
+ memcpy(data_buf, msg_data, msg_len);
- return msg_len;
+ return msg_len;
}
int CTvin::CHDMIRxCEC::GetDeviceLogicAddr(int source_input)
{
- return mSourceDevLogicAddrBuf[source_input - SOURCE_HDMI1];
+ return mSourceDevLogicAddrBuf[source_input - SOURCE_HDMI1];
}
int CTvin::CHDMIRxCEC::processRefreshSrcDevice(int source_input)
{
- int i = 0, physical_addr = 0;
- int source_port_1 = 0, source_port_2 = 0;
-
- if (source_input != SOURCE_HDMI1 && source_input != SOURCE_HDMI2 && source_input != SOURCE_HDMI3) {
- return -1;
- }
-
- mSourceDevLogicAddrBuf[0] = E_LA_TV;
- mSourceDevLogicAddrBuf[1] = E_LA_TV;
- mSourceDevLogicAddrBuf[2] = E_LA_TV;
-
- for (i = 0; i < CC_SOURCE_DEV_REFRESH_CNT; i++) {
- if (mSourceDevRefreshBuf[i] < 0) {
- continue;
- }
-
- physical_addr = 0;
- if (SendGivePhysicalAddressMessage(source_input, mSourceDevRefreshBuf[i], &physical_addr) > 0) {
- source_port_1 = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
- source_port_2 = CTvin::Tvin_GetSourcePortByCECPhysicalAddress(physical_addr);
- if (source_port_1 == source_port_2) {
- mSourceDevLogicAddrBuf[source_input - SOURCE_HDMI1] = mSourceDevRefreshBuf[i];
- break;
- }
- }
- }
-
- if (i == CC_SOURCE_DEV_REFRESH_CNT) {
- return -1;
- }
-
- return 0;
+ int i = 0, physical_addr = 0;
+ int source_port_1 = 0, source_port_2 = 0;
+
+ if (source_input != SOURCE_HDMI1 && source_input != SOURCE_HDMI2 && source_input != SOURCE_HDMI3) {
+ return -1;
+ }
+
+ mSourceDevLogicAddrBuf[0] = E_LA_TV;
+ mSourceDevLogicAddrBuf[1] = E_LA_TV;
+ mSourceDevLogicAddrBuf[2] = E_LA_TV;
+
+ for (i = 0; i < CC_SOURCE_DEV_REFRESH_CNT; i++) {
+ if (mSourceDevRefreshBuf[i] < 0) {
+ continue;
+ }
+
+ physical_addr = 0;
+ if (SendGivePhysicalAddressMessage(source_input, mSourceDevRefreshBuf[i], &physical_addr) > 0) {
+ source_port_1 = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
+ source_port_2 = CTvin::Tvin_GetSourcePortByCECPhysicalAddress(physical_addr);
+ if (source_port_1 == source_port_2) {
+ mSourceDevLogicAddrBuf[source_input - SOURCE_HDMI1] = mSourceDevRefreshBuf[i];
+ break;
+ }
+ }
+ }
+
+ if (i == CC_SOURCE_DEV_REFRESH_CNT) {
+ return -1;
+ }
+
+ return 0;
}
int CTvin::CHDMIRxCEC::ClearRxMessageBuffer()
{
- int m_cec_dev_fd = -1;
+ int m_cec_dev_fd = -1;
- m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
- if (m_cec_dev_fd < 0) {
- LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
- return -1;
- }
+ m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
+ if (m_cec_dev_fd < 0) {
+ LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
+ return -1;
+ }
- ioctl(m_cec_dev_fd, HDMI_IOC_CEC_CLEAR_BUFFER, NULL);
+ ioctl(m_cec_dev_fd, HDMI_IOC_CEC_CLEAR_BUFFER, NULL);
- close(m_cec_dev_fd);
- m_cec_dev_fd = -1;
+ close(m_cec_dev_fd);
+ m_cec_dev_fd = -1;
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::GetMessage(struct _cec_msg msg_buf[])
{
- int i = 0;
- int m_cec_dev_fd = -1;
- int msg_cnt = 0;
-
- if (msg_buf == NULL) {
- LOGE("%s, msg_buf is NULL\n", __FUNCTION__);
- }
-
- m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
- if (m_cec_dev_fd < 0) {
- LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
- return 0;
- }
-
- ioctl(m_cec_dev_fd, HDMI_IOC_CEC_GET_MSG_CNT, &msg_cnt);
- if (msg_cnt > 0) {
- LOGD("%s, msg_cnt = %d\n", __FUNCTION__, msg_cnt);
-
- for (i = 0; i < msg_cnt; i++) {
- ioctl(m_cec_dev_fd, HDMI_IOC_CEC_GET_MSG, &msg_buf[i]);
- PrintMessage(__FUNCTION__, 0, &msg_buf[i]);
- }
- }
-
- close(m_cec_dev_fd);
- m_cec_dev_fd = -1;
-
- return msg_cnt;
+ int i = 0;
+ int m_cec_dev_fd = -1;
+ int msg_cnt = 0;
+
+ if (msg_buf == NULL) {
+ LOGE("%s, msg_buf is NULL\n", __FUNCTION__);
+ }
+
+ m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
+ if (m_cec_dev_fd < 0) {
+ LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
+ return 0;
+ }
+
+ ioctl(m_cec_dev_fd, HDMI_IOC_CEC_GET_MSG_CNT, &msg_cnt);
+ if (msg_cnt > 0) {
+ LOGD("%s, msg_cnt = %d\n", __FUNCTION__, msg_cnt);
+
+ for (i = 0; i < msg_cnt; i++) {
+ ioctl(m_cec_dev_fd, HDMI_IOC_CEC_GET_MSG, &msg_buf[i]);
+ PrintMessage(__FUNCTION__, 0, &msg_buf[i]);
+ }
+ }
+
+ close(m_cec_dev_fd);
+ m_cec_dev_fd = -1;
+
+ return msg_cnt;
}
int CTvin::CHDMIRxCEC::SendMessage(struct _cec_msg *msg)
{
- int m_cec_dev_fd = -1;
+ int m_cec_dev_fd = -1;
- if (msg == NULL) {
- LOGE("%s, msg is NULL\n", __FUNCTION__);
- }
+ if (msg == NULL) {
+ LOGE("%s, msg is NULL\n", __FUNCTION__);
+ }
- PrintMessage(__FUNCTION__, 0, msg);
+ PrintMessage(__FUNCTION__, 0, msg);
- m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
- if (m_cec_dev_fd < 0) {
- LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
- return -1;
- }
+ m_cec_dev_fd = open(CS_HDMIRX_CEC_PATH, O_RDWR);
+ if (m_cec_dev_fd < 0) {
+ LOGE("%s, Open file %s error: (%s)!\n", __FUNCTION__, CS_HDMIRX_CEC_PATH, strerror ( errno ));
+ return -1;
+ }
- ioctl(m_cec_dev_fd, HDMI_IOC_CEC_SENT_MSG, msg);
+ ioctl(m_cec_dev_fd, HDMI_IOC_CEC_SENT_MSG, msg);
- close(m_cec_dev_fd);
- m_cec_dev_fd = -1;
+ close(m_cec_dev_fd);
+ m_cec_dev_fd = -1;
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::sendMessageAndWaitReply(struct _cec_msg *msg, struct _cec_msg *reply_msg, int WaitCmd, int timeout)
{
- int tmp_ret = 0, tmp_ind = 0;
+ int tmp_ret = 0, tmp_ind = 0;
- tmp_ret = SendMessage(msg);
- if (tmp_ret < 0) {
- return tmp_ret;
- }
+ tmp_ret = SendMessage(msg);
+ if (tmp_ret < 0) {
+ return tmp_ret;
+ }
- reply_msg->msg_len = 0;
+ reply_msg->msg_len = 0;
- HDMIRxRequestReplyItem reply_item;
- reply_item.WaitCmd = WaitCmd;
- reply_item.WaitLogicAddr = msg->addr;
- reply_item.WaitTimeOut = timeout;
- reply_item.WaitFlag = 1;
- reply_item.DataFlag = 0;
+ HDMIRxRequestReplyItem reply_item;
+ reply_item.WaitCmd = WaitCmd;
+ reply_item.WaitLogicAddr = msg->addr;
+ reply_item.WaitTimeOut = timeout;
+ reply_item.WaitFlag = 1;
+ reply_item.DataFlag = 0;
- tmp_ind = addToRequestList(&reply_item);
+ tmp_ind = addToRequestList(&reply_item);
- mReplyLock[tmp_ind].lock();
- mReplyList[tmp_ind].WaitReplyCondition.waitRelative(mReplyLock[tmp_ind], timeout);//wait reply
- mReplyLock[tmp_ind].unlock();
+ mReplyLock[tmp_ind].lock();
+ mReplyList[tmp_ind].WaitReplyCondition.waitRelative(mReplyLock[tmp_ind], timeout);//wait reply
+ mReplyLock[tmp_ind].unlock();
- if (mReplyList[tmp_ind].DataFlag == 1) {
- PrintMessage(__FUNCTION__, 0, &mReplyList[tmp_ind].msg);
- *reply_msg = mReplyList[tmp_ind].msg;
- } else {
- rmFromRequestList(tmp_ind);
- return -1;
- }
+ if (mReplyList[tmp_ind].DataFlag == 1) {
+ PrintMessage(__FUNCTION__, 0, &mReplyList[tmp_ind].msg);
+ *reply_msg = mReplyList[tmp_ind].msg;
+ } else {
+ rmFromRequestList(tmp_ind);
+ return -1;
+ }
- rmFromRequestList(tmp_ind);
+ rmFromRequestList(tmp_ind);
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::SendCustomMessage(int source_input, unsigned char data_buf[])
{
- CECMsgStream msg_stream;
+ CECMsgStream msg_stream;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- memcpy((void *)msg_stream.buf, data_buf, CC_CEC_STREAM_SIZE);
- if (msg_stream.msg.msg_len > CC_CEC_STREAM_SIZE) {
- return -1;
- }
+ memcpy((void *)msg_stream.buf, data_buf, CC_CEC_STREAM_SIZE);
+ if (msg_stream.msg.msg_len > CC_CEC_STREAM_SIZE) {
+ return -1;
+ }
- return SendMessage(&msg_stream.msg);
+ return SendMessage(&msg_stream.msg);
}
int CTvin::CHDMIRxCEC::SendCustomMessageAndWaitReply(int source_input, unsigned char data_buf[], unsigned char reply_buf[], int WaitCmd, int timeout)
{
- CECMsgStream msg_stream;
- struct _cec_msg reply_msg;
+ CECMsgStream msg_stream;
+ struct _cec_msg reply_msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- memcpy((void *)msg_stream.buf, data_buf, CC_CEC_STREAM_SIZE);
- if (msg_stream.msg.msg_len > CC_CEC_STREAM_SIZE) {
- return -1;
- }
+ memcpy((void *)msg_stream.buf, data_buf, CC_CEC_STREAM_SIZE);
+ if (msg_stream.msg.msg_len > CC_CEC_STREAM_SIZE) {
+ return -1;
+ }
- if (sendMessageAndWaitReply(&msg_stream.msg, &reply_msg, WaitCmd, timeout) < 0) {
- return -1;
- }
+ if (sendMessageAndWaitReply(&msg_stream.msg, &reply_msg, WaitCmd, timeout) < 0) {
+ return -1;
+ }
- return CopyMessageData(reply_buf, reply_msg.msg_data, reply_msg.msg_len);
+ return CopyMessageData(reply_buf, reply_msg.msg_data, reply_msg.msg_len);
}
int CTvin::CHDMIRxCEC::SendBoradcastStandbyMessage(int source_input)
{
- struct _cec_msg msg;
+ struct _cec_msg msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_STANDBY;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_STANDBY;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- return SendMessage(&msg);
+ return SendMessage(&msg);
}
int CTvin::CHDMIRxCEC::SendGiveCECVersionMessage(int source_input, unsigned char data_buf[])
{
- struct _cec_msg msg, reply_msg;
+ struct _cec_msg msg, reply_msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- if (data_buf == NULL) {
- return -1;
- }
+ if (data_buf == NULL) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_GET_CEC_VERSION;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_GET_CEC_VERSION;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_CEC_VERSION, 2000) < 0) {
- return -1;
- }
+ if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_CEC_VERSION, 2000) < 0) {
+ return -1;
+ }
- return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
+ return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
}
int CTvin::CHDMIRxCEC::SendGiveDeviceVendorIDMessage(int source_input, unsigned char data_buf[])
{
- struct _cec_msg msg, reply_msg;
+ struct _cec_msg msg, reply_msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- if (data_buf == NULL) {
- return -1;
- }
+ if (data_buf == NULL) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_GIVE_DEVICE_VENDOR_ID;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_GIVE_DEVICE_VENDOR_ID;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_DEVICE_VENDOR_ID, 2000) < 0) {
- return -1;
- }
+ if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_DEVICE_VENDOR_ID, 2000) < 0) {
+ return -1;
+ }
- return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
+ return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
}
int CTvin::CHDMIRxCEC::SendGiveOSDNameMessage(int source_input, unsigned char data_buf[])
{
- struct _cec_msg msg, reply_msg;
+ struct _cec_msg msg, reply_msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- if (data_buf == NULL) {
- return -1;
- }
+ if (data_buf == NULL) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_OSDNT_GIVE_OSD_NAME;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_OSDNT_GIVE_OSD_NAME;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_OSDNT_SET_OSD_NAME, 2000) < 0) {
- return -1;
- }
+ if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_OSDNT_SET_OSD_NAME, 2000) < 0) {
+ return -1;
+ }
- return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
+ return CopyMessageData(data_buf, reply_msg.msg_data, reply_msg.msg_len);
}
int CTvin::CHDMIRxCEC::SendGivePhysicalAddressMessage(int source_input, int logic_addr, int *physical_addr)
{
- struct _cec_msg msg, reply_msg;
+ struct _cec_msg msg, reply_msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- if (physical_addr == NULL) {
- return -1;
- }
+ if (physical_addr == NULL) {
+ return -1;
+ }
- msg.addr = logic_addr;
- msg.cmd = E_MSG_GIVE_PHYSICAL_ADDRESS;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = logic_addr;
+ msg.cmd = E_MSG_GIVE_PHYSICAL_ADDRESS;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_REPORT_PHYSICAL_ADDRESS, 2000) < 0) {
- return -1;
- }
+ if (sendMessageAndWaitReply(&msg, &reply_msg, E_MSG_REPORT_PHYSICAL_ADDRESS, 2000) < 0) {
+ return -1;
+ }
- if (reply_msg.msg_len == 5) {
- *physical_addr = 0;
- *physical_addr |= reply_msg.msg_data[0] << 8;
- *physical_addr |= reply_msg.msg_data[1];
- return reply_msg.msg_len;
- }
+ if (reply_msg.msg_len == 5) {
+ *physical_addr = 0;
+ *physical_addr |= reply_msg.msg_data[0] << 8;
+ *physical_addr |= reply_msg.msg_data[1];
+ return reply_msg.msg_len;
+ }
- return -1;
+ return -1;
}
int CTvin::CHDMIRxCEC::SendSetMenuLanguageMessage(int source_input, unsigned char data_buf[])
{
- struct _cec_msg msg;
+ struct _cec_msg msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- if (data_buf == NULL) {
- return -1;
- }
+ if (data_buf == NULL) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_SET_MENU_LANGUAGE;
- msg.msg_data[0] = data_buf[0];
- msg.msg_data[1] = data_buf[1];
- msg.msg_data[2] = data_buf[2];
- msg.msg_len = 5;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_SET_MENU_LANGUAGE;
+ msg.msg_data[0] = data_buf[0];
+ msg.msg_data[1] = data_buf[1];
+ msg.msg_data[2] = data_buf[2];
+ msg.msg_len = 5;
- return SendMessage(&msg);
+ return SendMessage(&msg);
}
int CTvin::CHDMIRxCEC::SendVendorRemoteKeyDownMessage(int source_input, unsigned char key_val)
{
- struct _cec_msg msg;
+ struct _cec_msg msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_VENDOR_RC_BUT_DOWN;
- msg.msg_data[0] = key_val;
- msg.msg_len = 3;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_VENDOR_RC_BUT_DOWN;
+ msg.msg_data[0] = key_val;
+ msg.msg_len = 3;
- return SendMessage(&msg);
+ return SendMessage(&msg);
}
int CTvin::CHDMIRxCEC::SendVendorRemoteKeyUpMessage(int source_input)
{
- struct _cec_msg msg;
+ struct _cec_msg msg;
- if (isAllowOperate(source_input) < 0) {
- return -1;
- }
+ if (isAllowOperate(source_input) < 0) {
+ return -1;
+ }
- msg.addr = GetDeviceLogicAddr(source_input);
- msg.cmd = E_MSG_VENDOR_RC_BUT_UP;
- msg.msg_data[0] = 0;
- msg.msg_len = 2;
+ msg.addr = GetDeviceLogicAddr(source_input);
+ msg.cmd = E_MSG_VENDOR_RC_BUT_UP;
+ msg.msg_data[0] = 0;
+ msg.msg_len = 2;
- return SendMessage(&msg);
+ return SendMessage(&msg);
}
int CTvin::CHDMIRxCEC::rmFromRequestList(int index)
{
- mListLock.lock();
+ mListLock.lock();
- ClrReplyListItem(&mReplyList[index]);
+ ClrReplyListItem(&mReplyList[index]);
- mListLock.unlock();
+ mListLock.unlock();
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::addToRequestList(HDMIRxRequestReplyItem *reply_item)
{
- int i = 0;
+ int i = 0;
- mListLock.lock();
+ mListLock.lock();
- for (i = 0; i < CC_REQUEST_LIST_SIZE; i++) {
- if (mReplyList[i].WaitFlag == 0) {
- mReplyList[i] = *reply_item;
- mListLock.unlock();
- return i;
- }
- }
+ for (i = 0; i < CC_REQUEST_LIST_SIZE; i++) {
+ if (mReplyList[i].WaitFlag == 0) {
+ mReplyList[i] = *reply_item;
+ mListLock.unlock();
+ return i;
+ }
+ }
- mListLock.unlock();
+ mListLock.unlock();
- return 0;
+ return 0;
}
int CTvin::CHDMIRxCEC::processData(int msg_cnt)
{
- int i = 0, j = 0;
- CECMsgStream msg_stream;
-
- for (i = 0; i < msg_cnt; i++) {
- for (j = 0; j < CC_REQUEST_LIST_SIZE; j++) {
- if (mReplyList[j].WaitFlag) {
- if (mMsgBuf[i].cmd == mReplyList[j].WaitCmd && ((mMsgBuf[i].addr & 0xF0) >> 4) == mReplyList[j].WaitLogicAddr) {
- mReplyList[j].DataFlag = 1;
- mReplyList[j].msg = mMsgBuf[i];
- PrintMessage(__FUNCTION__, 0, &mReplyList[j].msg);
- mReplyList[j].WaitReplyCondition.signal();
-
- return 0;
- }
- }
- }
-
- msg_stream.msg = mMsgBuf[i];
- if (mpObserver != NULL) {
- mpObserver->onHDMIRxCECMessage(msg_stream.msg.msg_len, msg_stream.buf);
- }
- }
-
- return 0;
+ int i = 0, j = 0;
+ CECMsgStream msg_stream;
+
+ for (i = 0; i < msg_cnt; i++) {
+ for (j = 0; j < CC_REQUEST_LIST_SIZE; j++) {
+ if (mReplyList[j].WaitFlag) {
+ if (mMsgBuf[i].cmd == mReplyList[j].WaitCmd && ((mMsgBuf[i].addr & 0xF0) >> 4) == mReplyList[j].WaitLogicAddr) {
+ mReplyList[j].DataFlag = 1;
+ mReplyList[j].msg = mMsgBuf[i];
+ PrintMessage(__FUNCTION__, 0, &mReplyList[j].msg);
+ mReplyList[j].WaitReplyCondition.signal();
+
+ return 0;
+ }
+ }
+ }
+
+ msg_stream.msg = mMsgBuf[i];
+ if (mpObserver != NULL) {
+ mpObserver->onHDMIRxCECMessage(msg_stream.msg.msg_len, msg_stream.buf);
+ }
+ }
+
+ return 0;
}
bool CTvin::CHDMIRxCEC::threadLoop()
{
- int msg_cnt = 0;
- int sleeptime = 200; //ms
+ int msg_cnt = 0;
+ int sleeptime = 200; //ms
- mState = STATE_RUNNING;
+ mState = STATE_RUNNING;
- while (!exitPending()) { //requietexit() or requietexitWait() not call
- while (mRequestPause) {
- mLock.lock();
- mState = STATE_PAUSE;
- mPauseCondition.wait(mLock); //first unlock,when return,lock again,so need,call unlock
- mState = STATE_RUNNING;
- mLock.unlock();
- }
+ while (!exitPending()) { //requietexit() or requietexitWait() not call
+ while (mRequestPause) {
+ mLock.lock();
+ mState = STATE_PAUSE;
+ mPauseCondition.wait(mLock); //first unlock,when return,lock again,so need,call unlock
+ mState = STATE_RUNNING;
+ mLock.unlock();
+ }
- msg_cnt = GetMessage(mMsgBuf);
+ msg_cnt = GetMessage(mMsgBuf);
- processData(msg_cnt);
+ processData(msg_cnt);
- if (!mRequestPause) {
- usleep(sleeptime * 1000);
- }
- }
+ if (!mRequestPause) {
+ usleep(sleeptime * 1000);
+ }
+ }
- mState = STATE_STOPED;
- //exit
- //return true, run again, return false,not run.
- return false;
+ mState = STATE_STOPED;
+ //exit
+ //return true, run again, return false,not run.
+ return false;
}