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/CSourceConnectDetect.cpp b/tvapi/libtv/tvin/CSourceConnectDetect.cpp
index 4399473..cbb2044 100644
--- a/tvapi/libtv/tvin/CSourceConnectDetect.cpp
+++ b/tvapi/libtv/tvin/CSourceConnectDetect.cpp
@@ -20,32 +20,29 @@
CSourceConnectDetect::CSourceConnectDetect(CTvin *pTvin)
{
- mpObserver = NULL;
- mpTvin = pTvin;
- if (mEpoll.create() < 0) {
- return;
- }
- //avin
- if (mAvinDetectFile.openFile(AVIN_DETECT_PATH) > 0)
- {
- m_event.data.fd = mAvinDetectFile.getFd();
- m_event.events = EPOLLIN | EPOLLET;
- mEpoll.add(mAvinDetectFile.getFd(), &m_event);
- }
- //HDMI
- if (mHdmiDetectFile.openFile(HDMI_DETECT_PATH) > 0)
- {
- m_event.data.fd = mHdmiDetectFile.getFd();
- m_event.events = EPOLLIN | EPOLLET;
- mEpoll.add(mHdmiDetectFile.getFd(), &m_event);
- }
- //vfame size change
- if (mVppPollFile.openFile(VPP_POLL_PATCH) > 0)
- {
- m_event.data.fd = mVppPollFile.getFd();
- m_event.events = EPOLLIN | EPOLLET;
- mEpoll.add(mVppPollFile.getFd(), &m_event);
- }
+ mpObserver = NULL;
+ mpTvin = pTvin;
+ if (mEpoll.create() < 0) {
+ return;
+ }
+ //avin
+ if (mAvinDetectFile.openFile(AVIN_DETECT_PATH) > 0) {
+ m_event.data.fd = mAvinDetectFile.getFd();
+ m_event.events = EPOLLIN | EPOLLET;
+ mEpoll.add(mAvinDetectFile.getFd(), &m_event);
+ }
+ //HDMI
+ if (mHdmiDetectFile.openFile(HDMI_DETECT_PATH) > 0) {
+ m_event.data.fd = mHdmiDetectFile.getFd();
+ m_event.events = EPOLLIN | EPOLLET;
+ mEpoll.add(mHdmiDetectFile.getFd(), &m_event);
+ }
+ //vfame size change
+ if (mVppPollFile.openFile(VPP_POLL_PATCH) > 0) {
+ m_event.data.fd = mVppPollFile.getFd();
+ m_event.events = EPOLLIN | EPOLLET;
+ mEpoll.add(mVppPollFile.getFd(), &m_event);
+ }
}
CSourceConnectDetect::~CSourceConnectDetect()
@@ -54,243 +51,216 @@ CSourceConnectDetect::~CSourceConnectDetect()
int CSourceConnectDetect::startDetect()
{
- this->run();
+ this->run();
- return 0;
+ return 0;
}
int CSourceConnectDetect::SourceInputMaptoChipHdmiPort(tv_source_input_t source_input)
{
- tvin_port_t source_port = TVIN_PORT_NULL;
- source_port = mpTvin->Tvin_GetSourcePortBySourceInput(source_input);
- switch (source_port)
- {
- case TVIN_PORT_HDMI0:
- return HDMI_DETECT_STATUS_BIT_A;
- break;
- case TVIN_PORT_HDMI1:
- return HDMI_DETECT_STATUS_BIT_B;
- break;
- case TVIN_PORT_HDMI2:
- return HDMI_DETECT_STATUS_BIT_C;
- break;
- case TVIN_PORT_HDMI3:
- return HDMI_DETECT_STATUS_BIT_D;
- break;
- default:
- return HDMI_DETECT_STATUS_BIT_A;
- break;
- }
+ tvin_port_t source_port = TVIN_PORT_NULL;
+ source_port = mpTvin->Tvin_GetSourcePortBySourceInput(source_input);
+ switch (source_port) {
+ case TVIN_PORT_HDMI0:
+ return HDMI_DETECT_STATUS_BIT_A;
+ break;
+ case TVIN_PORT_HDMI1:
+ return HDMI_DETECT_STATUS_BIT_B;
+ break;
+ case TVIN_PORT_HDMI2:
+ return HDMI_DETECT_STATUS_BIT_C;
+ break;
+ case TVIN_PORT_HDMI3:
+ return HDMI_DETECT_STATUS_BIT_D;
+ break;
+ default:
+ return HDMI_DETECT_STATUS_BIT_A;
+ break;
+ }
}
tv_source_input_t CSourceConnectDetect::ChipHdmiPortMaptoSourceInput(int port)
{
- switch (port)
- {
- case HDMI_DETECT_STATUS_BIT_A:
- return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI0);
- break;
- case HDMI_DETECT_STATUS_BIT_B:
- return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI1);
- break;
- case HDMI_DETECT_STATUS_BIT_C:
- return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI2);
- break;
- case HDMI_DETECT_STATUS_BIT_D:
- return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI3);
- break;
- default:
- return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI0);
- break;
- }
+ switch (port) {
+ case HDMI_DETECT_STATUS_BIT_A:
+ return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI0);
+ break;
+ case HDMI_DETECT_STATUS_BIT_B:
+ return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI1);
+ break;
+ case HDMI_DETECT_STATUS_BIT_C:
+ return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI2);
+ break;
+ case HDMI_DETECT_STATUS_BIT_D:
+ return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI3);
+ break;
+ default:
+ return mpTvin->Tvin_PortToSourceInput(TVIN_PORT_HDMI0);
+ break;
+ }
}
int CSourceConnectDetect::GetSourceConnectStatus(tv_source_input_t source_input)
{
- int PlugStatus = -1;
- int hdmi_status = 0;
- int source = -1;
- int HdmiDetectStatusBit = SourceInputMaptoChipHdmiPort((tv_source_input_t)source_input);
- switch (source_input)
- {
- case SOURCE_AV2:
- case SOURCE_AV1:
- {
- struct report_data_s status[2];
- mAvinDetectFile.readFile((void *)(&status), sizeof(struct report_data_s) * 2);
- for (int i = 0; i < 2; i++)
- {
- if (status[i].channel == AVIN_CHANNEL1)
- {
- source = SOURCE_AV1;
- }else if (status[i].channel == AVIN_CHANNEL2)
- {
- source = SOURCE_AV2;
- }
+ int PlugStatus = -1;
+ int hdmi_status = 0;
+ int source = -1;
+ int HdmiDetectStatusBit = SourceInputMaptoChipHdmiPort((tv_source_input_t)source_input);
+ switch (source_input) {
+ case SOURCE_AV2:
+ case SOURCE_AV1: {
+ struct report_data_s status[2];
+ mAvinDetectFile.readFile((void *)(&status), sizeof(struct report_data_s) * 2);
+ for (int i = 0; i < 2; i++) {
+ if (status[i].channel == AVIN_CHANNEL1) {
+ source = SOURCE_AV1;
+ } else if (status[i].channel == AVIN_CHANNEL2) {
+ source = SOURCE_AV2;
+ }
- if (source == source_input)
- {
- if (status[i].status == AVIN_STATUS_IN)
- {
- PlugStatus = CC_SOURCE_PLUG_IN;
- }else {
- PlugStatus = CC_SOURCE_PLUG_OUT;
- }
- break;
- }
- m_avin_status[i] = status[i];
- }//end for
+ if (source == source_input) {
+ if (status[i].status == AVIN_STATUS_IN) {
+ PlugStatus = CC_SOURCE_PLUG_IN;
+ } else {
+ PlugStatus = CC_SOURCE_PLUG_OUT;
+ }
+ break;
+ }
+ m_avin_status[i] = status[i];
+ }//end for
- break;
- }
- case SOURCE_HDMI1:
- case SOURCE_HDMI2:
- case SOURCE_HDMI3:
- {
- mHdmiDetectFile.readFile((void*)(&hdmi_status), sizeof(int));
- if ((hdmi_status & HdmiDetectStatusBit) == HdmiDetectStatusBit)
- {
- PlugStatus = CC_SOURCE_PLUG_IN;
- } else {
- PlugStatus = CC_SOURCE_PLUG_OUT;
- }
- m_hdmi_status = hdmi_status;
- break;
- }
- default:
- LOGD("GetSourceConnectStatus not support source!!!!!!!!!!!!!!!1");
- break;
- }
+ break;
+ }
+ case SOURCE_HDMI1:
+ case SOURCE_HDMI2:
+ case SOURCE_HDMI3: {
+ mHdmiDetectFile.readFile((void *)(&hdmi_status), sizeof(int));
+ if ((hdmi_status & HdmiDetectStatusBit) == HdmiDetectStatusBit) {
+ PlugStatus = CC_SOURCE_PLUG_IN;
+ } else {
+ PlugStatus = CC_SOURCE_PLUG_OUT;
+ }
+ m_hdmi_status = hdmi_status;
+ break;
+ }
+ default:
+ LOGD("GetSourceConnectStatus not support source!!!!!!!!!!!!!!!1");
+ break;
+ }
- return PlugStatus;
+ return PlugStatus;
}
bool CSourceConnectDetect::threadLoop()
{
- if ( mpObserver == NULL ) {
- return false;
- }
+ if ( mpObserver == NULL ) {
+ return false;
+ }
- LOGD("%s, entering...\n", "TV");
+ LOGD("%s, entering...\n", "TV");
- prctl(PR_SET_NAME, (unsigned long)"CSourceConnectDetect thread loop");
- //init status
- mHdmiDetectFile.readFile((void*)(&m_hdmi_status), sizeof(int));
- mAvinDetectFile.readFile((void *)(&m_avin_status), sizeof(struct report_data_s) * 2);
- LOGD("CSourceConnectDetect Loop, get init hdmi = 0x%x avin[0].status = %d, avin[1].status = %d", m_hdmi_status, m_avin_status[0].status, m_avin_status[1].status);
+ prctl(PR_SET_NAME, (unsigned long)"CSourceConnectDetect thread loop");
+ //init status
+ mHdmiDetectFile.readFile((void *)(&m_hdmi_status), sizeof(int));
+ mAvinDetectFile.readFile((void *)(&m_avin_status), sizeof(struct report_data_s) * 2);
+ LOGD("CSourceConnectDetect Loop, get init hdmi = 0x%x avin[0].status = %d, avin[1].status = %d", m_hdmi_status, m_avin_status[0].status, m_avin_status[1].status);
- while (!exitPending()) { //requietexit() or requietexitWait() not call
- int num = mEpoll.wait();
- for (int i = 0; i < num; ++i) {
- int fd = (mEpoll)[i].data.fd;
- /**
- * EPOLLIN event
- */
- if ((mEpoll)[i].events & EPOLLIN) {
- if (fd == mAvinDetectFile.getFd()) {//avin
- struct report_data_s status[2];
- mAvinDetectFile.readFile((void *)(&status), sizeof(struct report_data_s) * 2);
- for (int i = 0; i < 2; i++)
- {
- int source = -1, plug = -1;
- if (/*status[i].channel == m_avin_status[i].channel &&*/ status[i].status != m_avin_status[i].status)
- {
- //LOGD("status[i].status != m_avin_status[i].status");
- if (status[i].status == AVIN_STATUS_IN)
- {
- plug = CC_SOURCE_PLUG_IN;
- }else {
- plug = CC_SOURCE_PLUG_OUT;
- }
+ while (!exitPending()) { //requietexit() or requietexitWait() not call
+ int num = mEpoll.wait();
+ for (int i = 0; i < num; ++i) {
+ int fd = (mEpoll)[i].data.fd;
+ /**
+ * EPOLLIN event
+ */
+ if ((mEpoll)[i].events & EPOLLIN) {
+ if (fd == mAvinDetectFile.getFd()) {//avin
+ struct report_data_s status[2];
+ mAvinDetectFile.readFile((void *)(&status), sizeof(struct report_data_s) * 2);
+ for (int i = 0; i < 2; i++) {
+ int source = -1, plug = -1;
+ if (/*status[i].channel == m_avin_status[i].channel &&*/ status[i].status != m_avin_status[i].status) {
+ //LOGD("status[i].status != m_avin_status[i].status");
+ if (status[i].status == AVIN_STATUS_IN) {
+ plug = CC_SOURCE_PLUG_IN;
+ } else {
+ plug = CC_SOURCE_PLUG_OUT;
+ }
- if (status[i].channel == AVIN_CHANNEL1)
- {
- source = SOURCE_AV1;
- }else if (status[i].channel == AVIN_CHANNEL2)
- {
- source = SOURCE_AV2;
- }
+ if (status[i].channel == AVIN_CHANNEL1) {
+ source = SOURCE_AV1;
+ } else if (status[i].channel == AVIN_CHANNEL2) {
+ source = SOURCE_AV2;
+ }
- if (mpObserver != NULL)
- {
- mpObserver->onSourceConnect(source, plug);
- }
- }//not equal
- m_avin_status[i] = status[i];
- }
- }else if (fd == mHdmiDetectFile.getFd())//hdmi
- {
- int hdmi_status = 0;
- mHdmiDetectFile.readFile((void*)(&hdmi_status), sizeof(int));
- int source = -1, plug = -1;
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_A) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_A) )
- {
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_A) == HDMI_DETECT_STATUS_BIT_A)
- {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_A);
- plug = CC_SOURCE_PLUG_IN;
- } else {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_A);;
- plug = CC_SOURCE_PLUG_OUT;
- }
- mpObserver->onSourceConnect(source, plug);
- }
+ if (mpObserver != NULL) {
+ mpObserver->onSourceConnect(source, plug);
+ }
+ }//not equal
+ m_avin_status[i] = status[i];
+ }
+ } else if (fd == mHdmiDetectFile.getFd()) { //hdmi
+ int hdmi_status = 0;
+ mHdmiDetectFile.readFile((void *)(&hdmi_status), sizeof(int));
+ int source = -1, plug = -1;
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_A) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_A) ) {
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_A) == HDMI_DETECT_STATUS_BIT_A) {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_A);
+ plug = CC_SOURCE_PLUG_IN;
+ } else {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_A);;
+ plug = CC_SOURCE_PLUG_OUT;
+ }
+ mpObserver->onSourceConnect(source, plug);
+ }
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_B) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_B) )
- {
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_B) == HDMI_DETECT_STATUS_BIT_B)
- {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_B);
- plug = CC_SOURCE_PLUG_IN;
- } else {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_B);;
- plug = CC_SOURCE_PLUG_OUT;
- }
- mpObserver->onSourceConnect(source, plug);
- }
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_B) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_B) ) {
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_B) == HDMI_DETECT_STATUS_BIT_B) {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_B);
+ plug = CC_SOURCE_PLUG_IN;
+ } else {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_B);;
+ plug = CC_SOURCE_PLUG_OUT;
+ }
+ mpObserver->onSourceConnect(source, plug);
+ }
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_C) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_C) )
- {
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_C) == HDMI_DETECT_STATUS_BIT_C)
- {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_C);
- plug = CC_SOURCE_PLUG_IN;
- } else {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_C);;
- plug = CC_SOURCE_PLUG_OUT;
- }
- mpObserver->onSourceConnect(source, plug);
- }
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_C) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_C) ) {
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_C) == HDMI_DETECT_STATUS_BIT_C) {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_C);
+ plug = CC_SOURCE_PLUG_IN;
+ } else {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_C);;
+ plug = CC_SOURCE_PLUG_OUT;
+ }
+ mpObserver->onSourceConnect(source, plug);
+ }
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_D) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_D) )
- {
- if ((hdmi_status & HDMI_DETECT_STATUS_BIT_D) == HDMI_DETECT_STATUS_BIT_D)
- {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_D);
- plug = CC_SOURCE_PLUG_IN;
- } else {
- source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_D);;
- plug = CC_SOURCE_PLUG_OUT;
- }
- mpObserver->onSourceConnect(source, plug);
- }
- m_hdmi_status = hdmi_status;
- }else if (fd == mVppPollFile.getFd())//vframe size change
- {
- mpObserver->onVframeSizeChange();
- }
- /**
- * EPOLLOUT event
- */
- if ((mEpoll)[i].events & EPOLLOUT) {
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_D) != (m_hdmi_status & HDMI_DETECT_STATUS_BIT_D) ) {
+ if ((hdmi_status & HDMI_DETECT_STATUS_BIT_D) == HDMI_DETECT_STATUS_BIT_D) {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_D);
+ plug = CC_SOURCE_PLUG_IN;
+ } else {
+ source = ChipHdmiPortMaptoSourceInput(HDMI_DETECT_STATUS_BIT_D);;
+ plug = CC_SOURCE_PLUG_OUT;
+ }
+ mpObserver->onSourceConnect(source, plug);
+ }
+ m_hdmi_status = hdmi_status;
+ } else if (fd == mVppPollFile.getFd()) { //vframe size change
+ mpObserver->onVframeSizeChange();
+ }
+ /**
+ * EPOLLOUT event
+ */
+ if ((mEpoll)[i].events & EPOLLOUT) {
- }
- }
- }
- }//exit
+ }
+ }
+ }
+ }//exit
- LOGD("%s, exiting...\n", "CSourceConnectDetect");
- //return true, run again, return false,not run.
- return false;
+ LOGD("%s, exiting...\n", "CSourceConnectDetect");
+ //return true, run again, return false,not run.
+ return false;
}