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/tvutils/serial_operate.cpp b/tvapi/libtv/tvutils/serial_operate.cpp
new file mode 100644
index 0000000..c81357e
--- a/dev/null
+++ b/tvapi/libtv/tvutils/serial_operate.cpp
@@ -0,0 +1,229 @@
+#include <stdio.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <string.h>
+#include <pthread.h>
+#include <termios.h>
+#include <errno.h>
+#include <linux/hidraw.h>
+#include <android/log.h>
+#include <cutils/log.h>
+
+//#include "../TvService.h"
+//#include "../include/tvcmd.h"
+//#include "../tvconfig/tvconfig_api.h"
+//#include "../tvconfig/tvconfig_logcfg.h"
+
+#include "serial_base.h"
+#include "serial_operate.h"
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#define LOG_TAG "headset"
+#endif
+#include "CTvLog.h"
+
+
+//******************************************************
+#ifndef HIDIOCSFEATURE
+#define HIDIOCSFEATURE(len) _IOC(_IOC_WRITE|_IOC_READ, 'H', 0x06, len)
+#define HIDIOCGFEATURE(len) _IOC(_IOC_WRITE|_IOC_READ, 'H', 0x07, len)
+#endif
+#define product_nid 0x00e0
+//#define product_nid 0x00e0
+
+#define vendor_id 0x1A1D
+#define ENDPOINT 3
+
+#define EVENT_2_4G_HEADSET_ON 0
+#define EVENT_2_4G_HEADSET_OFF 1
+
+CTv2d4GHeadSetDetect::CTv2d4GHeadSetDetect()
+{
+}
+
+CTv2d4GHeadSetDetect::~CTv2d4GHeadSetDetect()
+{
+}
+
+int CTv2d4GHeadSetDetect::startDetect()
+{
+ this->run();
+
+ return 0;
+}
+
+bool CTv2d4GHeadSetDetect::threadLoop()
+{
+ int i = 0, rd_len = 0;
+ int thread_cmd_dly_tm = 1000 * 1000;
+ int tvThermal_cnt = 0, fd = 0;
+ char data[10] = "0";
+
+ LOGD("%s, entering...\n", __FUNCTION__);
+
+ //SetSerialBThreadExecFlag(1);
+
+ //*********************************
+ int hidraw_fd;
+ unsigned char buf[32];
+ char phybuf[256];
+ struct hidraw_devinfo info;
+ int read_size = 0;
+ bool debug = true;
+ char device[68];
+ int HeadsetConnectState = false;
+
+ int curdeviceID = -1;
+ for (int deviceID = 0; deviceID < 5; deviceID++) {
+ sprintf(device, "/dev/hidraw%d", deviceID);
+ LOGD(" thread device =%s ", device );
+ if ((hidraw_fd = open(device, O_RDWR)) < 0 ) {
+ LOGD("cann't open path:%s!!!\n", device);
+ continue;
+ }
+ memset(phybuf, 0x0, 256);
+ LOGD("AAAAAAAAAAAAAA:%s!!!\n", device);
+ if (ioctl(hidraw_fd, HIDIOCGRAWINFO, &info) >= 0 &&
+ ioctl(hidraw_fd, HIDIOCGRAWPHYS(256), phybuf) >= 0) {
+ LOGD("\t %d, product id = 0x%04x \n", __LINE__, info.product);
+ LOGD("\t %d, vendor id = 0x%04x \n", __LINE__, info.vendor);
+ int len = strlen(phybuf);
+ if (phybuf[len - 1] - '0' == ENDPOINT) {
+ if (info.vendor == vendor_id) {
+ curdeviceID = deviceID;
+ LOGD("\t product id = 0x%04x \n", info.product);
+ LOGD("\t vendor id = 0x%04x\n", info.vendor);
+ break;
+ }
+ }
+ }
+ close(hidraw_fd);
+ }
+ if (curdeviceID == -1)
+ return 0;
+
+ sprintf(device, "/dev/hidraw%d", curdeviceID);
+ LOGD(" thread device =%s ", device );
+ if ( (hidraw_fd = open(device, O_RDWR | O_NONBLOCK) ) < 0 ) {
+ printf("cann't open path:%s!!!\n", device);
+ return 0;
+ }
+ int checkvalue[300] ;
+ int countcheck = 0;
+ int count = 0;
+ int ritemcounts = 15;
+ //****************************************
+
+ while ( !exitPending() ) { //requietexit() or requietexitWait() not call
+ //loop codes
+ //LOGD("while 2.4G %s ", __FUNCTION__);
+
+ memset(buf, 0x0, 32);
+ for (int ritem = 0; ritem < ritemcounts ; ritem++ ) {
+ read_size = read(hidraw_fd, buf, 32);
+ //for (int i = 0; i < 32; i++)
+ //ALOGD("read_size %d ", read_size);
+ if (debug) {
+ count ++;
+ if (count == 3000) {
+ LOGD("%02x %02x %02x %02x %02x %02x ", buf[0], buf[1], buf[2], buf[3], buf[4], buf[5]);
+ count = 0;
+ }
+ }
+ if (read_size < 0 ) {
+
+ }
+
+ checkvalue[countcheck] = buf[4] & 0x1f;
+ if (countcheck == 299) {
+ int checkcountvalue = 0;
+ for (int icheck = 0; icheck < countcheck ; icheck++ )
+ checkcountvalue += checkvalue[icheck];
+ // LOGD("checkcountvalue = %d",checkcountvalue);
+ if (checkcountvalue <= 5 * 4) {
+ if (HeadsetConnectState == true) {
+ if (debug) {
+ LOGD("headset connect false");
+ LOGD("headset connect false");
+ }
+
+ mpObserver->onHeadSetDetect(0, 0);
+ //usleep(1000 * 200);
+ }
+ HeadsetConnectState = false;
+ } else if (checkcountvalue >= 200 * 4) {
+ if (HeadsetConnectState == false) {
+ if (debug) {
+ LOGD("headset connect true");
+ LOGD("headset connect true");
+ }
+ mpObserver->onHeadSetDetect(1, 0);
+ //usleep(1000 * 200);
+ }
+ HeadsetConnectState = true;
+ }
+ countcheck = 0;
+ }
+ countcheck ++;
+
+ // bit 0: headset mic in/off; bit 1:headset on/off; bit 2: headphone on/off; bit 3: soundbar on/off ;bit 4: subwoofer on/off
+ /* else if (buf[4] & 0x1f)
+ {
+ if (HeadsetConnectState == false)
+ {
+ if (debug)
+ {
+ ALOGD("headset connect true");
+ ALOGD("headset connect true");
+ }
+ android::TvService::getIntance()->SendDtvStats(1,0,0,0,0,0);
+ //usleep(1000 * 200);
+ }
+ HeadsetConnectState = true;
+ }
+ else
+ {
+ if (HeadsetConnectState == true)
+ {
+ if (debug)
+ {
+ ALOGD("headset connect false");
+ ALOGD("headset connect false");
+ }
+ android::TvService::getIntance()->SendDtvStats(2,0,0,0,0,0);
+ //usleep(1000 * 200);
+ }
+ HeadsetConnectState = false;
+ }*/
+ }
+ {
+ //added for fbc thermal setting
+ tvThermal_cnt++;
+ if (tvThermal_cnt == 300) { //60 sec
+ tvThermal_cnt = 0;
+ fd = open("/sys/class/thermal/thermal_zone0/temp", O_RDONLY);
+ if (fd < 0) {
+ LOGE("ERROR: failed to open file error: %d\n", errno);
+ } else {
+ read(fd, data, sizeof(data));
+ close(fd);
+ LOGD("thermal temp data = %s ~~~~~~\n", data);
+ int x = 0;
+ x = atoi(data);
+ mpObserver->onThermalDetect(x);
+ LOGD("int data :%d\n", x);
+ }
+ }
+ }
+ usleep(1000 * 200);
+ }
+ //exit
+ //return true, run again, return false,not run.
+ return false;
+}
+
+