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/CTvSubtitle.cpp b/tvapi/libtv/tv/CTvSubtitle.cpp
new file mode 100644
index 0000000..fe24ea0
--- a/dev/null
+++ b/tvapi/libtv/tv/CTvSubtitle.cpp
@@ -0,0 +1,348 @@
+//
+//
+// amlogic 2013
+//
+// @ Project : tv
+// @ Date : 2013-11
+// @ Author :
+//
+//
+#include "CTvSubtitle.h"
+CTvSubtitle::CTvSubtitle()
+{
+ mpObser = NULL;
+}
+CTvSubtitle::~CTvSubtitle()
+{
+}
+void CTvSubtitle::setObser(IObserver *pObser)
+{
+ mpObser = pObser;
+}
+void CTvSubtitle::stopDecoder()
+{
+}
+/**
+ * 开始字幕信息解析showboz sync
+ */
+void CTvSubtitle::startSub()
+{
+}
+
+/**
+ * 停止图文/字幕信息解析
+ */
+void CTvSubtitle::stop()
+{
+}
+
+/**
+ * 停止图文/字幕信息解析并清除缓存数据
+ */
+void CTvSubtitle::clear()
+{
+
+}
+
+/**
+ * 在图文模式下进入下一页
+ */
+void CTvSubtitle::nextPage()
+{
+
+}
+
+/**
+ * 在图文模式下进入上一页
+ */
+void CTvSubtitle::previousPage()
+{
+
+}
+
+/**
+ * 在图文模式下跳转到指定页
+ * @param page 要跳转到的页号
+ */
+void CTvSubtitle::gotoPage(int page)
+{
+
+}
+
+/**
+ * 在图文模式下跳转到home页
+ */
+void CTvSubtitle::goHome()
+{
+
+}
+
+/**
+ * 在图文模式下根据颜色跳转到指定链接
+ * @param color 颜色,COLOR_RED/COLOR_GREEN/COLOR_YELLOW/COLOR_BLUE
+ */
+void CTvSubtitle::colorLink(int color)
+{
+
+}
+
+/**
+ * 在图文模式下设定搜索字符串
+ * @param pattern 搜索匹配字符串
+ * @param casefold 是否区分大小写
+ */
+void CTvSubtitle::setSearchPattern(char *pattern, bool casefold)
+{
+
+}
+
+/**
+ * 搜索下一页
+ */
+void CTvSubtitle::searchNext()
+{
+}
+
+/**
+ * 搜索上一页
+ */
+void CTvSubtitle::searchPrevious()
+{
+}
+
+int CTvSubtitle::sub_init()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_destroy()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_lock()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_unlock()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_clear()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_start_dvb_sub(int dmx_id, int pid, int page_id, int anc_page_id)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_start_dtv_tt(int dmx_id, int region_id, int pid, int page, int sub_page, bool is_sub)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_stop_dvb_sub()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_stop_dtv_tt()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_goto(int page)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_color_link(int color)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_home_link()
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_next(int dir)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_set_search_pattern(char *pattern, bool casefold)
+{
+ return 0;
+}
+
+int CTvSubtitle::sub_tt_search(int dir)
+{
+ return 0;
+}
+
+/*
+ * 1, Set the country first and parameters should be either USA or KOREA
+#define CMD_SET_COUNTRY_USA 0x5001
+#define CMD_SET_COUNTRY_KOREA 0x5002
+
+2, Set the source type which including
+ a)VBI data(for analog program only)
+ b)USER data(for AIR or Cable service)
+CMD_CC_SET_VBIDATA = 0x7001,
+CMD_CC_SET_USERDATA = 0x7002,
+2.1 If the frontend type is Analog we must set the channel Index
+ with command 'CMD_CC_SET_CHAN_NUM' and the parameter is like 57M
+ we set 0x20000, this should according to USA standard frequency
+ table.
+
+3, Next is to set the CC service type
+
+#define CMD_CC_1 0x3001
+#define CMD_CC_2 0x3002
+#define CMD_CC_3 0x3003
+#define CMD_CC_4 0x3004
+
+//this doesn't support currently
+#define CMD_TT_1 0x3005
+#define CMD_TT_2 0x3006
+#define CMD_TT_3 0x3007
+#define CMD_TT_4 0x3008
+
+#define CMD_SERVICE_1 0x4001
+#define CMD_SERVICE_2 0x4002
+#define CMD_SERVICE_3 0x4003
+#define CMD_SERVICE_4 0x4004
+#define CMD_SERVICE_5 0x4005
+#define CMD_SERVICE_6 0x4006
+
+4, Then set CMD_CC_START to start the CC service, and you needn't to stop
+
+CC service while switching services
+
+5, CMD_CC_STOP should be called in some cases like switch source, change
+
+program, no signal, blocked...*/
+
+//channel_num == 0 ,if frontend is dtv
+//else != 0
+int CTvSubtitle::sub_start_atsc_cc(enum cc_param_country country, enum cc_param_source_type src_type, int channel_num, enum cc_param_caption_type caption_type)
+{
+ LOGD("----sub_start_atsc_cc-1--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
+ switch (country) {
+ case CC_PARAM_COUNTRY_USA:
+ AM_CC_Cmd(CMD_SET_COUNTRY_USA);
+ break;
+ case CC_PARAM_COUNTRY_KOREA:
+ AM_CC_Cmd(CMD_SET_COUNTRY_KOREA);
+ break;
+ default:
+ AM_CC_Cmd(CMD_SET_COUNTRY_USA);
+ break;
+ }
+
+ switch (src_type) {
+ case CC_PARAM_SOURCE_VBIDATA:
+ AM_CC_Cmd(CMD_CC_SET_VBIDATA);
+ break;
+ case CC_PARAM_SOURCE_USERDATA:
+ AM_CC_Cmd(CMD_CC_SET_USERDATA);
+ break;
+ default:
+ AM_CC_Cmd(CMD_CC_SET_USERDATA);
+ break;
+ }
+
+ //just for test
+ if (channel_num == 0) {
+ } else {
+ //AM_CC_Cmd(CMD_CC_SET_CHAN_NUM);
+ }
+
+ AM_CLOSECAPTION_cmd_t cc_t_cmd;
+ switch (caption_type) {
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC1:
+ cc_t_cmd = CMD_CC_1;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC2:
+ cc_t_cmd = CMD_CC_2;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC3:
+ cc_t_cmd = CMD_CC_3;
+ break;
+ case CC_PARAM_ANALOG_CAPTION_TYPE_CC4:
+ cc_t_cmd = CMD_CC_4;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE1:
+ cc_t_cmd = CMD_SERVICE_1;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE2:
+ cc_t_cmd = CMD_SERVICE_2;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE3:
+ cc_t_cmd = CMD_SERVICE_3;
+ break;
+ case CC_PARAM_DIGITAL_CAPTION_TYPE_SERVICE4:
+ cc_t_cmd = CMD_SERVICE_4;
+ break;
+ default:
+ cc_t_cmd = CMD_SERVICE_1;
+ break;
+ }
+ AM_CC_Cmd(cc_t_cmd);
+
+ AM_CC_Set_CallBack(close_caption_callback, this);
+ AM_VCHIP_Set_CallBack(atv_vchip_callback, this);
+ //start
+ AM_CC_Cmd(CMD_CC_START);
+ LOGD("----sub_start_atsc_cc-2--- country=%d,src=%d,ctype=%d", country, src_type, caption_type);
+ return 0;
+}
+
+int CTvSubtitle::sub_stop_atsc_cc()
+{
+ LOGD("----sub_stop_atsc_cc----");
+ AM_CC_Cmd(CMD_CC_STOP);
+ return 0;
+}
+int CTvSubtitle::ResetVchipChgStat()
+{
+ avchip_chg = 0;
+ AM_CC_Cmd(CMD_VCHIP_RST_CHGSTAT);
+ return 0;
+}
+int CTvSubtitle::IsVchipChange()
+{
+ return avchip_chg;
+}
+//cnt :data buf len
+//databuf len is max 512
+//cmdbuf len is max 128
+void CTvSubtitle::close_caption_callback(char *str, int cnt, int data_buf[], int cmd_buf[], void *user_data)
+{
+
+ CTvSubtitle *pSub = (CTvSubtitle *)user_data;
+
+ if (pSub == NULL) {
+ LOGD("sub cc callback is null user data for this");
+ return;
+ }
+
+ if (pSub->mpObser == NULL) return;
+
+ pSub->mCurCCEv.mDataBufSize = cnt;
+ pSub->mCurCCEv.mpDataBuffer = data_buf;
+ pSub->mCurCCEv.mCmdBufSize = 128;//max
+ pSub->mCurCCEv.mpCmdBuffer = cmd_buf;
+
+ pSub->mpObser->onEvent(pSub->mCurCCEv);
+}
+void CTvSubtitle::atv_vchip_callback(int Is_chg, void *user_data)
+{
+ CTvSubtitle *pSub = (CTvSubtitle *)user_data;
+ pSub->avchip_chg = Is_chg;
+}