summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_input.cpp45
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h100
-rw-r--r--tvapi/android/include/ITvClient.h58
-rw-r--r--tvapi/android/include/ITvService.h68
-rw-r--r--tvapi/android/include/Tv.h161
-rw-r--r--tvapi/android/include/tvcmd.h1188
-rw-r--r--tvapi/android/jni/Android.mk132
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp911
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp289
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp117
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp101
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tvserver/Android.mk162
-rw-r--r--tvapi/android/tvserver/TvService.cpp8755
-rw-r--r--tvapi/android/tvserver/TvService.h164
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rwxr-xr-x[-rw-r--r--]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk3
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2426
-rw-r--r--tvapi/libtv/audio/audio_alsa.h261
-rw-r--r--tvapi/libtv/audio/audio_android.cpp2070
-rw-r--r--tvapi/libtv/audio/audio_android.h157
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp1182
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h131
-rw-r--r--tvapi/libtv/audio/audio_api.cpp4940
-rw-r--r--tvapi/libtv/audio/audio_api.h647
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp456
-rw-r--r--tvapi/libtv/audio/audio_effect.h63
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h306
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h508
-rw-r--r--tvapi/libtv/include/ve.h438
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp426
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h47
-rw-r--r--tvapi/libtv/tv/CAv.cpp484
-rw-r--r--tvapi/libtv/tv/CAv.h194
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2326
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h680
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp838
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h227
-rw-r--r--tvapi/libtv/tv/CTv.cpp10755
-rw-r--r--tvapi/libtv/tv/CTv.h1269
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h167
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h15
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp260
-rw-r--r--tvapi/libtv/tv/CTvEpg.h280
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h314
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h93
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h43
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1417
-rw-r--r--tvapi/libtv/tv/CTvScanner.h319
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1060
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp272
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h469
-rw-r--r--tvapi/libtv/tv/CTvTime.h137
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h43
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h284
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h79
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf58
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp106
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h40
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp694
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h575
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp300
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h190
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h196
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp482
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h171
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h61
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1766
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1065
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h85
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp448
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4240
-rw-r--r--tvapi/libtv/tvin/CTvin.h2222
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h101
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp706
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h153
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h53
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h75
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4424
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h742
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h11
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2784
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp3706
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h338
-rw-r--r--tvapi/libtv/tvutils/CCondition.h87
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp250
-rw-r--r--tvapi/libtv/tvutils/CFile.h53
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h9
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp144
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h44
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h98
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h45
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h292
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h79
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp196
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h49
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h72
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3822
-rw-r--r--tvapi/libtv/tvutils/tvutils.h238
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h57
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3183
-rw-r--r--tvapi/libtv/vpp/CPQdb.h321
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp4772
-rw-r--r--tvapi/libtv/vpp/CVpp.h683
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp30
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
147 files changed, 55964 insertions, 55946 deletions
diff --git a/tvapi/libtv/tvin/CSourceConnectDetect.cpp b/tvapi/libtv/tvin/CSourceConnectDetect.cpp
index 1fe801d..ad44ad1 100644
--- a/tvapi/libtv/tvin/CSourceConnectDetect.cpp
+++ b/tvapi/libtv/tvin/CSourceConnectDetect.cpp
@@ -26,43 +26,43 @@
CTvin::CSourceConnectDetect::CSourceConnectDetect(CTvin *pTvin)
{
- for (int i = 0; i < SOURCE_MAX; i++) {
- mSourceDetectTable[i] = SOURCE_INVALID;
- mSourceDetectPreStatusBuf[i] = CC_SOURCE_PLUG_OUT;
- mSourceDetectCurStatusBuf[i] = CC_SOURCE_PLUG_OUT;
- }
+ for (int i = 0; i < SOURCE_MAX; i++) {
+ mSourceDetectTable[i] = SOURCE_INVALID;
+ mSourceDetectPreStatusBuf[i] = CC_SOURCE_PLUG_OUT;
+ mSourceDetectCurStatusBuf[i] = CC_SOURCE_PLUG_OUT;
+ }
- for (int i = 0; i < CC_AV_DETECT_SAMPLE_DATA_MAX_LEN; i++) {
- mAV1SampleDataBuf[i] = 0;
- mAV2SampleDataBuf[i] = 0;
- }
+ for (int i = 0; i < CC_AV_DETECT_SAMPLE_DATA_MAX_LEN; i++) {
+ mAV1SampleDataBuf[i] = 0;
+ mAV2SampleDataBuf[i] = 0;
+ }
#if CC_DETECT_SOURCE_AV2 == 1
- mSourceDetectTable[0] = SOURCE_AV1;
- mSourceDetectTable[1] = SOURCE_AV2;
- mSourceDetectTable[2] = SOURCE_HDMI1;
- mSourceDetectTable[3] = SOURCE_HDMI2;
- mSourceDetectTable[4] = SOURCE_HDMI3;
+ mSourceDetectTable[0] = SOURCE_AV1;
+ mSourceDetectTable[1] = SOURCE_AV2;
+ mSourceDetectTable[2] = SOURCE_HDMI1;
+ mSourceDetectTable[3] = SOURCE_HDMI2;
+ mSourceDetectTable[4] = SOURCE_HDMI3;
#else
- mSourceDetectTable[0] = SOURCE_AV1;
- mSourceDetectTable[1] = SOURCE_HDMI1;
- mSourceDetectTable[2] = SOURCE_HDMI2;
- mSourceDetectTable[3] = SOURCE_HDMI3;
+ mSourceDetectTable[0] = SOURCE_AV1;
+ mSourceDetectTable[1] = SOURCE_HDMI1;
+ mSourceDetectTable[2] = SOURCE_HDMI2;
+ mSourceDetectTable[3] = SOURCE_HDMI3;
#endif
- mSourceDetectSleepTime = 200; //default 200ms
+ mSourceDetectSleepTime = 200; //default 200ms
- mAVDetectMethod = CC_AV_DETECT_METHOD_ADC_PLUG_OUT;
- mAVDetectPlugOutADCThreshold = CC_AV_PLUG_OUT_ADC_DEF_THRESHOLD;
- mAVDetectPlugInADCThreshold = CC_AV_PLUG_IN_ADC_DEF_THRESHOLD;
- mAVDetectPlugInDutyCycle = 70;
- mAVDetectPlugOutDutyCycle = 70;
- mAVDetectSampleSize = 15;
- mAV1DetectADCChan = 2;
- mAV2DetectADCChan = 3;
+ mAVDetectMethod = CC_AV_DETECT_METHOD_ADC_PLUG_OUT;
+ mAVDetectPlugOutADCThreshold = CC_AV_PLUG_OUT_ADC_DEF_THRESHOLD;
+ mAVDetectPlugInADCThreshold = CC_AV_PLUG_IN_ADC_DEF_THRESHOLD;
+ mAVDetectPlugInDutyCycle = 70;
+ mAVDetectPlugOutDutyCycle = 70;
+ mAVDetectSampleSize = 15;
+ mAV1DetectADCChan = 2;
+ mAV2DetectADCChan = 3;
- mpObserver = NULL;
- mpTvin = pTvin;
+ mpObserver = NULL;
+ mpTvin = pTvin;
}
CTvin::CSourceConnectDetect::~CSourceConnectDetect()
@@ -71,242 +71,242 @@ CTvin::CSourceConnectDetect::~CSourceConnectDetect()
int CTvin::CSourceConnectDetect::startDetect()
{
- refreshDetectSources();
- refreshDetectAVInfo();
- this->run();
+ refreshDetectSources();
+ refreshDetectAVInfo();
+ this->run();
- return 0;
+ return 0;
}
int CTvin::CSourceConnectDetect::refreshDetectSources()
{
- int cur_index = 0;
- char *token = NULL;
- const char *strDelimit = ",";
- const char *config_value = NULL;
- char data_str[CC_CFG_VALUE_STR_MAX_LEN] = { 0 };
-
- config_value = config_get_str("TV", "tvin.SourceConnectDetect.sources", "null");
- if (strcasecmp(config_value, "null") == 0) {
- return 0;
- }
-
- for (int i = 0; i < SOURCE_MAX; i++) {
- mSourceDetectTable[i] = SOURCE_INVALID;
- mSourceDetectPreStatusBuf[i] = CC_SOURCE_PLUG_OUT;
- mSourceDetectCurStatusBuf[i] = CC_SOURCE_PLUG_OUT;
- }
-
- cur_index = 0;
- memset((void *)data_str, 0, sizeof(data_str));
- strncpy(data_str, config_value, sizeof(data_str) - 1);
- token = strtok(data_str, strDelimit);
- while (token != NULL) {
- if (strcasecmp(token, "SOURCE_AV1") == 0) {
- mSourceDetectTable[cur_index] = SOURCE_AV1;
- cur_index += 1;
- //LOGD("%s, add detect source SOURCE_AV1.\n", __FUNCTION__);
- } else if (strcasecmp(token, "SOURCE_AV2") == 0) {
- mSourceDetectTable[cur_index] = SOURCE_AV2;
- cur_index += 1;
- //LOGD("%s, add detect source SOURCE_AV2.\n", __FUNCTION__);
- } else if (strcasecmp(token, "SOURCE_HDMI1") == 0) {
- mSourceDetectTable[cur_index] = SOURCE_HDMI1;
- cur_index += 1;
- //LOGD("%s, add detect source SOURCE_HDMI1.\n", __FUNCTION__);
- } else if (strcasecmp(token, "SOURCE_HDMI2") == 0) {
- mSourceDetectTable[cur_index] = SOURCE_HDMI2;
- cur_index += 1;
- //LOGD("%s, add detect source SOURCE_HDMI2.\n", __FUNCTION__);
- } else if (strcasecmp(token, "SOURCE_HDMI3") == 0) {
- mSourceDetectTable[cur_index] = SOURCE_HDMI3;
- cur_index += 1;
- //LOGD("%s, add detect source SOURCE_HDMI3.\n", __FUNCTION__);
- }
-
- token = strtok(NULL, strDelimit);
- }
-
- return 0;
+ int cur_index = 0;
+ char *token = NULL;
+ const char *strDelimit = ",";
+ const char *config_value = NULL;
+ char data_str[CC_CFG_VALUE_STR_MAX_LEN] = { 0 };
+
+ config_value = config_get_str("TV", "tvin.SourceConnectDetect.sources", "null");
+ if (strcasecmp(config_value, "null") == 0) {
+ return 0;
+ }
+
+ for (int i = 0; i < SOURCE_MAX; i++) {
+ mSourceDetectTable[i] = SOURCE_INVALID;
+ mSourceDetectPreStatusBuf[i] = CC_SOURCE_PLUG_OUT;
+ mSourceDetectCurStatusBuf[i] = CC_SOURCE_PLUG_OUT;
+ }
+
+ cur_index = 0;
+ memset((void *)data_str, 0, sizeof(data_str));
+ strncpy(data_str, config_value, sizeof(data_str) - 1);
+ token = strtok(data_str, strDelimit);
+ while (token != NULL) {
+ if (strcasecmp(token, "SOURCE_AV1") == 0) {
+ mSourceDetectTable[cur_index] = SOURCE_AV1;
+ cur_index += 1;
+ //LOGD("%s, add detect source SOURCE_AV1.\n", __FUNCTION__);
+ } else if (strcasecmp(token, "SOURCE_AV2") == 0) {
+ mSourceDetectTable[cur_index] = SOURCE_AV2;
+ cur_index += 1;
+ //LOGD("%s, add detect source SOURCE_AV2.\n", __FUNCTION__);
+ } else if (strcasecmp(token, "SOURCE_HDMI1") == 0) {
+ mSourceDetectTable[cur_index] = SOURCE_HDMI1;
+ cur_index += 1;
+ //LOGD("%s, add detect source SOURCE_HDMI1.\n", __FUNCTION__);
+ } else if (strcasecmp(token, "SOURCE_HDMI2") == 0) {
+ mSourceDetectTable[cur_index] = SOURCE_HDMI2;
+ cur_index += 1;
+ //LOGD("%s, add detect source SOURCE_HDMI2.\n", __FUNCTION__);
+ } else if (strcasecmp(token, "SOURCE_HDMI3") == 0) {
+ mSourceDetectTable[cur_index] = SOURCE_HDMI3;
+ cur_index += 1;
+ //LOGD("%s, add detect source SOURCE_HDMI3.\n", __FUNCTION__);
+ }
+
+ token = strtok(NULL, strDelimit);
+ }
+
+ return 0;
}
int CTvin::CSourceConnectDetect::refreshDetectAVInfo()
{
- int cur_index = 0;
- char *token = NULL;
- const char *strDelimit = ",";
- const char *config_value = NULL;
- char data_str[CC_CFG_VALUE_STR_MAX_LEN] = { 0 };
-
- config_value = config_get_str("TV", "tvin.SourceConnectDetect.av.info", "null");
- if (strcasecmp(config_value, "null") == 0) {
- return 0;
- }
-
- cur_index = 0;
- memset((void *)data_str, 0, sizeof(data_str));
- strncpy(data_str, config_value, sizeof(data_str) - 1);
- token = strtok(data_str, strDelimit);
- while (token != NULL) {
- if (cur_index == 0) {
- mAV1DetectADCChan = strtol(token, NULL, 10);
- } else if (cur_index == 1) {
- mAV2DetectADCChan = strtol(token, NULL, 10);
- } else if (cur_index == 2) {
- mAVDetectSampleSize = strtol(token, NULL, 10);
- } else if (cur_index == 3) {
- mAVDetectMethod = strtol(token, NULL, 10);
- } else if (cur_index == 4) {
- mAVDetectPlugInDutyCycle = strtol(token, NULL, 10);
- } else if (cur_index == 5) {
- mAVDetectPlugOutDutyCycle = strtol(token, NULL, 10);
- } else if (cur_index == 6) {
- mAVDetectPlugInADCThreshold = strtol(token, NULL, 10);
- } else if (cur_index == 7) {
- mAVDetectPlugOutADCThreshold = strtol(token, NULL, 10);
- }
-
- cur_index += 1;
- token = strtok(NULL, strDelimit);
- }
-
- return 0;
+ int cur_index = 0;
+ char *token = NULL;
+ const char *strDelimit = ",";
+ const char *config_value = NULL;
+ char data_str[CC_CFG_VALUE_STR_MAX_LEN] = { 0 };
+
+ config_value = config_get_str("TV", "tvin.SourceConnectDetect.av.info", "null");
+ if (strcasecmp(config_value, "null") == 0) {
+ return 0;
+ }
+
+ cur_index = 0;
+ memset((void *)data_str, 0, sizeof(data_str));
+ strncpy(data_str, config_value, sizeof(data_str) - 1);
+ token = strtok(data_str, strDelimit);
+ while (token != NULL) {
+ if (cur_index == 0) {
+ mAV1DetectADCChan = strtol(token, NULL, 10);
+ } else if (cur_index == 1) {
+ mAV2DetectADCChan = strtol(token, NULL, 10);
+ } else if (cur_index == 2) {
+ mAVDetectSampleSize = strtol(token, NULL, 10);
+ } else if (cur_index == 3) {
+ mAVDetectMethod = strtol(token, NULL, 10);
+ } else if (cur_index == 4) {
+ mAVDetectPlugInDutyCycle = strtol(token, NULL, 10);
+ } else if (cur_index == 5) {
+ mAVDetectPlugOutDutyCycle = strtol(token, NULL, 10);
+ } else if (cur_index == 6) {
+ mAVDetectPlugInADCThreshold = strtol(token, NULL, 10);
+ } else if (cur_index == 7) {
+ mAVDetectPlugOutADCThreshold = strtol(token, NULL, 10);
+ }
+
+ cur_index += 1;
+ token = strtok(NULL, strDelimit);
+ }
+
+ return 0;
}
int CTvin::CSourceConnectDetect::GetSourceConnectStatus(int source_input)
{
- for (int i = 0; i < SOURCE_MAX; i++) {
- if (mSourceDetectTable[i] == source_input) {
- return mSourceDetectCurStatusBuf[i];
- }
- }
+ for (int i = 0; i < SOURCE_MAX; i++) {
+ if (mSourceDetectTable[i] == source_input) {
+ return mSourceDetectCurStatusBuf[i];
+ }
+ }
- return CC_SOURCE_PLUG_OUT;
+ return CC_SOURCE_PLUG_OUT;
}
bool CTvin::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");
+ prctl(PR_SET_NAME, (unsigned long)"CSourceConnectDetect thread loop");
- mpTvin->VDIN_OpenHDMIPinMuxOn(true);
+ mpTvin->VDIN_OpenHDMIPinMuxOn(true);
- while (!exitPending()) { //requietexit() or requietexitWait() not call
- DetectSources();
+ while (!exitPending()) { //requietexit() or requietexitWait() not call
+ DetectSources();
- usleep(mSourceDetectSleepTime * 1000);
- }
+ usleep(mSourceDetectSleepTime * 1000);
+ }
- LOGD("%s, exiting...\n", "TV");
- //return true, run again, return false,not run.
- return false;
+ LOGD("%s, exiting...\n", "TV");
+ //return true, run again, return false,not run.
+ return false;
}
int CTvin::CSourceConnectDetect::DetectSources()
{
- int i = 0, cur_source = 0;
-
- for (i = 0; i < SOURCE_MAX; i++) {
- cur_source = mSourceDetectTable[i];
- if (cur_source == SOURCE_AV1 || cur_source == SOURCE_AV2) {
- mSourceDetectCurStatusBuf[i] = DetectAVSource(cur_source);
- } else if (cur_source == SOURCE_HDMI1 || cur_source == SOURCE_HDMI2 || cur_source == SOURCE_HDMI3) {
- mSourceDetectCurStatusBuf[i] = DetectHDMISource(cur_source);
- }
- }
-
- for (i = 0; i < SOURCE_MAX; i++) {
- if (mSourceDetectCurStatusBuf[i] != mSourceDetectPreStatusBuf[i]) {
- mSourceDetectPreStatusBuf[i] = mSourceDetectCurStatusBuf[i];
- LOGD("%s, Source id = %d, Source plug status = %d\n", "TV", mSourceDetectTable[i], mSourceDetectCurStatusBuf[i]);
+ int i = 0, cur_source = 0;
+
+ for (i = 0; i < SOURCE_MAX; i++) {
+ cur_source = mSourceDetectTable[i];
+ if (cur_source == SOURCE_AV1 || cur_source == SOURCE_AV2) {
+ mSourceDetectCurStatusBuf[i] = DetectAVSource(cur_source);
+ } else if (cur_source == SOURCE_HDMI1 || cur_source == SOURCE_HDMI2 || cur_source == SOURCE_HDMI3) {
+ mSourceDetectCurStatusBuf[i] = DetectHDMISource(cur_source);
+ }
+ }
+
+ for (i = 0; i < SOURCE_MAX; i++) {
+ if (mSourceDetectCurStatusBuf[i] != mSourceDetectPreStatusBuf[i]) {
+ mSourceDetectPreStatusBuf[i] = mSourceDetectCurStatusBuf[i];
+ LOGD("%s, Source id = %d, Source plug status = %d\n", "TV", mSourceDetectTable[i], mSourceDetectCurStatusBuf[i]);
#if CC_DEBUG_AV_SAMPLE_BUF == 1
- int *cur_sample_buf = NULL;
-
- if (mSourceDetectTable[i] == SOURCE_AV1) {
- cur_sample_buf = mAV1SampleDataBuf;
- } else if (mSourceDetectTable[i] == SOURCE_AV2) {
- cur_sample_buf = mAV2SampleDataBuf;
- }
-
- if (cur_sample_buf != NULL) {
- for (int j = 0; j < mAVDetectSampleSize; j++) {
- LOGD("%s, cur_sample_buf[%d] = %d\n", "TV", j, cur_sample_buf[j]);
- }
- LOGD("%s, \n\n\n", "TV", i, cur_sample_buf[i]);
- }
+ int *cur_sample_buf = NULL;
+
+ if (mSourceDetectTable[i] == SOURCE_AV1) {
+ cur_sample_buf = mAV1SampleDataBuf;
+ } else if (mSourceDetectTable[i] == SOURCE_AV2) {
+ cur_sample_buf = mAV2SampleDataBuf;
+ }
+
+ if (cur_sample_buf != NULL) {
+ for (int j = 0; j < mAVDetectSampleSize; j++) {
+ LOGD("%s, cur_sample_buf[%d] = %d\n", "TV", j, cur_sample_buf[j]);
+ }
+ LOGD("%s, \n\n\n", "TV", i, cur_sample_buf[i]);
+ }
#endif
- mpObserver->onSourceConnect(mSourceDetectTable[i], mSourceDetectCurStatusBuf[i]);
- }
- }
+ mpObserver->onSourceConnect(mSourceDetectTable[i], mSourceDetectCurStatusBuf[i]);
+ }
+ }
- return 0;
+ return 0;
}
int CTvin::CSourceConnectDetect::DetectAVSource(int source_input)
{
- int i = 0, plug_in_cnt = 0, plug_out_cnt = 0;
- int detect_adc_chan = -1, cur_adc_val = 0;
- int *cur_sample_ind = 0;
- int *cur_sample_buf = NULL;
-
- if (source_input == SOURCE_AV1) {
- detect_adc_chan = mAV1DetectADCChan;
- cur_sample_ind = &mAV1CurSampleInd;
- cur_sample_buf = mAV1SampleDataBuf;
- } else if (source_input == SOURCE_AV2) {
- detect_adc_chan = mAV2DetectADCChan;
- cur_sample_ind = &mAV2CurSampleInd;
- cur_sample_buf = mAV2SampleDataBuf;
- } else {
- return CC_SOURCE_PLUG_OUT;
- }
-
- cur_adc_val = ReadADCSpecialChannelValue(detect_adc_chan);
- *cur_sample_ind = *cur_sample_ind % mAVDetectSampleSize;
- cur_sample_buf[*cur_sample_ind] = cur_adc_val;
- *cur_sample_ind = (*cur_sample_ind + 1 ) % mAVDetectSampleSize;
-
- plug_in_cnt = 0;
- plug_out_cnt = 0;
- for (i = 0; i < mAVDetectSampleSize; i++) {
- if (cur_sample_buf[i] >= mAVDetectPlugInADCThreshold) {
- plug_in_cnt += 1;
- } else if (cur_sample_buf[i] <= mAVDetectPlugOutADCThreshold) {
- plug_out_cnt += 1;
- }
- }
-
- if (mAVDetectMethod == CC_AV_DETECT_METHOD_ADC_PLUG_IN) {
- if ((plug_in_cnt * 100 / mAVDetectSampleSize) >= mAVDetectPlugInDutyCycle) {
- return CC_SOURCE_PLUG_IN;
- }
-
- return CC_SOURCE_PLUG_OUT;
- } else if (mAVDetectMethod == CC_AV_DETECT_METHOD_ADC_PLUG_OUT) {
- if ((plug_out_cnt * 100 / mAVDetectSampleSize) >= mAVDetectPlugOutDutyCycle) {
- return CC_SOURCE_PLUG_OUT;
- }
-
- return CC_SOURCE_PLUG_IN;
- }
-
- return CC_SOURCE_PLUG_OUT;
+ int i = 0, plug_in_cnt = 0, plug_out_cnt = 0;
+ int detect_adc_chan = -1, cur_adc_val = 0;
+ int *cur_sample_ind = 0;
+ int *cur_sample_buf = NULL;
+
+ if (source_input == SOURCE_AV1) {
+ detect_adc_chan = mAV1DetectADCChan;
+ cur_sample_ind = &mAV1CurSampleInd;
+ cur_sample_buf = mAV1SampleDataBuf;
+ } else if (source_input == SOURCE_AV2) {
+ detect_adc_chan = mAV2DetectADCChan;
+ cur_sample_ind = &mAV2CurSampleInd;
+ cur_sample_buf = mAV2SampleDataBuf;
+ } else {
+ return CC_SOURCE_PLUG_OUT;
+ }
+
+ cur_adc_val = ReadADCSpecialChannelValue(detect_adc_chan);
+ *cur_sample_ind = *cur_sample_ind % mAVDetectSampleSize;
+ cur_sample_buf[*cur_sample_ind] = cur_adc_val;
+ *cur_sample_ind = (*cur_sample_ind + 1 ) % mAVDetectSampleSize;
+
+ plug_in_cnt = 0;
+ plug_out_cnt = 0;
+ for (i = 0; i < mAVDetectSampleSize; i++) {
+ if (cur_sample_buf[i] >= mAVDetectPlugInADCThreshold) {
+ plug_in_cnt += 1;
+ } else if (cur_sample_buf[i] <= mAVDetectPlugOutADCThreshold) {
+ plug_out_cnt += 1;
+ }
+ }
+
+ if (mAVDetectMethod == CC_AV_DETECT_METHOD_ADC_PLUG_IN) {
+ if ((plug_in_cnt * 100 / mAVDetectSampleSize) >= mAVDetectPlugInDutyCycle) {
+ return CC_SOURCE_PLUG_IN;
+ }
+
+ return CC_SOURCE_PLUG_OUT;
+ } else if (mAVDetectMethod == CC_AV_DETECT_METHOD_ADC_PLUG_OUT) {
+ if ((plug_out_cnt * 100 / mAVDetectSampleSize) >= mAVDetectPlugOutDutyCycle) {
+ return CC_SOURCE_PLUG_OUT;
+ }
+
+ return CC_SOURCE_PLUG_IN;
+ }
+
+ return CC_SOURCE_PLUG_OUT;
}
int CTvin::CSourceConnectDetect::DetectHDMISource(int source_input)
{
- int source_port = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
+ int source_port = CTvin::Tvin_GetSourcePortBySourceInput((tv_source_input_t)source_input);
- if (mpTvin->VDIN_GetPortConnect(source_port) == true) {
- return CC_SOURCE_PLUG_IN;
- }
+ if (mpTvin->VDIN_GetPortConnect(source_port) == true) {
+ return CC_SOURCE_PLUG_IN;
+ }
- return CC_SOURCE_PLUG_OUT;
+ return CC_SOURCE_PLUG_OUT;
}