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/tvsetting/CBlobDeviceE2prom.cpp b/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
index 2e0ebe3..849c634 100644
--- a/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
+++ b/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
@@ -1,353 +1,353 @@
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-#include <fcntl.h>
-#include <errno.h>
-
-#include "CBlobDeviceE2prom.h"
-#include "../tvconfig/tvconfig.h"
-#include "../tvutils/tvutils.h"
-#include "CTvLog.h"
-
-#define LOG_TAG "CBlobDeviceE2prom"
-
-#define msleep(x) usleep(x*1000)
-
-CBlobDeviceE2prom::CBlobDeviceE2prom()
-{
-
-}
-
-CBlobDeviceE2prom::~CBlobDeviceE2prom()
-{
-}
-
-int CBlobDeviceE2prom::WriteBytes(int offset, int size, unsigned char *buf)
-{
- return 0;
-}
-int CBlobDeviceE2prom::ReadBytes(int offset, int size, unsigned char *buf)
-{
- return 0;
-}
-int CBlobDeviceE2prom::EraseAllData()
-{
- return 0;
-}
-int CBlobDeviceE2prom::InitCheck()
-{
- return 0;
-}
-int CBlobDeviceE2prom::OpenDevice()
-{
- return 0;
-}
-int CBlobDeviceE2prom::CloseDevice()
-{
- return 0;
-}
-//int CBlobDeviceE2prom::InitCheck() {
-/* int i, tmp_dev_total_size = 0, tmp_offset = 0, rw_check_count = 4;
- unsigned char *tmp_buf = NULL;
- unsigned char w_ch = 0, r_ch = 0;
-
- SetWriteProtectStatus (CC_SSM_PROTECT_ON);
-
- if (ValidOperateCheck() < 0) {
- return -1;
- }
-
- tmp_offset = E2P_DEV_RW_TEST_OFFSET;
-
- if (tmp_offset >= 0) {
- for (i = 0; i < rw_check_count; i++) {
- w_ch = 0x5A;
- WriteNBytes(tmp_offset, 1, &w_ch);
-
- r_ch = 0x00;
- ReadNBytes(tmp_offset, 1, &r_ch);
-
- if (r_ch != w_ch) {
- LOGE("%s, Device rw check error, write %d, read %d.\n", "TV", w_ch, r_ch);
- return -1;
- }
-
- w_ch = 0xA5;
- WriteNBytes(tmp_offset, 1, &w_ch);
-
- r_ch = 0x00;
- ReadNBytes(tmp_offset, 1, &r_ch);
-
- if (r_ch != w_ch) {
- LOGE("%s, Device rw check error, write %d, read %d.\n", "TV", w_ch, r_ch);
- return -1;
- }
- }
- }
-
- if (device_buf != NULL) {
- delete device_buf;
- device_buf = NULL;
- }
-
- if (device_use_buffer) {
- tmp_dev_total_size = GetDeviceTotalSize();
- if (tmp_dev_total_size <= 0) {
- LOGE("%s, Device file size must be more than 0.\n", "TV");
- return -1;
- }
-
- tmp_buf = new unsigned char[tmp_dev_total_size];
- if (tmp_buf != NULL) {
- if (ReadNBytes(0, tmp_dev_total_size, tmp_buf) < 0) {
- delete tmp_buf;
- tmp_buf = NULL;
-
- LOGE("%s, Read data from device error when read data to device rw buffer!!!.\n", "TV");
- return -1;
- }
-
- device_buf = new unsigned char[tmp_dev_total_size];
- if (device_buf != NULL) {
- memcpy((void *) device_buf, (void *) tmp_buf, tmp_dev_total_size);
- }
-
- delete tmp_buf;
- tmp_buf = NULL;
- }
- }
-*/
-// return 0;
-//}
-
-//int CBlobDeviceE2prom::OpenDevice() {
-/*int device_fd = CC_ERR_FILE_HANDLE;
-
-if (gFilePathBuf == NULL) {
- LOGE("%s, Device file name is NULL.\n", "TV");
- return CC_ERR_FILE_HANDLE;
-}
-
-device_fd = open(gFilePathBuf, O_RDWR);
-if (device_fd < 0) {
- LOGE("%s, Open device file \"%s\" error: %s.\n", "TV", gFilePathBuf, strerror(errno));
- return CC_ERR_FILE_HANDLE;
-}
-
-return device_fd;*/
-// return 0;
-//}
-
-//int CBlobDeviceE2prom::CloseDevice() {
-/*if (*device_fd >= 0) {
- close(*device_fd);
- *device_fd = CC_ERR_FILE_HANDLE;
-}*/
-
-// return 0;
-//}
-
-/*int CBlobDeviceE2prom::SetWriteProtectStatus(int protect_status) {
-}*/
-
-/*int CBlobDeviceE2prom::CheckDeviceWrAvaliable(int offset, int len) {
- int tmp_dev_start_offset = 0;
- int tmp_dev_end_offset = 0;
-
- GetDeviceRWStartOffset(&tmp_dev_start_offset);
- if (tmp_dev_start_offset < 0) {
- LOGE("%s, Device file r/w start offset must be greater than or euqal to 0.\n", "TV");
- return -1;
- }
-
- GetDeviceRWEndOffset(&tmp_dev_end_offset);
- if (tmp_dev_end_offset < 0) {
- LOGE("%s, Device file r/w end offset must be more than 0.\n", "TV");
- return -1;
- }
-
- if (len <= 0) {
- LOGE("%s, The w/r length should be more than 0.\n", "TV");
- return -1;
- }
-
- if ((len + tmp_dev_start_offset + offset) > tmp_dev_end_offset + 1) {
- LOGE("%s, w/r would be overflow!!! len = %d, start offset = %d, offset = %d, end offset = %d.\n", "TV", len, tmp_dev_start_offset, offset, tmp_dev_end_offset);
- return -1;
- }
-
- if (ValidOperateCheck() < 0) {
- return -1;
- }
-
- return 0;
-}
-
-/*int CBlobDeviceE2prom::WriteSpecialBytes(int offset, int len, unsigned char data_buf[]) {
- int i = 0, tmp_ret = 0;
- int tmp_dev_w_page_size = 0;
- int tmp_dev_slave_addr = 0;
- int device_fd = CC_ERR_FILE_HANDLE;
- struct i2c_rdwr_ioctl_data ctl_data;
- struct i2c_msg msg;
- unsigned char msg_buf[E2P_MSG_BUF_SIZE];
-
- //GetDeviceWritePageSize(&tmp_dev_w_page_size);
- //if (len > tmp_dev_w_page_size) {
- // LOGE("%s, The write length should be less than page size(%d).\n", "TV", tmp_dev_w_page_size);
- // return -1;
- //}
-
- if (CheckDeviceWrAvaliable(offset, len) < 0) {
- return -1;
- }
-
- device_fd = OpenDevice();
- if (device_fd == CC_ERR_FILE_HANDLE) {
- return -1;
- }
-
- memset((void *) msg_buf, 0, E2P_MSG_BUF_SIZE);
-
- msg_buf[0] = (unsigned char) (offset >> 8);
- msg_buf[1] = (unsigned char) (offset & 0x00ff);
-
- memcpy((void *) &msg_buf[2], data_buf, len);
-
- //GetDeviceSlaveAddress(&tmp_dev_slave_addr);
-
- //showboz
- msg.addr = //
- //tmp_dev_slave_addr//0;
- msg.flags = I2C_M_WR;
- msg.len = 2 + len;
- msg.buf = msg_buf;
- ctl_data.nmsgs = 1;
- ctl_data.msgs = &msg;
-
- SetWriteProtectStatus (CC_SSM_PROTECT_OFF);
-
- tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
-
- SetWriteProtectStatus (CC_SSM_PROTECT_ON);
-
- if (tmp_ret < 0) {
- LOGE("%s, ioctl failed, error %d (%s).\n", "TV", errno, strerror(errno));
-
- CloseDevice(&device_fd);
- return -1;
- }
-
- if (device_use_buffer && device_buf != NULL) {
- memcpy((void *) (device_buf + offset), (void *) data_buf, len);
- }
-
- CloseDevice(&device_fd);
-
- msleep(10);
-
- return 0;
-}*/
-
-/*int CBlobDeviceE2prom::ReadSpecialBytes(int offset, int len, unsigned char data_buf[]) {
- int i = 0, tmp_ret = 0;
- int device_fd = CC_ERR_FILE_HANDLE;
- int tmp_dev_slave_addr = 0;
- struct i2c_rdwr_ioctl_data ctl_data;
- struct i2c_msg msg;
- unsigned char msg_buf[E2P_MSG_BUF_SIZE];
-
- if (CheckDeviceWrAvaliable(offset, len) < 0) {
- return -1;
- }
-
- if (device_use_buffer && device_buf != NULL) {
- memcpy((void *) data_buf, (void *) (device_buf + offset), len);
- return 0;
- }
-
- device_fd = OpenDevice();
- if (device_fd == CC_ERR_FILE_HANDLE) {
- return -1;
- }
-
- //GetDeviceSlaveAddress(&tmp_dev_slave_addr);
-
- msg_buf[0] = (unsigned char) (offset >> 8);
- msg_buf[1] = (unsigned char) (offset & 0x00ff);
- msg.addr = tmp_dev_slave_addr;
- msg.flags = I2C_M_WR;
- msg.len = 2;
- msg.buf = msg_buf;
- ctl_data.nmsgs = 1;
- ctl_data.msgs = &msg;
-
- tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
-
- if (tmp_ret < 0) {
- LOGE("%s, ioctl failed(erase), error %d (%s).\n", "TV", errno, strerror(errno));
- CloseDevice(&device_fd);
- return -1;
- }
-
- msg.addr = tmp_dev_slave_addr;
- msg.flags |= I2C_M_RD;
- msg.len = len;
- msg.buf = data_buf;
- ctl_data.nmsgs = 1;
- ctl_data.msgs = &msg;
- tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
- if (tmp_ret < 0) {
- LOGE("%s, ioctl failed, error %d (%s).\n", "TV", errno, strerror(errno));
- CloseDevice(&device_fd);
- return -1;
- }
-
- CloseDevice(&device_fd);
-
- msleep(10);
-
- return 0;
-}
-
-int CTvSettingDeviceE2prom::ValidOperateCheck() {
- int tmp_dev_total_size = 0;
- int tmp_dev_start_offset = 0;
- int tmp_dev_end_offset = 0;
-
- if (gFilePathBuf == NULL) {
- LOGE("%s, Device file name is NULL.\n", "TV");
- return -1;
- }
-
- if (IsFileExist(gFilePathBuf) < 0) {
- LOGE("%s, Device file is not exist.\n", "TV");
- return -1;
- }
-
- tmp_dev_total_size = GetDeviceTotalSize();
- if (tmp_dev_total_size < 0) {
- LOGE("%s, Device file total size must be greater than or euqal to 0.\n", "TV");
- return -1;
- }
-
- //GetDeviceRWStartOffset(&tmp_dev_start_offset);
- //if (tmp_dev_start_offset < 0) {
- // LOGE("%s, Device file r/w start offset must be greater than or euqal to 0.\n", "TV");
- // return -1;
- //}
-
- //GetDeviceRWEndOffset(&tmp_dev_end_offset);
- //if (tmp_dev_end_offset < 0) {
- // LOGE("%s, Device file r/w end offset must be more than 0.\n", "TV");
- // return -1;
- //}
-
- //if (tmp_dev_end_offset - tmp_dev_start_offset + 1 > tmp_dev_total_size) {
- // LOGE("%s, end offset (%d) - start offset (%d) + 1 is more than total size(%d).\n", "TV", tmp_dev_end_offset, tmp_dev_start_offset, tmp_dev_total_size);
- // return -1;
- //}
-
- return 0;
-}*/
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <errno.h>
+
+#include "CBlobDeviceE2prom.h"
+#include "../tvconfig/tvconfig.h"
+#include "../tvutils/tvutils.h"
+#include "CTvLog.h"
+
+#define LOG_TAG "CBlobDeviceE2prom"
+
+#define msleep(x) usleep(x*1000)
+
+CBlobDeviceE2prom::CBlobDeviceE2prom()
+{
+
+}
+
+CBlobDeviceE2prom::~CBlobDeviceE2prom()
+{
+}
+
+int CBlobDeviceE2prom::WriteBytes(int offset, int size, unsigned char *buf)
+{
+ return 0;
+}
+int CBlobDeviceE2prom::ReadBytes(int offset, int size, unsigned char *buf)
+{
+ return 0;
+}
+int CBlobDeviceE2prom::EraseAllData()
+{
+ return 0;
+}
+int CBlobDeviceE2prom::InitCheck()
+{
+ return 0;
+}
+int CBlobDeviceE2prom::OpenDevice()
+{
+ return 0;
+}
+int CBlobDeviceE2prom::CloseDevice()
+{
+ return 0;
+}
+//int CBlobDeviceE2prom::InitCheck() {
+/* int i, tmp_dev_total_size = 0, tmp_offset = 0, rw_check_count = 4;
+ unsigned char *tmp_buf = NULL;
+ unsigned char w_ch = 0, r_ch = 0;
+
+ SetWriteProtectStatus (CC_SSM_PROTECT_ON);
+
+ if (ValidOperateCheck() < 0) {
+ return -1;
+ }
+
+ tmp_offset = E2P_DEV_RW_TEST_OFFSET;
+
+ if (tmp_offset >= 0) {
+ for (i = 0; i < rw_check_count; i++) {
+ w_ch = 0x5A;
+ WriteNBytes(tmp_offset, 1, &w_ch);
+
+ r_ch = 0x00;
+ ReadNBytes(tmp_offset, 1, &r_ch);
+
+ if (r_ch != w_ch) {
+ LOGE("%s, Device rw check error, write %d, read %d.\n", "TV", w_ch, r_ch);
+ return -1;
+ }
+
+ w_ch = 0xA5;
+ WriteNBytes(tmp_offset, 1, &w_ch);
+
+ r_ch = 0x00;
+ ReadNBytes(tmp_offset, 1, &r_ch);
+
+ if (r_ch != w_ch) {
+ LOGE("%s, Device rw check error, write %d, read %d.\n", "TV", w_ch, r_ch);
+ return -1;
+ }
+ }
+ }
+
+ if (device_buf != NULL) {
+ delete device_buf;
+ device_buf = NULL;
+ }
+
+ if (device_use_buffer) {
+ tmp_dev_total_size = GetDeviceTotalSize();
+ if (tmp_dev_total_size <= 0) {
+ LOGE("%s, Device file size must be more than 0.\n", "TV");
+ return -1;
+ }
+
+ tmp_buf = new unsigned char[tmp_dev_total_size];
+ if (tmp_buf != NULL) {
+ if (ReadNBytes(0, tmp_dev_total_size, tmp_buf) < 0) {
+ delete tmp_buf;
+ tmp_buf = NULL;
+
+ LOGE("%s, Read data from device error when read data to device rw buffer!!!.\n", "TV");
+ return -1;
+ }
+
+ device_buf = new unsigned char[tmp_dev_total_size];
+ if (device_buf != NULL) {
+ memcpy((void *) device_buf, (void *) tmp_buf, tmp_dev_total_size);
+ }
+
+ delete tmp_buf;
+ tmp_buf = NULL;
+ }
+ }
+*/
+// return 0;
+//}
+
+//int CBlobDeviceE2prom::OpenDevice() {
+/*int device_fd = CC_ERR_FILE_HANDLE;
+
+if (gFilePathBuf == NULL) {
+ LOGE("%s, Device file name is NULL.\n", "TV");
+ return CC_ERR_FILE_HANDLE;
+}
+
+device_fd = open(gFilePathBuf, O_RDWR);
+if (device_fd < 0) {
+ LOGE("%s, Open device file \"%s\" error: %s.\n", "TV", gFilePathBuf, strerror(errno));
+ return CC_ERR_FILE_HANDLE;
+}
+
+return device_fd;*/
+// return 0;
+//}
+
+//int CBlobDeviceE2prom::CloseDevice() {
+/*if (*device_fd >= 0) {
+ close(*device_fd);
+ *device_fd = CC_ERR_FILE_HANDLE;
+}*/
+
+// return 0;
+//}
+
+/*int CBlobDeviceE2prom::SetWriteProtectStatus(int protect_status) {
+}*/
+
+/*int CBlobDeviceE2prom::CheckDeviceWrAvaliable(int offset, int len) {
+ int tmp_dev_start_offset = 0;
+ int tmp_dev_end_offset = 0;
+
+ GetDeviceRWStartOffset(&tmp_dev_start_offset);
+ if (tmp_dev_start_offset < 0) {
+ LOGE("%s, Device file r/w start offset must be greater than or euqal to 0.\n", "TV");
+ return -1;
+ }
+
+ GetDeviceRWEndOffset(&tmp_dev_end_offset);
+ if (tmp_dev_end_offset < 0) {
+ LOGE("%s, Device file r/w end offset must be more than 0.\n", "TV");
+ return -1;
+ }
+
+ if (len <= 0) {
+ LOGE("%s, The w/r length should be more than 0.\n", "TV");
+ return -1;
+ }
+
+ if ((len + tmp_dev_start_offset + offset) > tmp_dev_end_offset + 1) {
+ LOGE("%s, w/r would be overflow!!! len = %d, start offset = %d, offset = %d, end offset = %d.\n", "TV", len, tmp_dev_start_offset, offset, tmp_dev_end_offset);
+ return -1;
+ }
+
+ if (ValidOperateCheck() < 0) {
+ return -1;
+ }
+
+ return 0;
+}
+
+/*int CBlobDeviceE2prom::WriteSpecialBytes(int offset, int len, unsigned char data_buf[]) {
+ int i = 0, tmp_ret = 0;
+ int tmp_dev_w_page_size = 0;
+ int tmp_dev_slave_addr = 0;
+ int device_fd = CC_ERR_FILE_HANDLE;
+ struct i2c_rdwr_ioctl_data ctl_data;
+ struct i2c_msg msg;
+ unsigned char msg_buf[E2P_MSG_BUF_SIZE];
+
+ //GetDeviceWritePageSize(&tmp_dev_w_page_size);
+ //if (len > tmp_dev_w_page_size) {
+ // LOGE("%s, The write length should be less than page size(%d).\n", "TV", tmp_dev_w_page_size);
+ // return -1;
+ //}
+
+ if (CheckDeviceWrAvaliable(offset, len) < 0) {
+ return -1;
+ }
+
+ device_fd = OpenDevice();
+ if (device_fd == CC_ERR_FILE_HANDLE) {
+ return -1;
+ }
+
+ memset((void *) msg_buf, 0, E2P_MSG_BUF_SIZE);
+
+ msg_buf[0] = (unsigned char) (offset >> 8);
+ msg_buf[1] = (unsigned char) (offset & 0x00ff);
+
+ memcpy((void *) &msg_buf[2], data_buf, len);
+
+ //GetDeviceSlaveAddress(&tmp_dev_slave_addr);
+
+ //showboz
+ msg.addr = //
+ //tmp_dev_slave_addr//0;
+ msg.flags = I2C_M_WR;
+ msg.len = 2 + len;
+ msg.buf = msg_buf;
+ ctl_data.nmsgs = 1;
+ ctl_data.msgs = &msg;
+
+ SetWriteProtectStatus (CC_SSM_PROTECT_OFF);
+
+ tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
+
+ SetWriteProtectStatus (CC_SSM_PROTECT_ON);
+
+ if (tmp_ret < 0) {
+ LOGE("%s, ioctl failed, error %d (%s).\n", "TV", errno, strerror(errno));
+
+ CloseDevice(&device_fd);
+ return -1;
+ }
+
+ if (device_use_buffer && device_buf != NULL) {
+ memcpy((void *) (device_buf + offset), (void *) data_buf, len);
+ }
+
+ CloseDevice(&device_fd);
+
+ msleep(10);
+
+ return 0;
+}*/
+
+/*int CBlobDeviceE2prom::ReadSpecialBytes(int offset, int len, unsigned char data_buf[]) {
+ int i = 0, tmp_ret = 0;
+ int device_fd = CC_ERR_FILE_HANDLE;
+ int tmp_dev_slave_addr = 0;
+ struct i2c_rdwr_ioctl_data ctl_data;
+ struct i2c_msg msg;
+ unsigned char msg_buf[E2P_MSG_BUF_SIZE];
+
+ if (CheckDeviceWrAvaliable(offset, len) < 0) {
+ return -1;
+ }
+
+ if (device_use_buffer && device_buf != NULL) {
+ memcpy((void *) data_buf, (void *) (device_buf + offset), len);
+ return 0;
+ }
+
+ device_fd = OpenDevice();
+ if (device_fd == CC_ERR_FILE_HANDLE) {
+ return -1;
+ }
+
+ //GetDeviceSlaveAddress(&tmp_dev_slave_addr);
+
+ msg_buf[0] = (unsigned char) (offset >> 8);
+ msg_buf[1] = (unsigned char) (offset & 0x00ff);
+ msg.addr = tmp_dev_slave_addr;
+ msg.flags = I2C_M_WR;
+ msg.len = 2;
+ msg.buf = msg_buf;
+ ctl_data.nmsgs = 1;
+ ctl_data.msgs = &msg;
+
+ tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
+
+ if (tmp_ret < 0) {
+ LOGE("%s, ioctl failed(erase), error %d (%s).\n", "TV", errno, strerror(errno));
+ CloseDevice(&device_fd);
+ return -1;
+ }
+
+ msg.addr = tmp_dev_slave_addr;
+ msg.flags |= I2C_M_RD;
+ msg.len = len;
+ msg.buf = data_buf;
+ ctl_data.nmsgs = 1;
+ ctl_data.msgs = &msg;
+ tmp_ret = ioctl(device_fd, I2C_RDWR, &ctl_data);
+ if (tmp_ret < 0) {
+ LOGE("%s, ioctl failed, error %d (%s).\n", "TV", errno, strerror(errno));
+ CloseDevice(&device_fd);
+ return -1;
+ }
+
+ CloseDevice(&device_fd);
+
+ msleep(10);
+
+ return 0;
+}
+
+int CTvSettingDeviceE2prom::ValidOperateCheck() {
+ int tmp_dev_total_size = 0;
+ int tmp_dev_start_offset = 0;
+ int tmp_dev_end_offset = 0;
+
+ if (gFilePathBuf == NULL) {
+ LOGE("%s, Device file name is NULL.\n", "TV");
+ return -1;
+ }
+
+ if (IsFileExist(gFilePathBuf) < 0) {
+ LOGE("%s, Device file is not exist.\n", "TV");
+ return -1;
+ }
+
+ tmp_dev_total_size = GetDeviceTotalSize();
+ if (tmp_dev_total_size < 0) {
+ LOGE("%s, Device file total size must be greater than or euqal to 0.\n", "TV");
+ return -1;
+ }
+
+ //GetDeviceRWStartOffset(&tmp_dev_start_offset);
+ //if (tmp_dev_start_offset < 0) {
+ // LOGE("%s, Device file r/w start offset must be greater than or euqal to 0.\n", "TV");
+ // return -1;
+ //}
+
+ //GetDeviceRWEndOffset(&tmp_dev_end_offset);
+ //if (tmp_dev_end_offset < 0) {
+ // LOGE("%s, Device file r/w end offset must be more than 0.\n", "TV");
+ // return -1;
+ //}
+
+ //if (tmp_dev_end_offset - tmp_dev_start_offset + 1 > tmp_dev_total_size) {
+ // LOGE("%s, end offset (%d) - start offset (%d) + 1 is more than total size(%d).\n", "TV", tmp_dev_end_offset, tmp_dev_start_offset, tmp_dev_total_size);
+ // return -1;
+ //}
+
+ return 0;
+}*/