summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk14
-rw-r--r--screen_source/Android.mk31
-rw-r--r--screen_source/aml_screen.cpp296
-rw-r--r--screen_source/v4l2_vdin.cpp676
-rw-r--r--screen_source/v4l2_vdin.h144
-rw-r--r--tv_callback.h18
-rw-r--r--tv_input.cpp263
-rw-r--r--tvapi/android/Android.mk2
-rw-r--r--tvapi/android/include/ITv.h98
-rw-r--r--tvapi/android/include/ITvClient.h56
-rw-r--r--tvapi/android/include/ITvService.h66
-rw-r--r--tvapi/android/include/Tv.h158
-rw-r--r--tvapi/android/include/tvcmd.h1212
-rw-r--r--tvapi/android/jni/Android.mk135
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp18
-rw-r--r--tvapi/android/jni/cfbc_test.cpp86
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp (renamed from tvapi/android/jni/android_amlogic_tv.cpp)929
-rw-r--r--tvapi/android/libtvbinder/Android.mk48
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp292
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp116
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp100
-rw-r--r--tvapi/android/libtvbinder/Tv.cpp378
-rw-r--r--tvapi/android/tv/Android.mk23
-rw-r--r--tvapi/android/tv/CTv.cpp104
-rw-r--r--tvapi/android/tv/CTv.h54
-rw-r--r--tvapi/android/tvserver/Android.mk164
-rw-r--r--tvapi/android/tvserver/TvService.cpp8911
-rw-r--r--tvapi/android/tvserver/TvService.h170
-rw-r--r--tvapi/android/tvserver/main.cpp46
-rw-r--r--tvapi/android/tvserver/tv_callback.h18
-rw-r--r--[-rwxr-xr-x]tvapi/build/include/.gitignore0
-rw-r--r--tvapi/build/include/xxxconfig.h1
-rw-r--r--tvapi/docs/tv.uml12156
-rw-r--r--tvapi/libtv/Android.mk12
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp126
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h31
-rw-r--r--tvapi/libtv/audio/CTvAudio.cpp30
-rw-r--r--tvapi/libtv/audio/CTvAudio.h76
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp2073
-rw-r--r--tvapi/libtv/audio/audio_alsa.h257
-rw-r--r--tvapi/libtv/audio/audio_android.cpp1035
-rw-r--r--tvapi/libtv/audio/audio_android.h78
-rw-r--r--tvapi/libtv/audio/audio_android_effect.cpp591
-rw-r--r--tvapi/libtv/audio/audio_android_effect.h65
-rw-r--r--tvapi/libtv/audio/audio_api.cpp2470
-rw-r--r--tvapi/libtv/audio/audio_api.h323
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp356
-rw-r--r--tvapi/libtv/audio/audio_effect.h58
-rw-r--r--tvapi/libtv/include/amstream.h526
-rw-r--r--tvapi/libtv/include/amvecm.h136
-rw-r--r--tvapi/libtv/include/cm.h308
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h316
-rw-r--r--tvapi/libtv/include/ve.h461
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp425
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp150
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h41
-rw-r--r--tvapi/libtv/tv/CAv.cpp116
-rw-r--r--tvapi/libtv/tv/CAv.h24
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp443
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h25
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp198
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h19
-rw-r--r--tvapi/libtv/tv/CTv.cpp13003
-rw-r--r--tvapi/libtv/tv/CTv.h1453
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp324
-rw-r--r--tvapi/libtv/tv/CTvBooking.h166
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp24
-rw-r--r--tvapi/libtv/tv/CTvEv.h12
-rw-r--r--tvapi/libtv/tv/CTvLog.h8
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp552
-rw-r--r--tvapi/libtv/tv/CTvRecord.h92
-rw-r--r--tvapi/libtv/tv/CTvSatellite.h42
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp335
-rw-r--r--tvapi/libtv/tv/CTvScanner.h26
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1279
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h351
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp361
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h484
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp6
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp4
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h282
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp379
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp706
-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.h574
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp25
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h188
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp86
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h194
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp483
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h170
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp88
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h60
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1806
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h1066
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp366
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h84
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp38
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp478
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h73
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp203
-rw-r--r--tvapi/libtv/tvin/CTvin.h191
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp54
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h100
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp403
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h152
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp160
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h52
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp258
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h74
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp4658
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.h30
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingCfg.h782
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp10
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp2726
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.h64
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp2575
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.h239
-rw-r--r--tvapi/libtv/tvutils/CCondition.h2
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp65
-rw-r--r--tvapi/libtv/tvutils/CFile.h3
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp2
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp31
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h3
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h96
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp18
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp8
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h12
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp2
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp25
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h4
-rw-r--r--tvapi/libtv/tvutils/serial_base.h34
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp66
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h70
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp3931
-rw-r--r--tvapi/libtv/tvutils/tvutils.h222
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp2
-rw-r--r--tvapi/libtv/version/version.cpp188
-rw-r--r--tvapi/libtv/version/version.h22
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp3509
-rw-r--r--tvapi/libtv/vpp/CPQdb.h340
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp5602
-rw-r--r--tvapi/libtv/vpp/CVpp.h230
-rw-r--r--tvapi/tvtests/Android.mk98
-rw-r--r--tvapi/tvtests/android_tvtest.cpp2
-rw-r--r--tvapi/tvtests/comm_test.cpp4
-rw-r--r--tvapi/tvtests/ssm_test.cpp420
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp854
151 files changed, 45277 insertions, 47437 deletions
diff --git a/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp b/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
index 849c634..246f2ad 100644
--- a/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
+++ b/tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp
@@ -1,353 +1,50 @@
-#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"
+
+
+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() {
+