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/CTvEpg.cpp b/tvapi/libtv/tv/CTvEpg.cpp
new file mode 100644
index 0000000..9140eac
--- a/dev/null
+++ b/tvapi/libtv/tv/CTvEpg.cpp
@@ -0,0 +1,216 @@
+/*
+ * amlogic 2013
+ *@ Project : tv
+ *@ Date : 2013-12
+ *@ Author :
+*/
+#include "CTvEpg.h"
+#include "CTvChannel.h"
+#ifdef LOG_TAG
+#undef LOG_TAG
+#define LOG_TAG "CTvEpg"
+#endif
+
+void CTvEpg::epg_evt_callback(int dev_no, int event_type, void *param, void *user_data)
+{
+ CTvEpg *pEpg;
+
+ AM_EPG_GetUserData(dev_no, (void **)&pEpg);
+
+ if (pEpg == NULL) return;
+
+ if (pEpg->mpObserver == NULL) {
+ return;
+ }
+ switch (event_type) {
+ case AM_EPG_EVT_NEW_TDT:
+ case AM_EPG_EVT_NEW_STT: {
+ int utc_time;
+ AM_EPG_GetUTCTime(&utc_time);
+ pEpg->mCurEpgEv.type = EpgEvent::EVENT_TDT_END;
+ pEpg->mCurEpgEv.time = (long)utc_time;
+ pEpg->mpObserver->onEvent(pEpg->mCurEpgEv);
+ }
+ break;
+ case AM_EPG_EVT_UPDATE_EVENTS:
+ pEpg->mCurEpgEv.type = EpgEvent::EVENT_PROGRAM_EVENTS_UPDATE;
+ pEpg->mCurEpgEv.programID = (int)param;
+ pEpg->mpObserver->onEvent(pEpg->mCurEpgEv);
+ break;
+ case AM_EPG_EVT_UPDATE_PROGRAM_AV:
+ pEpg->mCurEpgEv.type = EpgEvent::EVENT_PROGRAM_AV_UPDATE;
+ pEpg->mCurEpgEv.programID = (int)param;
+ pEpg->mpObserver->onEvent(pEpg->mCurEpgEv);
+ break;
+ case AM_EPG_EVT_UPDATE_PROGRAM_NAME:
+ pEpg->mCurEpgEv.type = EpgEvent::EVENT_PROGRAM_NAME_UPDATE;
+ pEpg->mCurEpgEv.programID = (int)param;
+ pEpg->mpObserver->onEvent(pEpg->mCurEpgEv);
+ break;
+ case AM_EPG_EVT_UPDATE_TS:
+ pEpg->mCurEpgEv.type = EpgEvent::EVENT_CHANNEL_UPDATE;
+ pEpg->mCurEpgEv.channelID = (int)param;
+ pEpg->mpObserver->onEvent(pEpg->mCurEpgEv);
+ break;
+ default:
+ break;
+ }
+}
+
+void CTvEpg::Init(int fend, int dmx, int fend_mod, char *textLanguages, char *dvb_text_coding)
+{
+ mFend_dev_id = fend;
+ mDmx_dev_id = dmx;
+ mFend_mod = fend_mod;
+ epg_create(fend, dmx, fend_mod, textLanguages);
+ epg_set_dvb_text_coding(dvb_text_coding);
+}
+
+void CTvEpg::epg_create(int fend_id, int dmx_id, int src, char *textLangs)
+{
+ AM_EPG_CreatePara_t para;
+ AM_ErrorCode_t ret;
+ AM_FEND_OpenPara_t fend_para;
+ AM_DMX_OpenPara_t dmx_para;
+
+ LOGD("Opening demux%d ...", dmx_id);
+ memset(&dmx_para, 0, sizeof(dmx_para));
+ AM_DMX_Open(dmx_id, &dmx_para);
+
+ para.fend_dev = fend_id;
+ para.dmx_dev = dmx_id;
+ para.source = src;
+ para.hdb = NULL;
+
+
+ snprintf(para.text_langs, sizeof(para.text_langs), "%s", textLangs);
+
+
+ ret = AM_EPG_Create(&para, &mEpgScanHandle);
+ if (ret != AM_SUCCESS) {
+ LOGD("AM_EPG_Create failed");
+ return;
+ }
+
+ /*注册EIT通知事件*/
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_NEW_TDT, epg_evt_callback, NULL);
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_NEW_STT, epg_evt_callback, NULL);
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_EVENTS, epg_evt_callback, NULL);
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_PROGRAM_AV, epg_evt_callback, NULL);
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_PROGRAM_NAME, epg_evt_callback, NULL);
+ AM_EVT_Subscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_TS, epg_evt_callback, NULL);
+ AM_EPG_SetUserData(mEpgScanHandle, (void *)this);
+}
+
+
+
+void CTvEpg::epg_destroy()
+{
+ /*反注册EIT通知事件*/
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_NEW_TDT, epg_evt_callback, NULL);
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_NEW_STT, epg_evt_callback, NULL);
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_EVENTS, epg_evt_callback, NULL);
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_PROGRAM_AV, epg_evt_callback, NULL);
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_PROGRAM_NAME, epg_evt_callback, NULL);
+ AM_EVT_Unsubscribe(mEpgScanHandle, AM_EPG_EVT_UPDATE_TS, epg_evt_callback, NULL);
+ AM_EPG_Destroy(mEpgScanHandle);
+ AM_DMX_Close(mDmx_dev_id);
+}
+
+
+void CTvEpg::epg_change_mode(int op, int mode)
+{
+ AM_ErrorCode_t ret;
+ ret = AM_EPG_ChangeMode(mEpgScanHandle, op, mode);
+ if (ret != AM_SUCCESS)
+ LOGD("AM_EPG_ChangeMode failed");
+}
+
+
+
+void CTvEpg::epg_monitor_service(int srv_id)
+{
+ int ret = AM_EPG_MonitorService(mEpgScanHandle, srv_id);
+ if (ret != AM_SUCCESS)
+ LOGD("AM_EPG_MonitorService failed");
+}
+
+
+
+void CTvEpg::epg_set_dvb_text_coding(char *coding)
+{
+ if (!strcmp(coding, "standard")) {
+ AM_SI_SetDefaultDVBTextCoding("");
+ } else {
+ AM_SI_SetDefaultDVBTextCoding(coding);
+ }
+}
+
+
+
+/*Start scan the sections.*/
+void CTvEpg::startScan(int mode)
+{
+ epg_change_mode(MODE_ADD, mode);
+}
+
+/*Stop scan the sections.*/
+void CTvEpg::stopScan(int mode)
+{
+ epg_change_mode(MODE_REMOVE, mode);
+}
+
+
+/*Enter a channel.*/
+void CTvEpg::enterChannel(int chan_id)
+{
+
+ if (chan_id == mCurScanChannelId)
+ return;
+ //already enter,leave it
+ if (mCurScanChannelId != INVALID_ID) {
+ leaveChannel();
+ }
+
+ if (mFend_mod == CTvChannel::MODE_ATSC) {
+ startScan(SCAN_PSIP_ETT | SCAN_PSIP_EIT | SCAN_MGT | SCAN_VCT | SCAN_RRT | SCAN_STT);
+ } else {
+ startScan(SCAN_EIT_ALL | SCAN_SDT | SCAN_NIT | SCAN_TDT | SCAN_CAT);
+ }
+
+ mCurScanChannelId = chan_id;
+}
+
+/*Leave the channel.*/
+void CTvEpg::leaveChannel()
+{
+
+ stopScan(SCAN_ALL);
+ mCurScanChannelId = INVALID_ID;
+}
+
+/*Enter the program.*/
+void CTvEpg::enterProgram(int prog_id)
+{
+ if (prog_id == mCurScanProgramId)
+ return;
+
+ if (mCurScanProgramId != INVALID_ID) {
+ leaveProgram();
+ }
+
+ mCurScanProgramId = prog_id;
+ epg_monitor_service(mCurScanProgramId);//---------db_id
+ startScan(SCAN_PAT | SCAN_PMT);
+}
+
+/*Leave the program.*/
+void CTvEpg::leaveProgram()
+{
+ if (mCurScanProgramId == INVALID_ID)
+ return;
+
+ stopScan(SCAN_PAT | SCAN_PMT);
+ epg_monitor_service(-1);
+ mCurScanProgramId = INVALID_ID;
+}