summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk23
-rw-r--r--TvPlay.cpp (renamed from tvapi/android/tv/TvPlay.cpp)2
-rw-r--r--TvPlay.h (renamed from tvapi/android/tv/TvPlay.h)2
-rw-r--r--tv_callback.h2
-rw-r--r--tv_input.cpp4
-rw-r--r--tvapi/Android.mk1
-rw-r--r--tvapi/android/Android.mk1
-rw-r--r--tvapi/android/include/ITv.h49
-rw-r--r--tvapi/android/include/ITvClient.h28
-rw-r--r--tvapi/android/include/ITvService.h33
-rw-r--r--tvapi/android/include/TvClient.h78
-rw-r--r--tvapi/android/include/tvcmd.h618
-rw-r--r--tvapi/android/jni/Android.mk69
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp167
-rw-r--r--tvapi/android/jni/cfbc_test.cpp43
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp469
-rw-r--r--tvapi/android/libtvbinder/Android.mk24
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp148
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp58
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp50
-rw-r--r--tvapi/android/libtvbinder/TvClient.cpp186
-rw-r--r--tvapi/android/tv/Android.mk23
-rw-r--r--tvapi/android/tvserver/Android.mk83
-rw-r--r--tvapi/android/tvserver/TvService.cpp4500
-rw-r--r--tvapi/android/tvserver/TvService.h90
-rw-r--r--tvapi/android/tvserver/main.cpp23
-rw-r--r--tvapi/android/tvserver/tv_callback.h17
-rw-r--r--tvapi/build/include/.gitignore0
-rw-r--r--tvapi/docs/TVMiddleware初期.wps252
-rw-r--r--tvapi/docs/tv.uml6093
-rw-r--r--tvapi/libtv/Android.mk222
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp126
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h31
-rw-r--r--tvapi/libtv/audio/CTvAudio.cpp28
-rw-r--r--tvapi/libtv/audio/CTvAudio.h76
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp853
-rw-r--r--tvapi/libtv/audio/audio_alsa.h127
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp131
-rw-r--r--tvapi/libtv/audio/audio_effect.h27
-rw-r--r--tvapi/libtv/include/amstream.h263
-rw-r--r--tvapi/libtv/include/amvecm.h68
-rw-r--r--tvapi/libtv/include/cm.h155
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h331
-rw-r--r--tvapi/libtv/include/ve.h242
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp207
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h46
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp142
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h36
-rw-r--r--tvapi/libtv/tv/CAv.cpp476
-rw-r--r--tvapi/libtv/tv/CAv.h153
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp1931
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h401
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp667
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h166
-rw-r--r--tvapi/libtv/tv/CTv.cpp7254
-rw-r--r--tvapi/libtv/tv/CTv.h817
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp159
-rw-r--r--tvapi/libtv/tv/CTvBooking.h81
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp24
-rw-r--r--tvapi/libtv/tv/CTvDmx.h17
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp214
-rw-r--r--tvapi/libtv/tv/CTvEpg.h158
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp11
-rw-r--r--tvapi/libtv/tv/CTvEv.h150
-rw-r--r--tvapi/libtv/tv/CTvLog.cpp20
-rw-r--r--tvapi/libtv/tv/CTvLog.h28
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp273
-rw-r--r--tvapi/libtv/tv/CTvRecord.h46
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h21
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1640
-rw-r--r--tvapi/libtv/tv/CTvScanner.h264
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp796
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h176
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp654
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h250
-rw-r--r--tvapi/libtv/tv/CTvTime.cpp64
-rw-r--r--tvapi/libtv/tv/CTvTime.h56
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp163
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h49
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp553
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h144
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp379
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp353
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h72
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf30
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp53
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h93
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp324
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h287
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp256
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h94
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp639
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h97
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp237
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h85
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp44
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h30
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp905
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h536
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp174
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h42
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp651
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.h94
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp263
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h73
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp3278
-rw-r--r--tvapi/libtv/tvin/CTvin.h1248
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp26
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h50
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp52
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h76
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp78
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h26
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp129
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h37
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2448
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h277
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h411
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp187
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h22
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1328
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h125
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp723
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h70
-rw-r--r--tvapi/libtv/tvutils/CCondition.h90
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp195
-rw-r--r--tvapi/libtv/tvutils/CFile.h47
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp16
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h9
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp122
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h53
-rw-r--r--tvapi/libtv/tvutils/CMutex.h115
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp121
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h49
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp358
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h54
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp151
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h184
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp165
-rw-r--r--tvapi/libtv/tvutils/CThread.h61
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp170
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h42
-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.cpp225
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h33
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp2025
-rw-r--r--tvapi/libtv/tvutils/tvutils.h103
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp88
-rw-r--r--tvapi/libtv/tvutils/zepoll.h48
-rw-r--r--tvapi/libtv/version/version.cpp94
-rw-r--r--tvapi/libtv/version/version.h11
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp1974
-rw-r--r--tvapi/libtv/vpp/CPQdb.h180
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp3779
-rw-r--r--tvapi/libtv/vpp/CVpp.h453
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp143
-rw-r--r--tvapi/libtv/vpp/pqdata.h30
-rw-r--r--tvapi/tvtests/Android.mk49
-rw-r--r--tvapi/tvtests/android_tvtest.cpp32
-rw-r--r--tvapi/tvtests/comm_test.cpp33
-rw-r--r--tvapi/tvtests/ssm_test.cpp210
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp427
163 files changed, 13 insertions, 62934 deletions
diff --git a/tvapi/libtv/tvutils/serial_base.cpp b/tvapi/libtv/tvutils/serial_base.cpp
deleted file mode 100644
index be9ae17..0000000
--- a/tvapi/libtv/tvutils/serial_base.cpp
+++ b/dev/null
@@ -1,466 +0,0 @@
-#define LOG_TAG "serial_base"
-
-#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 <android/log.h>
-#include <cutils/log.h>
-
-#include "serial_base.h"
-#include "CTvLog.h"
-
-#define CS_SERIAL_A_DEV_PATH "/dev/ttyS0"
-#define CS_SERIAL_B_DEV_PATH "/dev/ttyS1"
-
-static int gSerialAHandle = -1;
-static pthread_mutex_t serial_a_op_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_a_r_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_a_w_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_a_speed_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_a_parity_mutex = PTHREAD_MUTEX_INITIALIZER;
-
-static int gSerialBHandle = -1;
-static pthread_mutex_t serial_b_op_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_b_r_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_b_w_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_b_speed_mutex = PTHREAD_MUTEX_INITIALIZER;
-static pthread_mutex_t serial_b_parity_mutex = PTHREAD_MUTEX_INITIALIZER;
-
-static int speed_arr[] = { B115200, B38400, B19200, B9600, B4800, B2400, B1200, B300, B38400, B19200, B9600, B4800, B2400, B1200, B300, };
-static int name_arr[] = { 115200, 38400, 19200, 9600, 4800, 2400, 1200, 300, 38400, 19200, 9600, 4800, 2400, 1200, 300, };
-
-static int open_com_dev(int *dev_handle, char *dev_path)
-{
- if (*dev_handle < 0) {
- *dev_handle = open(dev_path, O_RDWR);
- if (*dev_handle < 0) {
- LOGE("%s, Can't Open Serial Port %s", "TV", dev_path);
- }
- }
-
- return *dev_handle;
-}
-
-static int close_com_dev(int *dev_handle)
-{
- if (*dev_handle >= 0) {
- close(*dev_handle);
- *dev_handle = -1;
- }
-
- return 0;
-}
-
-static __inline__ int cfsetdatabits(struct termios *s, int db)
-{
- if (db == 5) {
- s->c_cflag = (s->c_cflag & ~CSIZE) | (CS5 & CSIZE);
- } else if (db == 6) {
- s->c_cflag = (s->c_cflag & ~CSIZE) | (CS6 & CSIZE);
- } else if (db == 7) {
- s->c_cflag = (s->c_cflag & ~CSIZE) | (CS7 & CSIZE);
- } else if (db == 8) {
- s->c_cflag = (s->c_cflag & ~CSIZE) | (CS8 & CSIZE);
- } else {
- LOGE("%s, Unsupported data size!\n", "TV");
- }
-
- return 0;
-}
-
-static __inline__ int cfsetstopbits(struct termios *s, int sb)
-{
- if (sb == 1) {
- s->c_cflag &= ~CSTOPB;
- } else if (sb == 2) {
- s->c_cflag |= CSTOPB;
- } else {
- LOGE("%s, Unsupported stop bits!\n", "TV");
- }
-
- return 0;
-}
-
-static __inline__ int cfsetparity(struct termios *s, int pb)
-{
- if (pb == 'n' || pb == 'N') {
- s->c_cflag &= ~PARENB; /* Clear parity enable */
- s->c_cflag &= ~INPCK; /* Enable parity checking */
- } else if (pb == 'o' || pb == 'O') {
- s->c_cflag |= (PARODD | PARENB);
- s->c_cflag |= INPCK; /* Disable parity checking */
- } else if (pb == 'e' || pb == 'E') {
- s->c_cflag |= PARENB; /* Enable parity */
- s->c_cflag &= ~PARODD;
- s->c_iflag |= INPCK; /* Disable parity checking */
- } else if (pb == 's' || pb == 'S') {
- s->c_cflag &= ~PARENB;
- s->c_cflag &= ~CSTOPB;
- s->c_cflag |= INPCK; /* Disable parity checking */
- } else {
- LOGE("%s, Unsupported parity!\n", "TV");
- }
-
- return 0;
-}
-
-static int gOriAttrGetFlag = 0;
-static struct termios gOriAttrValue;
-static __inline__ int com_get_attr(int fd, struct termios *s)
-{
- if (gOriAttrGetFlag == 0) {
- if (tcgetattr(fd, s) != 0) {
- return -1;
- }
-
- gOriAttrGetFlag = 1;
- gOriAttrValue = *s;
- }
-
- *s = gOriAttrValue;
-
- return 0;
-}
-
-static int com_set_opt(int hComm, int speed, int db, int sb, int pb, int to, int raw_mode)
-{
- int i = 0;
- struct termios tmpOpt;
-
- if (com_get_attr(hComm, &tmpOpt) != 0) {
- LOGE("%s, get serial attr error(%s)!\n", "TV", strerror(errno));
- return -1;
- }
-
- for (i = 0; i < (int)(sizeof(speed_arr) / sizeof(int)); i++) {
- if (speed == name_arr[i]) {
- cfsetispeed(&tmpOpt, speed_arr[i]);
- cfsetospeed(&tmpOpt, speed_arr[i]);
- break;
- }
- }
-
- cfsetdatabits(&tmpOpt, db);
- cfsetstopbits(&tmpOpt, sb);
- cfsetparity(&tmpOpt, pb);
-
- if (to >= 0) {
- tmpOpt.c_cc[VTIME] = to; /* 设置超时15 seconds*/
- tmpOpt.c_cc[VMIN] = 0; /* Update the options and do it NOW */
- }
-
- if (raw_mode == 1) {
- cfmakeraw(&tmpOpt);
- }
-
- tcflush(hComm, TCIOFLUSH);
- if (tcsetattr(hComm, TCSANOW, &tmpOpt) < 0) {
- LOGE("%s, set serial attr error(%s)!\n", "TV", strerror(errno));
- return -1;
- }
- tcflush(hComm, TCIOFLUSH);
-
- return 0;
-}
-
-static int com_write_data(int hComm, const unsigned char *pData, unsigned int uLen)
-{
- unsigned int len;
-
- if (hComm < 0) {
- return -1;
- }
-
- if (pData == NULL) {
- return -1;
- }
-
- LOGD("%s, write %d bytes\n", "TV", uLen);
-
- len = write(hComm, pData, uLen);
- if (len == uLen) {
- LOGD("%s, write data success\n", "TV");
- return len;
- } else {
- tcflush(hComm, TCOFLUSH);
- LOGE("%s, write data failed and tcflush hComm\n", "TV");
- return -1;
- }
-}
-
-static int com_read_data(int hComm, char *pData, unsigned int uLen)
-{
- char inbuff[uLen];
- char buff[uLen];
- char tempbuff[uLen];
- int i = 0, j = 0;
-
- memset(inbuff, '\0', uLen);
- memset(buff, '\0', uLen);
- memset(tempbuff, '\0', uLen);
-
- if (hComm < 0) {
- return -1;
- }
-
- char *p = inbuff;
-
- fd_set readset;
- struct timeval tv;
- int MaxFd = 0;
-
- unsigned int c = 0;
- int z, k;
-
- do {
- FD_ZERO(&readset);
- FD_SET(hComm, &readset);
- MaxFd = hComm + 1;
- tv.tv_sec = 0;
- tv.tv_usec = 100000;
- do {
- z = select(MaxFd, &readset, 0, 0, &tv);
- } while (z == -1 && errno == EINTR);
-
- if (z == -1) {
- hComm = -1;
- break;
- }
-
- if (z == 0) {
- hComm = -1;
- break;
- }
-
- if (FD_ISSET(hComm, &readset)) {
- z = read(hComm, buff, uLen - c);
-#if 0
- for (k = 0; k < z; k++) {
- LOGD("%s, inbuff[%d]:%02X", "TV", k, buff[k]);
- }
-#endif
- c += z;
-
- if (z > 0) {
- if (z < (signed int) uLen) {
- buff[z + 1] = '\0';
- memcpy(p, buff, z);
- p += z;
- } else {
- memcpy(inbuff, buff, z);
- }
-
- memset(buff, '\0', uLen);
- } else {
- hComm = -1;
- }
-
- if (c >= uLen) {
- hComm = -1;
- break;
- }
- }
- } while (hComm >= 0);
-
- memcpy(pData, inbuff, c);
- p = NULL;
- return c;
-}
-
-int com_a_open_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_op_mutex);
-
- tmp_ret = open_com_dev(&gSerialAHandle, (char *)CS_SERIAL_A_DEV_PATH);
-
- pthread_mutex_unlock(&serial_a_op_mutex);
-
- return tmp_ret;
-}
-
-int com_b_open_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_op_mutex);
-
- tmp_ret = open_com_dev(&gSerialBHandle, (char *)CS_SERIAL_B_DEV_PATH);
-
- pthread_mutex_unlock(&serial_b_op_mutex);
-
- return tmp_ret;
-}
-
-int com_a_close_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_op_mutex);
-
- tmp_ret = close_com_dev(&gSerialAHandle);
-
- pthread_mutex_unlock(&serial_a_op_mutex);
-
- return tmp_ret;
-}
-
-int com_b_close_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_op_mutex);
-
- tmp_ret = close_com_dev(&gSerialBHandle);
-
- pthread_mutex_unlock(&serial_b_op_mutex);
-
- return tmp_ret;
-}
-
-int com_a_get_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_op_mutex);
-
- tmp_ret = gSerialAHandle;
-
- pthread_mutex_unlock(&serial_a_op_mutex);
-
- return tmp_ret;
-}
-
-int com_b_get_dev()
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_op_mutex);
-
- tmp_ret = gSerialBHandle;
-
- pthread_mutex_unlock(&serial_b_op_mutex);
-
- return tmp_ret;
-}
-
-int com_a_set_opt(int speed, int db, int sb, int pb, int to, int raw_mode)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_parity_mutex);
-
- if (com_a_get_dev() < 0) {
- pthread_mutex_unlock(&serial_a_parity_mutex);
- return -1;
- }
-
- tmp_ret = com_set_opt(gSerialAHandle, speed, db, sb, pb, to, raw_mode);
-
- pthread_mutex_unlock(&serial_a_parity_mutex);
-
- return tmp_ret;
-}
-
-int com_b_set_opt(int speed, int db, int sb, int pb, int to, int raw_mode)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_parity_mutex);
-
- if (com_b_get_dev() < 0) {
- pthread_mutex_unlock(&serial_b_parity_mutex);
- return -1;
- }
-
- tmp_ret = com_set_opt(gSerialBHandle, speed, db, sb, pb, to, raw_mode);
-
- pthread_mutex_unlock(&serial_b_parity_mutex);
-
- return tmp_ret;
-}
-
-int com_a_write_data(const unsigned char *pData, unsigned int uLen)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_w_mutex);
-
- if (com_a_get_dev() < 0) {
- pthread_mutex_unlock(&serial_a_w_mutex);
- return -1;
- }
-
- LOGD("%s, write %d bytes\n", "TV", uLen);
-
- tmp_ret = com_write_data(gSerialAHandle, pData, uLen);
-
- pthread_mutex_unlock(&serial_a_w_mutex);
-
- return tmp_ret;
-}
-
-int com_b_write_data(const unsigned char *pData, unsigned int uLen)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_w_mutex);
-
- if (com_b_get_dev() < 0) {
- pthread_mutex_unlock(&serial_b_w_mutex);
- return -1;
- }
-
- LOGD("%s, write %d bytes\n", "TV", uLen);
-
- tmp_ret = com_write_data(gSerialBHandle, pData, uLen);
-
- pthread_mutex_unlock(&serial_b_w_mutex);
-
- return tmp_ret;
-}
-
-int com_a_read_data(char *pData, unsigned int uLen)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_a_r_mutex);
-
- if (com_a_get_dev() < 0) {
- pthread_mutex_unlock(&serial_a_r_mutex);
- return -1;
- }
-
- tmp_ret = com_read_data(gSerialAHandle, pData, uLen);
-
- pthread_mutex_unlock(&serial_a_r_mutex);
-
- return tmp_ret;
-}
-
-int com_b_read_data(char *pData, unsigned int uLen)
-{
- int tmp_ret = 0;
-
- pthread_mutex_lock(&serial_b_r_mutex);
-
- if (com_b_get_dev() < 0) {
- pthread_mutex_unlock(&serial_b_r_mutex);
- return -1;
- }
-
- tmp_ret = com_read_data(gSerialBHandle, pData, uLen);
-
- pthread_mutex_unlock(&serial_b_r_mutex);
-
- return tmp_ret;
-}