summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_input.cpp45
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h100
-rw-r--r--tvapi/android/include/ITvClient.h58
-rw-r--r--tvapi/android/include/ITvService.h68
-rw-r--r--tvapi/android/include/Tv.h161
-rw-r--r--tvapi/android/include/tvcmd.h1188
-rw-r--r--tvapi/android/jni/Android.mk132
-rw-r--r--tvapi/android/jni/android_amlogic_tv.cpp911
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp289
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp117
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp101
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tvserver/Android.mk162
-rw-r--r--tvapi/android/tvserver/TvService.cpp8755
-rw-r--r--tvapi/android/tvserver/TvService.h164
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rwxr-xr-x[-rw-r--r--]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk3
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2426
-rw-r--r--tvapi/libtv/audio/audio_alsa.h261
-rw-r--r--tvapi/libtv/audio/audio_android.cpp2070
-rw-r--r--tvapi/libtv/audio/audio_android.h157
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp1182
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h131
-rw-r--r--tvapi/libtv/audio/audio_api.cpp4940
-rw-r--r--tvapi/libtv/audio/audio_api.h647
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp456
-rw-r--r--tvapi/libtv/audio/audio_effect.h63
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h306
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h508
-rw-r--r--tvapi/libtv/include/ve.h438
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp426
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h47
-rw-r--r--tvapi/libtv/tv/CAv.cpp484
-rw-r--r--tvapi/libtv/tv/CAv.h194
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2326
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h680
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp838
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h227
-rw-r--r--tvapi/libtv/tv/CTv.cpp10755
-rw-r--r--tvapi/libtv/tv/CTv.h1269
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h167
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h15
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp260
-rw-r--r--tvapi/libtv/tv/CTvEpg.h280
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h314
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h93
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h43
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1417
-rw-r--r--tvapi/libtv/tv/CTvScanner.h319
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1060
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp272
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h469
-rw-r--r--tvapi/libtv/tv/CTvTime.h137
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h43
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h284
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h79
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.conf58
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp106
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.h40
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp694
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h575
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp300
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h190
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h196
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp482
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h171
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h61
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1766
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1065
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h85
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp448
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4240
-rw-r--r--tvapi/libtv/tvin/CTvin.h2222
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h101
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp706
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h153
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h53
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h75
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4424
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h742
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h11
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2784
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp3706
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h338
-rw-r--r--tvapi/libtv/tvutils/CCondition.h87
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp250
-rw-r--r--tvapi/libtv/tvutils/CFile.h53
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h9
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp144
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h44
-rw-r--r--tvapi/libtv/tvutils/CMutex.h116
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h98
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h45
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h292
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h79
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp196
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h49
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h72
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3822
-rw-r--r--tvapi/libtv/tvutils/tvutils.h238
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h57
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3183
-rw-r--r--tvapi/libtv/vpp/CPQdb.h321
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp4772
-rw-r--r--tvapi/libtv/vpp/CVpp.h683
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp30
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
147 files changed, 55964 insertions, 55946 deletions
diff --git a/tvapi/libtv/tvutils/CSerialPort.cpp b/tvapi/libtv/tvutils/CSerialPort.cpp
index f634b04..d48869f 100644
--- a/tvapi/libtv/tvutils/CSerialPort.cpp
+++ b/tvapi/libtv/tvutils/CSerialPort.cpp
@@ -15,7 +15,7 @@
CSerialPort::CSerialPort()
{
- mDevId = -1;
+ mDevId = -1;
}
//close it
CSerialPort::~CSerialPort()
@@ -24,334 +24,334 @@ CSerialPort::~CSerialPort()
int CSerialPort::OpenDevice(int serial_dev_id)
{
- int tmp_ret = 0;
- const char *dev_file_name = NULL;
-
- if (getFd() < 0) {
- if (serial_dev_id == SERIAL_A) {
- dev_file_name = DEV_PATH_S0;
- } else if (serial_dev_id == SERIAL_B) {
- dev_file_name = DEV_PATH_S1;
- } else if (serial_dev_id == SERIAL_C) {
- dev_file_name = DEV_PATH_S2;
- }
-
- if (dev_file_name != NULL) {
- mDevId = serial_dev_id;
- tmp_ret = openFile(dev_file_name);
- }
- }
-
- return tmp_ret;
+ int tmp_ret = 0;
+ const char *dev_file_name = NULL;
+
+ if (getFd() < 0) {
+ if (serial_dev_id == SERIAL_A) {
+ dev_file_name = DEV_PATH_S0;
+ } else if (serial_dev_id == SERIAL_B) {
+ dev_file_name = DEV_PATH_S1;
+ } else if (serial_dev_id == SERIAL_C) {
+ dev_file_name = DEV_PATH_S2;
+ }
+
+ if (dev_file_name != NULL) {
+ mDevId = serial_dev_id;
+ tmp_ret = openFile(dev_file_name);
+ }
+ }
+
+ return tmp_ret;
}
int CSerialPort::CloseDevice()
{
- mDevId = -1;
- closeFile();
+ mDevId = -1;
+ closeFile();
- return 0;
+ return 0;
}
void CSerialPort::set_speed (int fd, int speed)
{
- int i;
- int status;
- struct termios Opt;
- tcgetattr (fd, &Opt);
- for (i = 0; i < sizeof (speed_arr) / sizeof (int); i++) {
- if (speed == name_arr[i]) {
- tcflush (fd, TCIOFLUSH);
- cfsetispeed (&Opt, speed_arr[i]);
- cfsetospeed (&Opt, speed_arr[i]);
- status = tcsetattr (fd, TCSANOW, &Opt);
- if (status != 0) {
- perror ("tcsetattr fd1");
- return;
- }
- tcflush (fd, TCIOFLUSH);
- }
- }
+ int i;
+ int status;
+ struct termios Opt;
+ tcgetattr (fd, &Opt);
+ for (i = 0; i < sizeof (speed_arr) / sizeof (int); i++) {
+ if (speed == name_arr[i]) {
+ tcflush (fd, TCIOFLUSH);
+ cfsetispeed (&Opt, speed_arr[i]);
+ cfsetospeed (&Opt, speed_arr[i]);
+ status = tcsetattr (fd, TCSANOW, &Opt);
+ if (status != 0) {
+ perror ("tcsetattr fd1");
+ return;
+ }
+ tcflush (fd, TCIOFLUSH);
+ }
+ }
}
int CSerialPort::set_Parity (int fd, int databits, int stopbits, int parity)
{
- struct termios options;
- if (tcgetattr (fd, &options) != 0) {
- perror ("SetupSerial 1");
- return (0);
- }
- options.c_cflag &= ~CSIZE;
- switch (databits) {
- case 7:
- options.c_cflag |= CS7;
- break;
- case 8:
- options.c_cflag |= CS8;
- break;
- default:
- fprintf (stderr, "Unsupported data size\n");
- return (0);
- }
- switch (parity) {
- case 'n':
- case 'N':
- options.c_cflag &= ~PARENB; /* Clear parity enable */
- options.c_iflag &= ~INPCK; /* Enable parity checking */
- break;
- case 'o':
- case 'O':
- options.c_cflag |= (PARODD | PARENB);
- options.c_iflag |= INPCK; /* Disnable parity checking */
- break;
- case 'e':
- case 'E':
- options.c_cflag |= PARENB; /* Enable parity */
- options.c_cflag &= ~PARODD;
- options.c_iflag |= INPCK; /* Disnable parity checking */
- break;
- case 'S':
- case 's': /*as no parity */
- options.c_cflag &= ~PARENB;
- options.c_cflag &= ~CSTOPB;
- break;
- default:
- fprintf (stderr, "Unsupported parity\n");
- return (0);
- }
-
- switch (stopbits) {
- case 1:
- options.c_cflag &= ~CSTOPB;
- break;
- case 2:
- options.c_cflag |= CSTOPB;
- break;
- default:
- fprintf (stderr, "Unsupported stop bits\n");
- return (0);
- }
- /* Set input parity option */
- if (parity != 'n')
- options.c_iflag |= INPCK;
- tcflush (fd, TCIFLUSH);
- options.c_cc[VTIME] = 150;
- options.c_cc[VMIN] = 0; /* Update the options and do it NOW */
- //qd to set raw mode, which is copied from web
- options.c_iflag &= ~(IGNBRK | BRKINT | PARMRK | ISTRIP
- | INLCR | IGNCR | ICRNL | IXON);
- options.c_oflag &= ~OPOST;
- options.c_lflag &= ~(ECHO | ECHONL | ICANON | ISIG | IEXTEN);
- options.c_cflag &= ~(CSIZE | PARENB);
- options.c_cflag |= CS8;
-
- if (tcsetattr (fd, TCSANOW, &options) != 0) {
- perror ("SetupSerial 3");
- return (0);
- }
- return (1);
+ struct termios options;
+ if (tcgetattr (fd, &options) != 0) {
+ perror ("SetupSerial 1");
+ return (0);
+ }
+ options.c_cflag &= ~CSIZE;
+ switch (databits) {
+ case 7:
+ options.c_cflag |= CS7;
+ break;
+ case 8:
+ options.c_cflag |= CS8;
+ break;
+ default:
+ fprintf (stderr, "Unsupported data size\n");
+ return (0);
+ }
+ switch (parity) {
+ case 'n':
+ case 'N':
+ options.c_cflag &= ~PARENB; /* Clear parity enable */
+ options.c_iflag &= ~INPCK; /* Enable parity checking */
+ break;
+ case 'o':
+ case 'O':
+ options.c_cflag |= (PARODD | PARENB);
+ options.c_iflag |= INPCK; /* Disnable parity checking */
+ break;
+ case 'e':
+ case 'E':
+ options.c_cflag |= PARENB; /* Enable parity */
+ options.c_cflag &= ~PARODD;
+ options.c_iflag |= INPCK; /* Disnable parity checking */
+ break;
+ case 'S':
+ case 's': /*as no parity */
+ options.c_cflag &= ~PARENB;
+ options.c_cflag &= ~CSTOPB;
+ break;
+ default:
+ fprintf (stderr, "Unsupported parity\n");
+ return (0);
+ }
+
+ switch (stopbits) {
+ case 1:
+ options.c_cflag &= ~CSTOPB;
+ break;
+ case 2:
+ options.c_cflag |= CSTOPB;
+ break;
+ default:
+ fprintf (stderr, "Unsupported stop bits\n");
+ return (0);
+ }
+ /* Set input parity option */
+ if (parity != 'n')
+ options.c_iflag |= INPCK;
+ tcflush (fd, TCIFLUSH);
+ options.c_cc[VTIME] = 150;
+ options.c_cc[VMIN] = 0; /* Update the options and do it NOW */
+ //qd to set raw mode, which is copied from web
+ options.c_iflag &= ~(IGNBRK | BRKINT | PARMRK | ISTRIP
+ | INLCR | IGNCR | ICRNL | IXON);
+ options.c_oflag &= ~OPOST;
+ options.c_lflag &= ~(ECHO | ECHONL | ICANON | ISIG | IEXTEN);
+ options.c_cflag &= ~(CSIZE | PARENB);
+ options.c_cflag |= CS8;
+
+ if (tcsetattr (fd, TCSANOW, &options) != 0) {
+ perror ("SetupSerial 3");
+ return (0);
+ }
+ return (1);
}
int CSerialPort::setup_serial()
{
- set_speed(mFd, 115200);
- set_Parity(mFd, 8, 1, 'N');
- return 0;
+ set_speed(mFd, 115200);
+ set_Parity(mFd, 8, 1, 'N');
+ return 0;
}
int CSerialPort::set_opt(int speed, int db, int sb, char pb, int overtime, bool raw_mode)
{
- int i = 0;
- struct termios old_cfg, new_cfg;
- if (mFd <= 0) {
- LOGE("not open dev, when set opt");
- return -1;
- }
- //first get it
- if (tcgetattr(mFd, &old_cfg) != 0) {
- LOGE("get serial attr error mFd = %d(%s)!\n", mFd, strerror(errno));
- return -1;
- }
-
- //set speed
- for (i = 0; i < sizeof(speed_arr) / sizeof(int); i++) {
- if (speed == name_arr[i]) {
- cfsetispeed(&new_cfg, speed_arr[i]);
- cfsetospeed(&new_cfg, speed_arr[i]);
- break;
- }
- }
-
- setdatabits(&new_cfg, db);
- setstopbits(&new_cfg, sb);
- setparity(&new_cfg, pb);
-
-
- if (overtime >= 0) {
- new_cfg.c_cc[VTIME] = overtime / 100; /* 设置超时 seconds*/
- new_cfg.c_cc[VMIN] = 0; /* Update the options and do it NOW */
- }
-
- if (raw_mode) {
- cfmakeraw(&new_cfg);
- }
-
- //clear
- tcflush(mFd, TCIOFLUSH);
- if (tcsetattr(mFd, TCSANOW, &new_cfg) < 0) {
- LOGE("%s, set serial attr error(%s)!\n", "TV", strerror(errno));
- return -1;
- }
- //clear,let be avail
- tcflush(mFd, TCIOFLUSH);
-
- return 0;
+ int i = 0;
+ struct termios old_cfg, new_cfg;
+ if(mFd <= 0) {
+ LOGE("not open dev, when set opt");
+ return -1;
+ }
+ //first get it
+ if(tcgetattr(mFd, &old_cfg) != 0) {
+ LOGE("get serial attr error mFd = %d(%s)!\n", mFd, strerror(errno));
+ return -1;
+ }
+
+ //set speed
+ for (i = 0; i < sizeof(speed_arr) / sizeof(int); i++) {
+ if (speed == name_arr[i]) {
+ cfsetispeed(&new_cfg, speed_arr[i]);
+ cfsetospeed(&new_cfg, speed_arr[i]);
+ break;
+ }
+ }
+
+ setdatabits(&new_cfg, db);
+ setstopbits(&new_cfg, sb);
+ setparity(&new_cfg, pb);
+
+
+ if (overtime >= 0) {
+ new_cfg.c_cc[VTIME] = overtime / 100; /* 设置超时 seconds*/
+ new_cfg.c_cc[VMIN] = 0; /* Update the options and do it NOW */
+ }
+
+ if (raw_mode) {
+ cfmakeraw(&new_cfg);
+ }
+
+ //clear
+ tcflush(mFd, TCIOFLUSH);
+ if (tcsetattr(mFd, TCSANOW, &new_cfg) < 0) {
+ LOGE("%s, set serial attr error(%s)!\n", "TV", strerror(errno));
+ return -1;
+ }
+ //clear,let be avail
+ tcflush(mFd, TCIOFLUSH);
+
+ return 0;
}
int CSerialPort::writeFile(const unsigned char *pData, unsigned int uLen)
{
- unsigned int len;
- len = write(mFd, pData, uLen);
- if (len == uLen) {
- return len;
- } else {
- tcflush(mFd, TCOFLUSH);
- LOGE("write data failed and tcflush hComm\n");
- return -1;
- }
+ unsigned int len;
+ len = write(mFd, pData, uLen);
+ if (len == uLen) {
+ return len;
+ } else {
+ tcflush(mFd, TCOFLUSH);
+ LOGE("write data failed and tcflush hComm\n");
+ return -1;
+ }
}
static int com_read_data(int hComm, unsigned 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);
+ 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]);
- }
+ 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;
+ 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 CSerialPort::readFile(unsigned char *pBuf, unsigned int uLen)
{
- //using non-block mode
- return com_read_data(mFd, pBuf, uLen);
+ //using non-block mode
+ return com_read_data(mFd, pBuf, uLen);
}
int CSerialPort::setdatabits(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("Unsupported data size!\n");
- }
- return 0;
+ 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("Unsupported data size!\n");
+ }
+ return 0;
}
int CSerialPort::setstopbits(struct termios *s, int sb)
{
- if (sb == 1) {
- s->c_cflag &= ~CSTOPB;
- } else if (sb == 2) {
- s->c_cflag |= CSTOPB;
- } else {
- LOGE("Unsupported stop bits!\n");
- }
- return 0;
+ if (sb == 1) {
+ s->c_cflag &= ~CSTOPB;
+ } else if (sb == 2) {
+ s->c_cflag |= CSTOPB;
+ } else {
+ LOGE("Unsupported stop bits!\n");
+ }
+ return 0;
}
int CSerialPort::setparity(struct termios *s, char 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("Unsupported parity!\n");
- }
- return 0;
+ 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("Unsupported parity!\n");
+ }
+ return 0;
}