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/tvtests/ssm_test.cpp b/tvapi/tvtests/ssm_test.cpp
index 44b0aea..1ac0e8f 100644
--- a/tvapi/tvtests/ssm_test.cpp
+++ b/tvapi/tvtests/ssm_test.cpp
@@ -1,210 +1,210 @@
-#include <stdio.h>
-#include <unistd.h>
-#include <string.h>
-#include <fcntl.h>
-#include <errno.h>
-#include <android/log.h>
-
-#include "ssm_api.h"
-
-#define LOG_TAG "ssm_test"
-#include "CTvLog.h"
-
-// The follow is R/W test struct declare.
-// The size of it is 11 when it aligned with 1 Byte
-// and is 16 when it aligned with 4 Bytes.
-// You should use the 1 Byte aligned mode when R/W ssm by using struct.
-
-#if 1 // memory aligned with 1 Bytes
-typedef struct tagS_TEST_STRUCT {
- char tmp_ch0;
- char tmp_ch1;
- int tmp_val0;
- unsigned char tmp_ch2;
- unsigned char tmp_ch3;
- unsigned char tmp_ch4;
- short tmp_short0;
-} __attribute__((packed)) S_TEST_STRUCT;
-#else // memory aligned with 4 Bytes
-typedef struct tagS_TEST_STRUCT {
- char tmp_ch0;
- char tmp_ch1;
- int tmp_val0;
- unsigned char tmp_ch2;
- unsigned char tmp_ch3;
- unsigned char tmp_ch4;
- short tmp_short0;
-} S_TEST_STRUCT;
-#endif
-
-static void TestRWOneByte(int tmp_rw_offset, int tmp_w_val, unsigned char tmp_w_ch);
-static void TestRWNBytes(int tmp_rw_offset);
-static void TestRWOneStruct(int tmp_rw_offset);
-
-int main()
-{
- TestRWOneByte(0, 1, -1);
- TestRWOneByte(1, 2, -2);
- TestRWOneByte(30, 3, -3);
- TestRWOneByte(31, -1, 1);
- TestRWOneByte(32, -2, 2);
- TestRWOneByte(33, -3, 3);
-
- TestRWNBytes(31);
-
- TestRWOneStruct(0);
-}
-
-static void TestRWOneByte(int tmp_rw_offset, int tmp_w_val, unsigned char tmp_w_ch)
-{
- int tmp_r_val = 0;
- unsigned char tmp_r_ch = 0;
-
- LOGD("\n\n");
- LOGD("**************Test R/W One Byte **************\n\n");
-
- LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
-
- SSMWriteOneByte(tmp_rw_offset, tmp_w_ch);
- SSMReadOneByte(tmp_rw_offset, &tmp_r_ch);
- LOGD("tmp_w_ch = %d, tmp_r_ch = %d.\n", tmp_w_ch, tmp_r_ch);
-
- SSMWriteOneByte(tmp_rw_offset, tmp_w_val);
- SSMReadOneByte(tmp_rw_offset, &tmp_r_val);
- LOGD("tmp_w_val = %d, tmp_r_val = %d.\n", tmp_w_val, tmp_r_val);
-}
-
-static void TestRWNBytes(int tmp_rw_offset)
-{
- int i = 0, tmp_op_buf_size = 0;
- int device_size = 0, tmp_w_page_size = 0, tmp_r_page_size = 0;
- int *tmp_op_int_w_buf = NULL, *tmp_op_int_r_buf = NULL;
- unsigned char *tmp_op_char_w_buf = NULL, *tmp_op_char_r_buf = NULL;
-
- LOGD("\n\n");
- LOGD("**************Test R/W N Bytes **************\n\n");
-
- SSMGetDeviceTotalSize(&device_size);
- SSMGetDeviceWritePageSize(&tmp_w_page_size);
- SSMGetDeviceReadPageSize(&tmp_r_page_size);
-
- if (tmp_w_page_size < tmp_r_page_size) {
- tmp_op_buf_size = tmp_w_page_size * 2 / 3;
- } else if (tmp_r_page_size < tmp_w_page_size) {
- tmp_op_buf_size = tmp_r_page_size * 2 / 3;
- } else {
- tmp_op_buf_size = tmp_w_page_size;
- }
-
- if (tmp_op_buf_size > device_size) {
- tmp_op_buf_size = device_size;
- }
-
- if (tmp_op_buf_size > 0) {
- LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
-
- tmp_op_char_w_buf = new unsigned char[tmp_op_buf_size];
- if (tmp_op_char_w_buf != NULL) {
- tmp_op_char_r_buf = new unsigned char[tmp_op_buf_size];
- if (tmp_op_char_r_buf != NULL) {
- for (i = 0; i < tmp_op_buf_size; i++) {
- tmp_op_char_w_buf[i] = (tmp_op_buf_size / 2) - i;
- LOGD("tmp_op_char_w_buf[%d] = %d\n", i, tmp_op_char_w_buf[i]);
- }
- SSMWriteNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_char_w_buf);
-
- for (i = 0; i < tmp_op_buf_size; i++) {
- tmp_op_char_r_buf[i] = 0;
- }
- SSMReadNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_char_r_buf);
-
- for (i = 0; i < tmp_op_buf_size; i++) {
- LOGD("tmp_op_char_r_buf[%d] = %d\n", i, tmp_op_char_r_buf[i]);
- }
-
- delete tmp_op_char_r_buf;
- tmp_op_char_r_buf = NULL;
- }
-
- delete tmp_op_char_w_buf;
- tmp_op_char_w_buf = NULL;
- }
-
- tmp_op_int_w_buf = new int[tmp_op_buf_size];
- if (tmp_op_int_w_buf != NULL) {
- tmp_op_int_r_buf = new int[tmp_op_buf_size];
- if (tmp_op_int_r_buf != NULL) {
- for (i = 0; i < tmp_op_buf_size; i++) {
- tmp_op_int_w_buf[i] = (tmp_op_buf_size / 2) - i;
- LOGD("tmp_op_int_w_buf[%d] = %d\n", i, tmp_op_int_w_buf[i]);
- }
- SSMWriteNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_int_w_buf);
-
- for (i = 0; i < tmp_op_buf_size; i++) {
- tmp_op_int_r_buf[i] = 0;
- }
- SSMReadNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_int_r_buf);
-
- for (i = 0; i < tmp_op_buf_size; i++) {
- LOGD("tmp_op_int_r_buf[%d] = %d\n", i, tmp_op_int_r_buf[i]);
- }
-
- delete tmp_op_int_r_buf;
- tmp_op_int_r_buf = NULL;
- }
-
- delete tmp_op_int_w_buf;
- tmp_op_int_w_buf = NULL;
- }
- }
-}
-
-static void TestRWOneStruct(int tmp_rw_offset)
-{
- S_TEST_STRUCT TestWriteStruct, TestReadStruct;
-
- LOGD("\n\n");
- LOGD("**************Test R/W One Struct **************\n\n");
-
- LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
-
- TestWriteStruct.tmp_ch0 = -9;
- TestWriteStruct.tmp_ch1 = -8;
- TestWriteStruct.tmp_val0 = 9;
- TestWriteStruct.tmp_ch2 = 255;
- TestWriteStruct.tmp_ch3 = 254;
- TestWriteStruct.tmp_ch4 = 250;
- TestWriteStruct.tmp_short0 = -9;
-
- SSMWriteNTypes(tmp_rw_offset, sizeof(S_TEST_STRUCT), (unsigned char *) &TestWriteStruct);
-
- LOGD("\n\n");
- LOGD("write struct length = %d.\n", sizeof(S_TEST_STRUCT));
- LOGD("TestWriteStruct.tmp_ch0 = %d.\n", TestWriteStruct.tmp_ch0);
- LOGD("TestWriteStruct.tmp_ch1 = %d.\n", TestWriteStruct.tmp_ch1);
- LOGD("TestWriteStruct.tmp_val0 = %d.\n", TestWriteStruct.tmp_val0);
- LOGD("TestWriteStruct.tmp_ch2 = %d.\n", TestWriteStruct.tmp_ch2);
- LOGD("TestWriteStruct.tmp_ch3 = %d.\n", TestWriteStruct.tmp_ch3);
- LOGD("TestWriteStruct.tmp_ch4 = %d.\n", TestWriteStruct.tmp_ch4);
- LOGD("TestWriteStruct.tmp_short0 = %d.\n", TestWriteStruct.tmp_short0);
-
- TestReadStruct.tmp_ch0 = 0;
- TestReadStruct.tmp_ch1 = 0;
- TestReadStruct.tmp_val0 = 0;
- TestReadStruct.tmp_ch2 = 0;
- TestReadStruct.tmp_ch3 = 0;
- TestWriteStruct.tmp_ch4 = 0;
- TestWriteStruct.tmp_short0 = 0;
-
- SSMReadNTypes(tmp_rw_offset, sizeof(S_TEST_STRUCT), (unsigned char *) &TestReadStruct);
-
- LOGD("\n\n");
- LOGD("read struct length = %d.\n", sizeof(S_TEST_STRUCT));
- LOGD("TestReadStruct.tmp_ch0 = %d.\n", TestReadStruct.tmp_ch0);
- LOGD("TestReadStruct.tmp_ch1 = %d.\n", TestReadStruct.tmp_ch1);
- LOGD("TestReadStruct.tmp_val0 = %d.\n", TestReadStruct.tmp_val0);
- LOGD("TestReadStruct.tmp_ch2 = %d.\n", TestReadStruct.tmp_ch2);
- LOGD("TestReadStruct.tmp_ch3 = %d.\n", TestReadStruct.tmp_ch3);
- LOGD("TestReadStruct.tmp_ch4 = %d.\n", TestReadStruct.tmp_ch4);
- LOGD("TestReadStruct.tmp_short0 = %d.\n", TestReadStruct.tmp_short0);
-}
+#include <stdio.h>
+#include <unistd.h>
+#include <string.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <android/log.h>
+
+#include "ssm_api.h"
+
+#define LOG_TAG "ssm_test"
+#include "CTvLog.h"
+
+// The follow is R/W test struct declare.
+// The size of it is 11 when it aligned with 1 Byte
+// and is 16 when it aligned with 4 Bytes.
+// You should use the 1 Byte aligned mode when R/W ssm by using struct.
+
+#if 1 // memory aligned with 1 Bytes
+typedef struct tagS_TEST_STRUCT {
+ char tmp_ch0;
+ char tmp_ch1;
+ int tmp_val0;
+ unsigned char tmp_ch2;
+ unsigned char tmp_ch3;
+ unsigned char tmp_ch4;
+ short tmp_short0;
+} __attribute__((packed)) S_TEST_STRUCT;
+#else // memory aligned with 4 Bytes
+typedef struct tagS_TEST_STRUCT {
+ char tmp_ch0;
+ char tmp_ch1;
+ int tmp_val0;
+ unsigned char tmp_ch2;
+ unsigned char tmp_ch3;
+ unsigned char tmp_ch4;
+ short tmp_short0;
+} S_TEST_STRUCT;
+#endif
+
+static void TestRWOneByte(int tmp_rw_offset, int tmp_w_val, unsigned char tmp_w_ch);
+static void TestRWNBytes(int tmp_rw_offset);
+static void TestRWOneStruct(int tmp_rw_offset);
+
+int main()
+{
+ TestRWOneByte(0, 1, -1);
+ TestRWOneByte(1, 2, -2);
+ TestRWOneByte(30, 3, -3);
+ TestRWOneByte(31, -1, 1);
+ TestRWOneByte(32, -2, 2);
+ TestRWOneByte(33, -3, 3);
+
+ TestRWNBytes(31);
+
+ TestRWOneStruct(0);
+}
+
+static void TestRWOneByte(int tmp_rw_offset, int tmp_w_val, unsigned char tmp_w_ch)
+{
+ int tmp_r_val = 0;
+ unsigned char tmp_r_ch = 0;
+
+ LOGD("\n\n");
+ LOGD("**************Test R/W One Byte **************\n\n");
+
+ LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
+
+ SSMWriteOneByte(tmp_rw_offset, tmp_w_ch);
+ SSMReadOneByte(tmp_rw_offset, &tmp_r_ch);
+ LOGD("tmp_w_ch = %d, tmp_r_ch = %d.\n", tmp_w_ch, tmp_r_ch);
+
+ SSMWriteOneByte(tmp_rw_offset, tmp_w_val);
+ SSMReadOneByte(tmp_rw_offset, &tmp_r_val);
+ LOGD("tmp_w_val = %d, tmp_r_val = %d.\n", tmp_w_val, tmp_r_val);
+}
+
+static void TestRWNBytes(int tmp_rw_offset)
+{
+ int i = 0, tmp_op_buf_size = 0;
+ int device_size = 0, tmp_w_page_size = 0, tmp_r_page_size = 0;
+ int *tmp_op_int_w_buf = NULL, *tmp_op_int_r_buf = NULL;
+ unsigned char *tmp_op_char_w_buf = NULL, *tmp_op_char_r_buf = NULL;
+
+ LOGD("\n\n");
+ LOGD("**************Test R/W N Bytes **************\n\n");
+
+ SSMGetDeviceTotalSize(&device_size);
+ SSMGetDeviceWritePageSize(&tmp_w_page_size);
+ SSMGetDeviceReadPageSize(&tmp_r_page_size);
+
+ if (tmp_w_page_size < tmp_r_page_size) {
+ tmp_op_buf_size = tmp_w_page_size * 2 / 3;
+ } else if (tmp_r_page_size < tmp_w_page_size) {
+ tmp_op_buf_size = tmp_r_page_size * 2 / 3;
+ } else {
+ tmp_op_buf_size = tmp_w_page_size;
+ }
+
+ if (tmp_op_buf_size > device_size) {
+ tmp_op_buf_size = device_size;
+ }
+
+ if (tmp_op_buf_size > 0) {
+ LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
+
+ tmp_op_char_w_buf = new unsigned char[tmp_op_buf_size];
+ if (tmp_op_char_w_buf != NULL) {
+ tmp_op_char_r_buf = new unsigned char[tmp_op_buf_size];
+ if (tmp_op_char_r_buf != NULL) {
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ tmp_op_char_w_buf[i] = (tmp_op_buf_size / 2) - i;
+ LOGD("tmp_op_char_w_buf[%d] = %d\n", i, tmp_op_char_w_buf[i]);
+ }
+ SSMWriteNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_char_w_buf);
+
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ tmp_op_char_r_buf[i] = 0;
+ }
+ SSMReadNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_char_r_buf);
+
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ LOGD("tmp_op_char_r_buf[%d] = %d\n", i, tmp_op_char_r_buf[i]);
+ }
+
+ delete tmp_op_char_r_buf;
+ tmp_op_char_r_buf = NULL;
+ }
+
+ delete tmp_op_char_w_buf;
+ tmp_op_char_w_buf = NULL;
+ }
+
+ tmp_op_int_w_buf = new int[tmp_op_buf_size];
+ if (tmp_op_int_w_buf != NULL) {
+ tmp_op_int_r_buf = new int[tmp_op_buf_size];
+ if (tmp_op_int_r_buf != NULL) {
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ tmp_op_int_w_buf[i] = (tmp_op_buf_size / 2) - i;
+ LOGD("tmp_op_int_w_buf[%d] = %d\n", i, tmp_op_int_w_buf[i]);
+ }
+ SSMWriteNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_int_w_buf);
+
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ tmp_op_int_r_buf[i] = 0;
+ }
+ SSMReadNTypes(tmp_rw_offset, tmp_op_buf_size, tmp_op_int_r_buf);
+
+ for (i = 0; i < tmp_op_buf_size; i++) {
+ LOGD("tmp_op_int_r_buf[%d] = %d\n", i, tmp_op_int_r_buf[i]);
+ }
+
+ delete tmp_op_int_r_buf;
+ tmp_op_int_r_buf = NULL;
+ }
+
+ delete tmp_op_int_w_buf;
+ tmp_op_int_w_buf = NULL;
+ }
+ }
+}
+
+static void TestRWOneStruct(int tmp_rw_offset)
+{
+ S_TEST_STRUCT TestWriteStruct, TestReadStruct;
+
+ LOGD("\n\n");
+ LOGD("**************Test R/W One Struct **************\n\n");
+
+ LOGD("tmp_rw_offset = %d.\n", tmp_rw_offset);
+
+ TestWriteStruct.tmp_ch0 = -9;
+ TestWriteStruct.tmp_ch1 = -8;
+ TestWriteStruct.tmp_val0 = 9;
+ TestWriteStruct.tmp_ch2 = 255;
+ TestWriteStruct.tmp_ch3 = 254;
+ TestWriteStruct.tmp_ch4 = 250;
+ TestWriteStruct.tmp_short0 = -9;
+
+ SSMWriteNTypes(tmp_rw_offset, sizeof(S_TEST_STRUCT), (unsigned char *) &TestWriteStruct);
+
+ LOGD("\n\n");
+ LOGD("write struct length = %d.\n", sizeof(S_TEST_STRUCT));
+ LOGD("TestWriteStruct.tmp_ch0 = %d.\n", TestWriteStruct.tmp_ch0);
+ LOGD("TestWriteStruct.tmp_ch1 = %d.\n", TestWriteStruct.tmp_ch1);
+ LOGD("TestWriteStruct.tmp_val0 = %d.\n", TestWriteStruct.tmp_val0);
+ LOGD("TestWriteStruct.tmp_ch2 = %d.\n", TestWriteStruct.tmp_ch2);
+ LOGD("TestWriteStruct.tmp_ch3 = %d.\n", TestWriteStruct.tmp_ch3);
+ LOGD("TestWriteStruct.tmp_ch4 = %d.\n", TestWriteStruct.tmp_ch4);
+ LOGD("TestWriteStruct.tmp_short0 = %d.\n", TestWriteStruct.tmp_short0);
+
+ TestReadStruct.tmp_ch0 = 0;
+ TestReadStruct.tmp_ch1 = 0;
+ TestReadStruct.tmp_val0 = 0;
+ TestReadStruct.tmp_ch2 = 0;
+ TestReadStruct.tmp_ch3 = 0;
+ TestWriteStruct.tmp_ch4 = 0;
+ TestWriteStruct.tmp_short0 = 0;
+
+ SSMReadNTypes(tmp_rw_offset, sizeof(S_TEST_STRUCT), (unsigned char *) &TestReadStruct);
+
+ LOGD("\n\n");
+ LOGD("read struct length = %d.\n", sizeof(S_TEST_STRUCT));
+ LOGD("TestReadStruct.tmp_ch0 = %d.\n", TestReadStruct.tmp_ch0);
+ LOGD("TestReadStruct.tmp_ch1 = %d.\n", TestReadStruct.tmp_ch1);
+ LOGD("TestReadStruct.tmp_val0 = %d.\n", TestReadStruct.tmp_val0);
+ LOGD("TestReadStruct.tmp_ch2 = %d.\n", TestReadStruct.tmp_ch2);
+ LOGD("TestReadStruct.tmp_ch3 = %d.\n", TestReadStruct.tmp_ch3);
+ LOGD("TestReadStruct.tmp_ch4 = %d.\n", TestReadStruct.tmp_ch4);
+ LOGD("TestReadStruct.tmp_short0 = %d.\n", TestReadStruct.tmp_short0);
+}