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_base.cpp b/tvapi/libtv/tvutils/serial_base.cpp
new file mode 100644
index 0000000..8a5a98b
--- a/dev/null
+++ b/tvapi/libtv/tvutils/serial_base.cpp
@@ -0,0 +1,466 @@
+#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"
+
+#define LOG_TAG "serial_base"
+#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 < 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, 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, 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;
+}