summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk26
-rw-r--r--tv_input.cpp246
-rw-r--r--tvapi/Android.mk1
-rw-r--r--tvapi/android/Android.mk1
-rw-r--r--tvapi/android/include/ITv.h51
-rw-r--r--tvapi/android/include/ITvClient.h30
-rw-r--r--tvapi/android/include/ITvService.h35
-rw-r--r--tvapi/android/include/Tv.h82
-rw-r--r--tvapi/android/include/tvcmd.h594
-rw-r--r--tvapi/android/jni/Android.mk66
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp456
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp167
-rw-r--r--tvapi/android/jni/cfbc_test.cpp43
-rw-r--r--tvapi/android/libtvbinder/Android.mk24
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp145
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp59
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp51
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp189
-rw-r--r--tvapi/android/tvserver/Android.mk85
-rw-r--r--tvapi/android/tvserver/TvService.cpp4375
-rw-r--r--tvapi/android/tvserver/TvService.h83
-rw-r--r--tvapi/android/tvserver/main.cpp23
-rw-r--r--tvapi/build/include/.gitignore0
-rw-r--r--tvapi/build/include/xxxconfig.h1
-rw-r--r--tvapi/docs/TVMiddleware初期.wps252
-rw-r--r--tvapi/docs/tv.uml6093
-rw-r--r--tvapi/libtv/Android.mk224
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp1213
-rw-r--r--tvapi/libtv/audio/audio_alsa.h131
-rw-r--r--tvapi/libtv/audio/audio_android.cpp1035
-rw-r--r--tvapi/libtv/audio/audio_android.h79
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp591
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h66
-rw-r--r--tvapi/libtv/audio/audio_api.cpp2470
-rw-r--r--tvapi/libtv/audio/audio_api.h324
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp228
-rw-r--r--tvapi/libtv/audio/audio_effect.h32
-rw-r--r--tvapi/libtv/include/amstream.h263
-rw-r--r--tvapi/libtv/include/amvecm.h68
-rw-r--r--tvapi/libtv/include/cm.h153
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h331
-rw-r--r--tvapi/libtv/include/ve.h219
-rw-r--r--tvapi/libtv/projects/Android.mk1
-rw-r--r--tvapi/libtv/projects/haier_360_v1/CTvHaierDtmb360.cpp83
-rw-r--r--tvapi/libtv/projects/haier_360_v1/CTvHaierDtmb360.h18
-rw-r--r--tvapi/libtv/projects/haier_360_v1/haier_360_v1.h0
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/Android.mk48
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/CTvRefN300.cpp12
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/CTvRefN300.h8
-rw-r--r--tvapi/libtv/projects/ref_n300_v1/ref_n300_v1.h1
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/Android.mk48
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/CTvSkyworthDtmbN310.cpp88
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/CTvSkyworthDtmbN310.h18
-rw-r--r--tvapi/libtv/projects/skyworth_n310_v1/skyworth_n310_v1.h1
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp213
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h49
-rw-r--r--tvapi/libtv/tv/CAv.cpp381
-rw-r--r--tvapi/libtv/tv/CAv.h148
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp1700
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h382
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp568
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h160
-rw-r--r--tvapi/libtv/tv/CTv.cpp5385
-rw-r--r--tvapi/libtv/tv/CTv.h636
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp162
-rw-r--r--tvapi/libtv/tv/CTvBooking.h84
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp24
-rw-r--r--tvapi/libtv/tv/CTvDmx.h18
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp216
-rw-r--r--tvapi/libtv/tv/CTvEpg.h160
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp11
-rw-r--r--tvapi/libtv/tv/CTvEv.h192
-rw-r--r--tvapi/libtv/tv/CTvLog.cpp20
-rw-r--r--tvapi/libtv/tv/CTvLog.h35
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp276
-rw-r--r--tvapi/libtv/tv/CTvRecord.h47
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h22
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1146
-rw-r--r--tvapi/libtv/tv/CTvScanner.h183
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp530
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h177
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp348
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h236
-rw-r--r--tvapi/libtv/tv/CTvTime.cpp15
-rw-r--r--tvapi/libtv/tv/CTvTime.h102
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp161
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h50
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp556
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h143
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp353
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h73
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf30
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp53
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h20
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp347
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h288
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp259
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h96
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp644
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h99
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp241
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h86
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp44
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h31
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp883
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h536
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp183
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h43
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp654
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp312
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp3292
-rw-r--r--tvapi/libtv/tvin/CTvin.h1379
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp27
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h51
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp353
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h77
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp80
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h27
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp129
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h38
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2212
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h251
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h371
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp187
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h23
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1392
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h62
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp1853
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h169
-rw-r--r--tvapi/libtv/tvutils/CCondition.h91
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp191
-rw-r--r--tvapi/libtv/tvutils/CFile.h47
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp15
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h10
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp116
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h54
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h50
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp357
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h55
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp152
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h186
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp165
-rw-r--r--tvapi/libtv/tvutils/CThread.h62
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp156
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h39
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp466
-rw-r--r--tvapi/libtv/tvutils/serial_base.h17
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp229
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h36
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp1912
-rw-r--r--tvapi/libtv/tvutils/tvutils.h119
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp88
-rw-r--r--tvapi/libtv/tvutils/zepoll.h49
-rw-r--r--tvapi/libtv/version/version.cpp94
-rw-r--r--tvapi/libtv/version/version.h11
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp1535
-rw-r--r--tvapi/libtv/vpp/CPQdb.h161
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp3711
-rw-r--r--tvapi/libtv/vpp/CVpp.h438
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp143
-rw-r--r--tvapi/libtv/vpp/pqdata.h30
-rw-r--r--tvapi/script/setenv.sh54
-rw-r--r--tvapi/tvtests/Android.mk49
-rw-r--r--tvapi/tvtests/android_tvtest.cpp33
-rw-r--r--tvapi/tvtests/comm_test.cpp33
-rw-r--r--tvapi/tvtests/ssm_test.cpp210
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp427
169 files changed, 64432 insertions, 116 deletions
diff --git a/tvapi/libtv/tv/CAv.cpp b/tvapi/libtv/tv/CAv.cpp
new file mode 100644
index 0000000..7f757ca
--- a/dev/null
+++ b/tvapi/libtv/tv/CAv.cpp
@@ -0,0 +1,381 @@
+#include "CAv.h"
+#define LOG_TAG "CAv"
+#include "../tvutils/tvutils.h"
+#include <stdio.h>
+#include <unistd.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <sys/ioctl.h>
+#include <fcntl.h>
+#include <amstream.h>
+CAv::CAv()
+{
+ mpObserver = NULL;
+ mTvPlayDevId = 0;
+ mCurVideoLayerMuteState = -1;
+ mCurDisableVideoColor = -1;
+ mFdAmVideo = -1;
+}
+CAv::~CAv()
+{
+
+}
+int CAv::SetVideoWindow(int x, int y, int w, int 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;
+}
+
+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 CAv::GetVideoStatus(AM_AV_VideoStatus_t *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 );
+}
+
+int CAv::ResetAudioDecoder()
+{
+ return AM_AV_ResetAudioDecoder ( mTvPlayDevId );
+}
+
+int CAv::SetTSSource(AM_AV_TSSource_t 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 );
+}
+
+int CAv::StopTS()
+{
+ return AM_AV_StopTS (mTvPlayDevId);
+}
+
+int CAv::AudioGetOutputMode(AM_AOUT_OutputMode_t *mode)
+{
+ return AM_AOUT_GetOutputMode ( 0, mode );
+}
+
+int CAv::AudioSetOutputMode(AM_AOUT_OutputMode_t mode)
+{
+ return AM_AOUT_SetOutputMode ( 0, mode );
+}
+
+int CAv::EnableVideoBlackout()
+{
+ return AM_AV_EnableVideoBlackout(mTvPlayDevId);
+}
+
+int CAv::DisableVideoBlackout()
+{
+ 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);
+}
+
+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);
+}
+//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
+ return ClearVideoBuffer();//disable video 2
+}
+
+//just enable video
+int CAv::EnableVideoNow()
+{
+ LOGD("EnableVideoNow");
+ if (mCurVideoLayerMuteState == 0) {
+ LOGD("video is enable, return");
+ return 0;
+ }
+ mCurVideoLayerMuteState = 0;
+ SetVideoScreenColor ( 3, 16, 128, 128 ); // Show blue with vdin0, postblending disabled
+ return AM_AV_EnableVideo(mTvPlayDevId);
+}
+
+//call disable video 2
+int CAv::ClearVideoBuffer()
+{
+ 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;
+
+ value = vdin_blending_mask << 24;
+
+ 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);
+
+
+ if ( fp == NULL ) {
+ LOGE ( "Open /sys/class/video/test_screen error(%s)!\n", strerror ( errno ) );
+ return -1;
+ }
+
+ fprintf ( fp, "0x%lx", ( unsigned long ) value );
+
+ fclose ( fp );
+ fp = NULL;
+
+ return 0;
+}
+
+int CAv::getVideoDisableValue()
+{
+ LOGD("this fun is empty!!!!!!!!");
+ return 0;
+}
+
+int CAv::SetVideoLayerDisable ( int value )
+{
+ FILE *fp = NULL;
+
+ 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;
+ }
+
+ fprintf ( fp, "%d", value );
+
+ fclose ( fp );
+ fp = NULL;
+
+ 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;
+}
+
+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);
+
+ 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+" );
+
+ 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;
+ }
+
+ return resolution;
+}
+
+void CAv::av_evt_callback ( int 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);
+}
+
+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;
+}