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/tv/CAv.cpp b/tvapi/libtv/tv/CAv.cpp
index 904ee3b..54f44e2 100644
--- a/tvapi/libtv/tv/CAv.cpp
+++ b/tvapi/libtv/tv/CAv.cpp
@@ -11,11 +11,11 @@
#include <amstream.h>
CAv::CAv()
{
- mpObserver = NULL;
- mTvPlayDevId = 0;
- mCurVideoLayerMuteState = -1;
- mCurDisableVideoColor = -1;
- mFdAmVideo = -1;
+ mpObserver = NULL;
+ mTvPlayDevId = 0;
+ mCurVideoLayerMuteState = -1;
+ mCurDisableVideoColor = -1;
+ mFdAmVideo = -1;
}
CAv::~CAv()
{
@@ -23,451 +23,451 @@ CAv::~CAv()
}
int CAv::SetVideoWindow(int x, int y, int w, int h)
{
- return AM_AV_SetVideoWindow (mTvPlayDevId, x, y, w, h );
+ return AM_AV_SetVideoWindow (mTvPlayDevId, x, y, w, h );
}
int CAv::Open()
{
- AM_AV_OpenPara_t para_av;
- memset ( &para_av, 0, sizeof ( AM_AV_OpenPara_t ) );
- int rt = AM_AV_Open ( mTvPlayDevId, &para_av );
- if ( rt != AM_SUCCESS ) {
- LOGD ( "%s, dvbplayer_open fail %d %d\n!" , __FUNCTION__, mTvPlayDevId, rt );
- return -1;
- }
-
- //open audio channle output
- AM_AOUT_OpenPara_t aout_para;
- memset ( &aout_para, 0, sizeof ( AM_AOUT_OpenPara_t ) );
- rt = AM_AOUT_Open ( 0, &aout_para );
-
- if ( AM_SUCCESS != rt ) {
- LOGD ( "%s, BUG: CANN'T OPEN AOUT\n", __FUNCTION__);
- }
- //
- mFdAmVideo = open ( PATH_VIDEO_AMVIDEO, O_RDWR );
- if ( mFdAmVideo < 0 ) {
- LOGE ( "mFdAmVideo < 0, error(%s)!\n", strerror ( errno ) );
- return -1;
- }
- /*Register events*/
- AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AV_NO_DATA, av_evt_callback, this );
- AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AV_DATA_RESUME, av_evt_callback, this );
- AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_VIDEO_SCAMBLED, av_evt_callback, this );
- AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AUDIO_SCAMBLED, av_evt_callback, this );
- AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_VIDEO_NOT_SUPPORT, av_evt_callback, this );
-
- return rt;
+ AM_AV_OpenPara_t para_av;
+ memset ( &para_av, 0, sizeof ( AM_AV_OpenPara_t ) );
+ int rt = AM_AV_Open ( mTvPlayDevId, &para_av );
+ if ( rt != AM_SUCCESS ) {
+ LOGD ( "%s, dvbplayer_open fail %d %d\n!" , __FUNCTION__, mTvPlayDevId, rt );
+ return -1;
+ }
+
+ //open audio channle output
+ AM_AOUT_OpenPara_t aout_para;
+ memset ( &aout_para, 0, sizeof ( AM_AOUT_OpenPara_t ) );
+ rt = AM_AOUT_Open ( 0, &aout_para );
+
+ if ( AM_SUCCESS != rt ) {
+ LOGD ( "%s, BUG: CANN'T OPEN AOUT\n", __FUNCTION__);
+ }
+ //
+ mFdAmVideo = open ( PATH_VIDEO_AMVIDEO, O_RDWR );
+ if ( mFdAmVideo < 0 ) {
+ LOGE ( "mFdAmVideo < 0, error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
+ /*Register events*/
+ AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AV_NO_DATA, av_evt_callback, this );
+ AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AV_DATA_RESUME, av_evt_callback, this );
+ AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_VIDEO_SCAMBLED, av_evt_callback, this );
+ AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_AUDIO_SCAMBLED, av_evt_callback, this );
+ AM_EVT_Subscribe ( mTvPlayDevId, AM_AV_EVT_VIDEO_NOT_SUPPORT, av_evt_callback, this );
+
+ return rt;
}
int CAv::Close()
{
- int iRet;
- iRet = AM_AV_Close ( mTvPlayDevId );
- iRet = AM_AOUT_Close ( mTvPlayDevId );
- if (mFdAmVideo > 0) {
- close(mFdAmVideo);
- mFdAmVideo = -1;
- }
- return iRet;
+ int iRet;
+ iRet = AM_AV_Close ( mTvPlayDevId );
+ iRet = AM_AOUT_Close ( mTvPlayDevId );
+ if (mFdAmVideo > 0) {
+ close(mFdAmVideo);
+ mFdAmVideo = -1;
+ }
+ return iRet;
}
int CAv::GetVideoStatus(AM_AV_VideoStatus_t *status)
{
- return AM_AV_GetVideoStatus(mTvPlayDevId, status);
+ return AM_AV_GetVideoStatus(mTvPlayDevId, status);
}
int CAv::SwitchTSAudio(int apid, AM_AV_AFormat_t afmt)
{
- return AM_AV_SwitchTSAudio (mTvPlayDevId, ( uint16_t ) apid, ( AM_AV_AFormat_t ) afmt );
+ return AM_AV_SwitchTSAudio (mTvPlayDevId, ( uint16_t ) apid, ( AM_AV_AFormat_t ) afmt );
}
int CAv::ResetAudioDecoder()
{
- return AM_AV_ResetAudioDecoder ( mTvPlayDevId );
+ return AM_AV_ResetAudioDecoder ( mTvPlayDevId );
}
int CAv::SetTSSource(AM_AV_TSSource_t ts_source)
{
- return AM_AV_SetTSSource ( mTvPlayDevId, ts_source );
+ return AM_AV_SetTSSource ( mTvPlayDevId, ts_source );
}
int CAv::StartTS(uint16_t vpid, uint16_t apid, AM_AV_VFormat_t vfmt, AM_AV_AFormat_t afmt)
{
- return AM_AV_StartTS ( mTvPlayDevId, vpid, apid, ( AM_AV_VFormat_t ) vfmt, ( AM_AV_AFormat_t ) afmt );
+ return AM_AV_StartTS ( mTvPlayDevId, vpid, apid, ( AM_AV_VFormat_t ) vfmt, ( AM_AV_AFormat_t ) afmt );
}
int CAv::StopTS()
{
- return AM_AV_StopTS (mTvPlayDevId);
+ return AM_AV_StopTS (mTvPlayDevId);
}
int CAv::AudioGetOutputMode(AM_AOUT_OutputMode_t *mode)
{
- return AM_AOUT_GetOutputMode ( 0, mode );
+ return AM_AOUT_GetOutputMode ( 0, mode );
}
int CAv::AudioSetOutputMode(AM_AOUT_OutputMode_t mode)
{
- return AM_AOUT_SetOutputMode ( 0, mode );
+ return AM_AOUT_SetOutputMode ( 0, mode );
}
int CAv::EnableVideoBlackout()
{
- return AM_AV_EnableVideoBlackout(mTvPlayDevId);
+ return AM_AV_EnableVideoBlackout(mTvPlayDevId);
}
int CAv::DisableVideoBlackout()
{
- return AM_AV_DisableVideoBlackout(mTvPlayDevId);
+ return AM_AV_DisableVideoBlackout(mTvPlayDevId);
}
int CAv::DisableVideoWithBlueColor()
{
- LOGD("DisableVideoWithBlueColor");
- if (mCurVideoLayerMuteState == 1 && mCurDisableVideoColor == DISABLE_VIDEO_COLOR_BLUE) {
- LOGD("video is disable with blue, return");
- return 0;
- }
- mCurVideoLayerMuteState = 1;
- mCurDisableVideoColor = DISABLE_VIDEO_COLOR_BLUE;
- SetVideoScreenColor ( 0, 41, 240, 110 ); // Show blue with vdin0, postblending disabled
- return AM_AV_DisableVideo(mTvPlayDevId);
+ LOGD("DisableVideoWithBlueColor");
+ if (mCurVideoLayerMuteState == 1 && mCurDisableVideoColor == DISABLE_VIDEO_COLOR_BLUE) {
+ LOGD("video is disable with blue, return");
+ return 0;
+ }
+ mCurVideoLayerMuteState = 1;
+ mCurDisableVideoColor = DISABLE_VIDEO_COLOR_BLUE;
+ SetVideoScreenColor ( 0, 41, 240, 110 ); // Show blue with vdin0, postblending disabled
+ return AM_AV_DisableVideo(mTvPlayDevId);
}
int CAv::DisableVideoWithBlackColor()
{
- LOGD("DisableVideoWithBlackColor");
- if (mCurVideoLayerMuteState == 1 && mCurDisableVideoColor == DISABLE_VIDEO_COLOR_BLACK) {
- LOGD("video is disable with black, return");
- return 0;
- }
- mCurDisableVideoColor = DISABLE_VIDEO_COLOR_BLACK;
- mCurVideoLayerMuteState = 1;
- SetVideoScreenColor ( 0, 16, 128, 128 ); // Show blue with vdin0, postblending disabled
- return AM_AV_DisableVideo(mTvPlayDevId);
+ LOGD("DisableVideoWithBlackColor");
+ if (mCurVideoLayerMuteState == 1 && mCurDisableVideoColor == DISABLE_VIDEO_COLOR_BLACK) {
+ LOGD("video is disable with black, return");
+ return 0;
+ }
+ mCurDisableVideoColor = DISABLE_VIDEO_COLOR_BLACK;
+ mCurVideoLayerMuteState = 1;
+ SetVideoScreenColor ( 0, 16, 128, 128 ); // Show blue with vdin0, postblending disabled
+ return AM_AV_DisableVideo(mTvPlayDevId);
}
//auto enable,
int CAv::EnableVideoAuto()
{
- LOGD("EnableVideo");
- if (mCurVideoLayerMuteState == 0) {
- LOGD("video is enable, return");
- return 0;
- }
- mCurVideoLayerMuteState = 0;
- SetVideoScreenColor ( 0, 16, 128, 128 ); // Show black with vdin0, postblending disabled
- ClearVideoBuffer();//disable video 2
- return 0;
+ LOGD("EnableVideo");
+ if (mCurVideoLayerMuteState == 0) {
+ LOGD("video is enable, return");
+ return 0;
+ }
+ mCurVideoLayerMuteState = 0;
+ SetVideoScreenColor ( 0, 16, 128, 128 ); // Show black with vdin0, postblending disabled
+ ClearVideoBuffer();//disable video 2
+ return 0;
}
//just enable video
int CAv::EnableVideoNow()
{
- LOGD("EnableVideoNow");
- const char *config_value = NULL;
- if (mCurVideoLayerMuteState == 0) {
- LOGD("video is enable, return");
- return 0;
- }
- mCurVideoLayerMuteState = 0;
- config_value = config_get_str ( CFG_SECTION_TV, CFG_BLUE_SCREEN_COLOR, "null" );
- if ( strcmp ( config_value, "black" ) == 0 ) {
- } else {
- SetVideoScreenColor ( 0, 16, 128, 128 ); // Show blue with vdin0, postblending disabled
- }
- return AM_AV_EnableVideo(mTvPlayDevId);
+ LOGD("EnableVideoNow");
+ const char *config_value = NULL;
+ if (mCurVideoLayerMuteState == 0) {
+ LOGD("video is enable, return");
+ return 0;
+ }
+ mCurVideoLayerMuteState = 0;
+ config_value = config_get_str ( CFG_SECTION_TV, CFG_BLUE_SCREEN_COLOR, "null" );
+ if ( strcmp ( config_value, "black" ) == 0 ) {
+ } else {
+ SetVideoScreenColor ( 0, 16, 128, 128 ); // Show blue with vdin0, postblending disabled
+ }
+ return AM_AV_EnableVideo(mTvPlayDevId);
}
int CAv::WaittingVideoPlaying(int minFrameCount , int waitTime )
{
- //EnableVideoNow();
- static const int COUNT_FOR_TIME = 20;
- int times = waitTime / COUNT_FOR_TIME;
- int ret = -1;
- int i = 0;
- for (i = 0; i < times; i++) {
- if (videoIsPlaying(minFrameCount)) {
- ret = 0;
- break;
- }
- }
- if (i == times) {
- LOGD("EnableVideoWhenVideoPlaying time out!!!!!!!!!!!!!");
- ret = -2;
- }
- return ret;
+ //EnableVideoNow();
+ static const int COUNT_FOR_TIME = 20;
+ int times = waitTime / COUNT_FOR_TIME;
+ int ret = -1;
+ int i = 0;
+ for (i = 0; i < times; i++) {
+ if (videoIsPlaying(minFrameCount)) {
+ ret = 0;
+ break;
+ }
+ }
+ if (i == times) {
+ LOGD("EnableVideoWhenVideoPlaying time out!!!!!!!!!!!!!");
+ ret = -2;
+ }
+ return ret;
}
int CAv::EnableVideoWhenVideoPlaying(int minFrameCount, int waitTime)
{
- int ret = WaittingVideoPlaying(minFrameCount, waitTime);
- if (ret == 0) { //ok to playing
- EnableVideoNow();
- }
- return ret;
+ int ret = WaittingVideoPlaying(minFrameCount, waitTime);
+ if (ret == 0) { //ok to playing
+ EnableVideoNow();
+ }
+ return ret;
}
bool CAv::videoIsPlaying(int minFrameCount)
{
- int value[3];
- value[0] = getVideoFrameCount();
- usleep(20 * 1000);
- value[1] = getVideoFrameCount();
- //usleep(20*1000);
- //value[2] = getVideoFrameCount();
- LOGD("---videoIsPlaying framecount =%d = %d = %d", value[0], value[1], value[2]);
- if (value[1] >= minFrameCount && (value[1] > value[0])) return true;
- else return false;
+ int value[3];
+ value[0] = getVideoFrameCount();
+ usleep(20 * 1000);
+ value[1] = getVideoFrameCount();
+ //usleep(20*1000);
+ //value[2] = getVideoFrameCount();
+ LOGD("---videoIsPlaying framecount =%d = %d = %d", value[0], value[1], value[2]);
+ if (value[1] >= minFrameCount && (value[1] > value[0])) return true;
+ else return false;
}
int CAv::getVideoFrameCount()
{
- char buf[32];
- int fd = -1;
- fd = open(PATH_FRAME_COUNT, O_RDWR);
- if (fd < 0) {
- LOGW("Open %s error(%s)!\n", PATH_FRAME_COUNT, strerror(errno));
- return -1;
- }
- read(fd, buf, sizeof(buf));
- int value = 0;
- sscanf ( buf, "%d", &value );
- close ( fd );
- return value;
+ char buf[32];
+ int fd = -1;
+ fd = open(PATH_FRAME_COUNT, O_RDWR);
+ if (fd < 0) {
+ LOGW("Open %s error(%s)!\n", PATH_FRAME_COUNT, strerror(errno));
+ return -1;
+ }
+ read(fd, buf, sizeof(buf));
+ int value = 0;
+ sscanf ( buf, "%d", &value );
+ close ( fd );
+ return value;
}
tvin_sig_fmt_t CAv::getVideoResolutionToFmt()
{
- tvin_sig_fmt_e sig_fmt = TVIN_SIG_FMT_HDMI_1920X1080P_60HZ;
- int height = CFile::getFileAttrValue(PATH_VIDEO_HEIGHT);
- LOGD("---------getVideoResolutionToFmt -------- height = %d", height);
- if (height <= 576) {
- sig_fmt = TVIN_SIG_FMT_HDMI_720X480P_60HZ;
- } else if (height >576 && height <= 1088) {
- sig_fmt = TVIN_SIG_FMT_HDMI_1920X1080P_60HZ;
- } else {
- sig_fmt = TVIN_SIG_FMT_HDMI_3840_2160_00HZ;
- }
- return sig_fmt;
+ tvin_sig_fmt_e sig_fmt = TVIN_SIG_FMT_HDMI_1920X1080P_60HZ;
+ int height = CFile::getFileAttrValue(PATH_VIDEO_HEIGHT);
+ LOGD("---------getVideoResolutionToFmt -------- height = %d", height);
+ if (height <= 576) {
+ sig_fmt = TVIN_SIG_FMT_HDMI_720X480P_60HZ;
+ } else if (height > 576 && height <= 1088) {
+ sig_fmt = TVIN_SIG_FMT_HDMI_1920X1080P_60HZ;
+ } else {
+ sig_fmt = TVIN_SIG_FMT_HDMI_3840_2160_00HZ;
+ }
+ return sig_fmt;
}
//call disable video 2
int CAv::ClearVideoBuffer()
{
- LOGD("ClearVideoBuffer");
- return AM_AV_ClearVideoBuffer(mTvPlayDevId);
+ LOGD("ClearVideoBuffer");
+ return AM_AV_ClearVideoBuffer(mTvPlayDevId);
}
int CAv::SetVideoScreenColor ( int vdin_blending_mask, int y, int u, int v )
{
- FILE *fp = NULL;
- unsigned long value = 0;
+ FILE *fp = NULL;
+ unsigned long value = 0;
- value = vdin_blending_mask << 24;
+ value = vdin_blending_mask << 24;
- value |= ( unsigned int ) ( y << 16 ) | ( unsigned int ) ( u << 8 ) | ( unsigned int ) ( v );
+ value |= ( unsigned int ) ( y << 16 ) | ( unsigned int ) ( u << 8 ) | ( unsigned int ) ( v );
- fp = fopen ( "/sys/class/video/test_screen", "w" );
- LOGD ( "~~~fopen~~~##VPP_SetVideoScreenColor##%s : vdin_blending_mask:%d,y:%d,u:%d,v:%d ##" , "/sys/class/video/test_screen", vdin_blending_mask, y, u, v);
+ fp = fopen ( "/sys/class/video/test_screen", "w" );
+ LOGD ( "~~~fopen~~~##VPP_SetVideoScreenColor##%s : vdin_blending_mask:%d,y:%d,u:%d,v:%d ##" , "/sys/class/video/test_screen", vdin_blending_mask, y, u, v);
- if ( fp == NULL ) {
- LOGE ( "Open /sys/class/video/test_screen error(%s)!\n", strerror ( errno ) );
- return -1;
- }
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/test_screen error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
- fprintf ( fp, "0x%lx", ( unsigned long ) value );
+ fprintf ( fp, "0x%lx", ( unsigned long ) value );
- fclose ( fp );
- fp = NULL;
+ fclose ( fp );
+ fp = NULL;
- return 0;
+ return 0;
}
int CAv::getVideoDisableValue()
{
- LOGD("this fun is empty!!!!!!!!");
- return 0;
+ LOGD("this fun is empty!!!!!!!!");
+ return 0;
}
int CAv::SetVideoLayerDisable ( int value )
{
- FILE *fp = NULL;
+ FILE *fp = NULL;
- fp = fopen ( "/sys/class/video/disable_video", "w" );
- LOGD ( "~~~fopen~~~##VPP_SetVideoLayerDisable##%s : %d ##" , "/sys/class/video/disable_video", value);
+ fp = fopen ( "/sys/class/video/disable_video", "w" );
+ LOGD ( "~~~fopen~~~##VPP_SetVideoLayerDisable##%s : %d ##" , "/sys/class/video/disable_video", value);
- if ( fp == NULL ) {
- LOGE ( "Open /sys/class/video/disable_video error(%s)!\n", strerror ( errno ) );
- return -1;
- }
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/disable_video error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
- fprintf ( fp, "%d", value );
+ fprintf ( fp, "%d", value );
- fclose ( fp );
- fp = NULL;
+ fclose ( fp );
+ fp = NULL;
- return 0;
+ return 0;
}
int CAv::setVideoScreenMode ( int value )
{
- FILE *fp = fopen ( "/sys/class/video/screen_mode", "w" );
- LOGD ( "setVideoScreenMode %d ##" , value);
- if ( fp == NULL ) {
- LOGE ( "Open /sys/class/video/screen_mode error(%s)!\n", strerror ( errno ) );
- return -1;
- }
- fprintf ( fp, "%d", value );
- fclose ( fp );
- return 0;
+ FILE *fp = fopen ( "/sys/class/video/screen_mode", "w" );
+ LOGD ( "setVideoScreenMode %d ##" , value);
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/screen_mode error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
+ fprintf ( fp, "%d", value );
+ fclose ( fp );
+ return 0;
}
int CAv::setVideoAxis ( int h, int v, int width, int height )
{
- FILE *fp = NULL;
- fp = fopen ( "/sys/class/video/axis", "w" );
- LOGD ( "setVideoAxis##%s : %d %d %d %d ##" , "/sys/class/video/axis", h, v, width, height);
+ FILE *fp = NULL;
+ fp = fopen ( "/sys/class/video/axis", "w" );
+ LOGD ( "setVideoAxis##%s : %d %d %d %d ##" , "/sys/class/video/axis", h, v, width, height);
- if ( fp == NULL ) {
- LOGE ( "Open /sys/class/video/axis ERROR(%s)!!\n", strerror ( errno ) );
- return -1;
- }
- fprintf ( fp, "%d %d %d %d", h, v, width, height );
- fclose ( fp );
- return 0;
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/axis ERROR(%s)!!\n", strerror ( errno ) );
+ return -1;
+ }
+ fprintf ( fp, "%d %d %d %d", h, v, width, height );
+ fclose ( fp );
+ return 0;
}
int CAv::getVideoScreenMode()
{
- int value;
- FILE *fp = fopen ( "/sys/class/video/screen_mode", "r+" );
+ int value;
+ FILE *fp = fopen ( "/sys/class/video/screen_mode", "r+" );
- if ( fp == NULL ) {
- LOGE ( "Open /sys/class/video/screen_mode error(%s)!\n", strerror ( errno ) );
- return -1;
- }
- fscanf ( fp, "%d", &value );
- fclose ( fp );
- return value;
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/screen_mode error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
+ fscanf ( fp, "%d", &value );
+ fclose ( fp );
+ return value;
}
video_display_resolution_t CAv::getVideoDisplayResolution()
{
- char attrV[64];
- memset (attrV, 0x0, 64);
- Tv_Utils_GetFileAttrStr ( "/sys/class/video/device_resolution", 64, attrV );
- video_display_resolution_t resolution;
- if (strncasecmp(attrV, "1366x768", strlen ("1366x768")) == 0) {
- resolution = VPP_DISPLAY_RESOLUTION_1366X768;
- } else if (strncasecmp(attrV, "3840x2160", strlen ("3840x2160")) == 0) {
- resolution = VPP_DISPLAY_RESOLUTION_3840X2160;
- } else if (strncasecmp(attrV, "1920x1080", strlen ("1920x1080")) == 0) {
- resolution = VPP_DISPLAY_RESOLUTION_1920X1080;
- } else {
- LOGW("video display resolution is = (%s) not define , default it", attrV);
- resolution = VPP_DISPLAY_RESOLUTION_1920X1080;
- }
+ char attrV[64];
+ memset (attrV, 0x0, 64);
+ Tv_Utils_GetFileAttrStr ( "/sys/class/video/device_resolution", 64, attrV );
+ video_display_resolution_t resolution;
+ if (strncasecmp(attrV, "1366x768", strlen ("1366x768")) == 0) {
+ resolution = VPP_DISPLAY_RESOLUTION_1366X768;
+ } else if (strncasecmp(attrV, "3840x2160", strlen ("3840x2160")) == 0) {
+ resolution = VPP_DISPLAY_RESOLUTION_3840X2160;
+ } else if (strncasecmp(attrV, "1920x1080", strlen ("1920x1080")) == 0) {
+ resolution = VPP_DISPLAY_RESOLUTION_1920X1080;
+ } else {
+ LOGW("video display resolution is = (%s) not define , default it", attrV);
+ resolution = VPP_DISPLAY_RESOLUTION_1920X1080;
+ }
- return resolution;
+ return resolution;
}
void CAv::av_evt_callback ( long dev_no, int event_type, void *param, void *user_data )
{
- CAv *pAv = ( CAv * ) user_data;
- if (NULL == pAv ) {
- LOGD ( "%s, ERROR : av_evt_callback NULL == pTv\n", __FUNCTION__ );
- return ;
- }
- if ( pAv->mpObserver == NULL ) {
- LOGD ( "%s, ERROR : mpObserver NULL == mpObserver\n", __FUNCTION__ );
- return;
- }
- switch ( event_type ) {
- case AM_AV_EVT_AV_NO_DATA:
- pAv->mCurAvEvent.type = AVEvent::EVENT_AV_STOP;
- pAv->mCurAvEvent.param = ( int )param;
- pAv->mpObserver->onEvent(pAv->mCurAvEvent);
- break;
- case AM_AV_EVT_AV_DATA_RESUME:
- pAv->mCurAvEvent.type = AVEvent::EVENT_AV_RESUEM;
- pAv->mCurAvEvent.param = ( int )param;
- pAv->mpObserver->onEvent(pAv->mCurAvEvent);
- break;
- case AM_AV_EVT_VIDEO_SCAMBLED:
- case AM_AV_EVT_AUDIO_SCAMBLED:
- pAv->mCurAvEvent.type = AVEvent::EVENT_AV_SCAMBLED;
- pAv->mCurAvEvent.param = ( int )param;
- pAv->mpObserver->onEvent(pAv->mCurAvEvent);
- break;
- case AM_AV_EVT_VIDEO_NOT_SUPPORT: {
- pAv->mCurAvEvent.type = AVEvent::EVENT_AV_UNSUPPORT;
- pAv->mCurAvEvent.param = ( int )param;
- pAv->mpObserver->onEvent(pAv->mCurAvEvent);
- break;
- }
- default:
- break;
- }
- LOGD ( "%s, av_evt_callback : dev_no %d type %d param = %d\n", __FUNCTION__, dev_no, pAv->mCurAvEvent.type , (int)param);
+ CAv *pAv = ( CAv * ) user_data;
+ if (NULL == pAv ) {
+ LOGD ( "%s, ERROR : av_evt_callback NULL == pTv\n", __FUNCTION__ );
+ return ;
+ }
+ if ( pAv->mpObserver == NULL ) {
+ LOGD ( "%s, ERROR : mpObserver NULL == mpObserver\n", __FUNCTION__ );
+ return;
+ }
+ switch ( event_type ) {
+ case AM_AV_EVT_AV_NO_DATA:
+ pAv->mCurAvEvent.type = AVEvent::EVENT_AV_STOP;
+ pAv->mCurAvEvent.param = ( int )param;
+ pAv->mpObserver->onEvent(pAv->mCurAvEvent);
+ break;
+ case AM_AV_EVT_AV_DATA_RESUME:
+ pAv->mCurAvEvent.type = AVEvent::EVENT_AV_RESUEM;
+ pAv->mCurAvEvent.param = ( int )param;
+ pAv->mpObserver->onEvent(pAv->mCurAvEvent);
+ break;
+ case AM_AV_EVT_VIDEO_SCAMBLED:
+ case AM_AV_EVT_AUDIO_SCAMBLED:
+ pAv->mCurAvEvent.type = AVEvent::EVENT_AV_SCAMBLED;
+ pAv->mCurAvEvent.param = ( int )param;
+ pAv->mpObserver->onEvent(pAv->mCurAvEvent);
+ break;
+ case AM_AV_EVT_VIDEO_NOT_SUPPORT: {
+ pAv->mCurAvEvent.type = AVEvent::EVENT_AV_UNSUPPORT;
+ pAv->mCurAvEvent.param = ( int )param;
+ pAv->mpObserver->onEvent(pAv->mCurAvEvent);
+ break;
+ }
+ default:
+ break;
+ }
+ LOGD ( "%s, av_evt_callback : dev_no %d type %d param = %d\n", __FUNCTION__, dev_no, pAv->mCurAvEvent.type , (int)param);
}
int CAv::set3DMode(VIDEO_3D_MODE_T mode, int LR_switch, int mode_3D_TO_2D)
{
- unsigned int cmd = MODE_3D_DISABLE;
- switch (mode) {
- case VIDEO_3D_MODE_DISABLE:
- cmd = MODE_3D_DISABLE;
- break;
- case VIDEO_3D_MODE_AUTO:
- cmd = MODE_3D_ENABLE | MODE_3D_AUTO;
- break;
- case VIDEO_3D_MODE_LR:
- cmd = MODE_3D_ENABLE | MODE_3D_LR;
- break;
- case VIDEO_3D_MODE_TB:
- cmd = MODE_3D_ENABLE | MODE_3D_TB;
- break;
- case VIDEO_3D_MODE_LA:
- cmd = MODE_3D_ENABLE | MODE_3D_LA;
- break;
- case VIDEO_3D_MODE_FA:
- cmd = MODE_3D_ENABLE | MODE_3D_FA;
- break;
- default:
- cmd = MODE_3D_DISABLE;
- break;
- }
-
- if (LR_switch == 1) {
- cmd = cmd | MODE_3D_LR_SWITCH;
- }
-
- if (mode_3D_TO_2D == 1) {
- cmd = cmd | MODE_3D_TO_2D_L;
- }
-
- if (mode_3D_TO_2D == 2) {
- cmd = cmd | MODE_3D_TO_2D_R;
- }
- LOGD("set 3d mode fd = %d cmd = 0x%x", mFdAmVideo, cmd);
- int ret = ioctl(mFdAmVideo, AMSTREAM_IOC_SET_3D_TYPE , cmd);
- if (ret < 0) {
- LOGE("set3DMode error ( %s )", strerror ( errno ));
- }
- return 0;
+ unsigned int cmd = MODE_3D_DISABLE;
+ switch (mode) {
+ case VIDEO_3D_MODE_DISABLE:
+ cmd = MODE_3D_DISABLE;
+ break;
+ case VIDEO_3D_MODE_AUTO:
+ cmd = MODE_3D_ENABLE | MODE_3D_AUTO;
+ break;
+ case VIDEO_3D_MODE_LR:
+ cmd = MODE_3D_ENABLE | MODE_3D_LR;
+ break;
+ case VIDEO_3D_MODE_TB:
+ cmd = MODE_3D_ENABLE | MODE_3D_TB;
+ break;
+ case VIDEO_3D_MODE_LA:
+ cmd = MODE_3D_ENABLE | MODE_3D_LA;
+ break;
+ case VIDEO_3D_MODE_FA:
+ cmd = MODE_3D_ENABLE | MODE_3D_FA;
+ break;
+ default:
+ cmd = MODE_3D_DISABLE;
+ break;
+ }
+
+ if (LR_switch == 1) {
+ cmd = cmd | MODE_3D_LR_SWITCH;
+ }
+
+ if (mode_3D_TO_2D == 1) {
+ cmd = cmd | MODE_3D_TO_2D_L;
+ }
+
+ if (mode_3D_TO_2D == 2) {
+ cmd = cmd | MODE_3D_TO_2D_R;
+ }
+ LOGD("set 3d mode fd = %d cmd = 0x%x", mFdAmVideo, cmd);
+ int ret = ioctl(mFdAmVideo, AMSTREAM_IOC_SET_3D_TYPE , cmd);
+ if (ret < 0) {
+ LOGE("set3DMode error ( %s )", strerror ( errno ));
+ }
+ return 0;
}
int CAv::setLookupPtsForDtmb(int enable)
{
- FILE *fp = fopen ( PATH_MEPG_DTMB_LOOKUP_PTS_FLAG, "w" );
- LOGD ( "setLookupPtsForDtmb %d ##" , enable);
- if ( fp == NULL ) {
- LOGE ( "Open %s error(%s)!\n", PATH_MEPG_DTMB_LOOKUP_PTS_FLAG, strerror ( errno ) );
- return -1;
- }
- fprintf ( fp, "%d", enable );
- fclose ( fp );
- return 0;
+ FILE *fp = fopen ( PATH_MEPG_DTMB_LOOKUP_PTS_FLAG, "w" );
+ LOGD ( "setLookupPtsForDtmb %d ##" , enable);
+ if ( fp == NULL ) {
+ LOGE ( "Open %s error(%s)!\n", PATH_MEPG_DTMB_LOOKUP_PTS_FLAG, strerror ( errno ) );
+ return -1;
+ }
+ fprintf ( fp, "%d", enable );
+ fclose ( fp );
+ return 0;
}