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/android/jni/cfbc_jni.cpp b/tvapi/android/jni/cfbc_jni.cpp
index 7ec7d86..edfb575 100644
--- a/tvapi/android/jni/cfbc_jni.cpp
+++ b/tvapi/android/jni/cfbc_jni.cpp
@@ -23,145 +23,145 @@ static CFbcCommunication *g_cfbc_handle = NULL;
JNIEnv *getJNIEnv(bool *needsDetach)
{
- JNIEnv *env = NULL;
- jint result = -1;
- if (m_vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
- __android_log_print(ANDROID_LOG_INFO, TAG, "ERROR: GetEnv failed\n");
-
- int status = m_vm->AttachCurrentThread(&env, NULL);
- if (status < 0) {
- __android_log_print(ANDROID_LOG_INFO, TAG, "callback_handler: failed to attach current thread");
- return NULL;
- }
-
- *needsDetach = true;
- }
-
- __android_log_print(ANDROID_LOG_INFO, TAG, "GetEnv Success");
- return env;
+ JNIEnv *env = NULL;
+ jint result = -1;
+ if (m_vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
+ __android_log_print(ANDROID_LOG_INFO, TAG, "ERROR: GetEnv failed\n");
+
+ int status = m_vm->AttachCurrentThread(&env, NULL);
+ if (status < 0) {
+ __android_log_print(ANDROID_LOG_INFO, TAG, "callback_handler: failed to attach current thread");
+ return NULL;
+ }
+
+ *needsDetach = true;
+ }
+
+ __android_log_print(ANDROID_LOG_INFO, TAG, "GetEnv Success");
+ return env;
}
void detachJNI()
{
- int result = m_vm->DetachCurrentThread();
- if (result != JNI_OK) {
- __android_log_print(ANDROID_LOG_INFO, TAG, "thread detach failed: %#x", result);
- }
+ int result = m_vm->DetachCurrentThread();
+ if (result != JNI_OK) {
+ __android_log_print(ANDROID_LOG_INFO, TAG, "thread detach failed: %#x", result);
+ }
}
//this data buf is same as cmd buf
void java_jni_callback(char *str, int cnt, int data_buf[])
{
- char temp_str[MAX_CNT];
- int idx = 0;
- if (str != NULL && cnt > 0) {
- memset(temp_str, 0, sizeof(temp_str));
- JNI_DBG("java jni string is:\n%s, cnt:%d.", str, cnt);
- //strcpy(temp_str, "Call From C/C++!");
- memcpy(temp_str, str, strlen(str) % MAX_CNT);
-
- if (NULL != jni_local_obj) {
- bool needsDetach = false;
- jint j_cnt = data_buf[1];
- jint j_data_buf[MAX_CNT];
- for (idx = 0; idx < j_cnt; idx++) {
- idx %= MAX_CNT;
- j_data_buf[idx] = data_buf[idx];
- JNI_DBG("java_jni_callback the %d data is:0x%x, %d.", idx, j_data_buf[idx], data_buf[idx]);
- }
-
- //jobject obj;
- jni_local_env = getJNIEnv(&needsDetach);
- //obj = (*jni_local_env)->NewGlobalRef(jni_local_env,jni_local_obj);
- jni_local_clz = jni_local_env->GetObjectClass(jni_local_obj);
- //this func name and parameters should be same as the callback defined in java code
- jni_local_mid = jni_local_env->GetMethodID(jni_local_clz, "android_java_callback", "(Ljava/lang/String;[I)I");
-
- jstring str1 = jni_local_env->NewStringUTF(temp_str);
-
- jintArray cc_data_arr = jni_local_env->NewIntArray(j_cnt);
- jni_local_env->SetIntArrayRegion(cc_data_arr, 0, cnt, j_data_buf);
- //jint *temp_data = jni_local_env->GetIntArrayElements(cc_data_arr, NULL);
-
- jint cnt = jni_local_env->CallIntMethod(jni_local_obj, jni_local_mid, str1, cc_data_arr);
-
- //jni_local_env->ReleaseIntArrayElements(cc_data_arr, temp_data, 0);
- //jni_local_env->ReleaseIntArrayElements(cc_cmd_arr, temp_cmd, 0);
- JNI_DBG("%s %d be called.", __FUNCTION__, __LINE__);
-
- if (needsDetach) {
- detachJNI();
- }
- }
- }
+ char temp_str[MAX_CNT];
+ int idx = 0;
+ if(str != NULL && cnt > 0) {
+ memset(temp_str, 0, sizeof(temp_str));
+ JNI_DBG("java jni string is:\n%s, cnt:%d.", str, cnt);
+ //strcpy(temp_str, "Call From C/C++!");
+ memcpy(temp_str, str, strlen(str) % MAX_CNT);
+
+ if(NULL != jni_local_obj) {
+ bool needsDetach = false;
+ jint j_cnt = data_buf[1];
+ jint j_data_buf[MAX_CNT];
+ for(idx = 0; idx < j_cnt; idx++) {
+ idx %= MAX_CNT;
+ j_data_buf[idx] = data_buf[idx];
+ JNI_DBG("java_jni_callback the %d data is:0x%x, %d.", idx, j_data_buf[idx], data_buf[idx]);
+ }
+
+ //jobject obj;
+ jni_local_env = getJNIEnv(&needsDetach);
+ //obj = (*jni_local_env)->NewGlobalRef(jni_local_env,jni_local_obj);
+ jni_local_clz = jni_local_env->GetObjectClass(jni_local_obj);
+ //this func name and parameters should be same as the callback defined in java code
+ jni_local_mid = jni_local_env->GetMethodID(jni_local_clz, "android_java_callback", "(Ljava/lang/String;[I)I");
+
+ jstring str1 = jni_local_env->NewStringUTF(temp_str);
+
+ jintArray cc_data_arr = jni_local_env->NewIntArray(j_cnt);
+ jni_local_env->SetIntArrayRegion(cc_data_arr, 0, cnt, j_data_buf);
+ //jint *temp_data = jni_local_env->GetIntArrayElements(cc_data_arr, NULL);
+
+ jint cnt = jni_local_env->CallIntMethod(jni_local_obj, jni_local_mid, str1, cc_data_arr);
+
+ //jni_local_env->ReleaseIntArrayElements(cc_data_arr, temp_data, 0);
+ //jni_local_env->ReleaseIntArrayElements(cc_cmd_arr, temp_cmd, 0);
+ JNI_DBG("%s %d be called.", __FUNCTION__, __LINE__);
+
+ if(needsDetach) {
+ detachJNI();
+ }
+ }
+ }
}
//here we needn't to match the java package name
static jint jni_java_exec_cmd(JNIEnv *env, jobject obj, jintArray cmdArray)
{
- jint *arry = env->GetIntArrayElements(cmdArray, NULL);
- jint length = env->GetArrayLength(cmdArray);
+ jint *arry = env->GetIntArrayElements(cmdArray, NULL);
+ jint length = env->GetArrayLength(cmdArray);
- int cmd_cnt = arry[1], idx = 0;
- int cmd_array[MAX_CNT];
- memset(cmd_array, 0, sizeof(cmd_array));
- for (idx = 0; idx < cmd_cnt; idx++)
- cmd_array[idx] = arry[idx];
+ int cmd_cnt = arry[1], idx = 0;
+ int cmd_array[MAX_CNT];
+ memset(cmd_array, 0, sizeof(cmd_array));
+ for(idx = 0; idx < cmd_cnt; idx++)
+ cmd_array[idx] = arry[idx];
- JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
+ JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
- if (g_cfbc_handle == NULL) {
- g_cfbc_handle = new CFbcCommunication();
- g_cfbc_handle->run("cfbc_thread", 0, 0);
- }
+ if(g_cfbc_handle == NULL) {
+ g_cfbc_handle = new CFbcCommunication();
+ g_cfbc_handle->run("cfbc_thread", 0, 0);
+ }
- //g_cfbc_handle->handleCmd(COMM_DEV_CEC, cmd_array);
- //c_exec_cmd(cmd_array);
+ //g_cfbc_handle->handleCmd(COMM_DEV_CEC, cmd_array);
+ //c_exec_cmd(cmd_array);
- if (NULL == jni_local_obj) {
- jni_local_obj = env->NewGlobalRef(obj);
- }
+ if(NULL == jni_local_obj) {
+ jni_local_obj = env->NewGlobalRef(obj);
+ }
#if 0
- /* this is used to terminate the jni call if needed
- ** and we should handle the pthread we create in c layer
- */
- if (cmd_array[0] == 0x1002) {
- if (NULL != jni_local_obj)
- env->DeleteGlobalRef(jni_local_obj);
- }
+ /* this is used to terminate the jni call if needed
+ ** and we should handle the pthread we create in c layer
+ */
+ if(cmd_array[0] == 0x1002) {
+ if(NULL != jni_local_obj)
+ env->DeleteGlobalRef(jni_local_obj);
+ }
#endif
- return 0;
+ return 0;
}
//the name of 'exec_cmd' should be same as the native func in java code
static JNINativeMethod gMethods[] = {
- {"exec_cmd", "([I)I", (void *)jni_java_exec_cmd},
+ {"exec_cmd", "([I)I", (void *)jni_java_exec_cmd},
};
static int register_android_MyFunc(JNIEnv *env)
{
- JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
- //the name below should be same as the class name in which native method declared in Java layer
- return android::AndroidRuntime::registerNativeMethods(env, "com/fbc/MyFunc", gMethods, NELEM(gMethods));
+ JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
+ //the name below should be same as the class name in which native method declared in Java layer
+ return android::AndroidRuntime::registerNativeMethods(env, "com/fbc/MyFunc", gMethods, NELEM(gMethods));
}
jint JNI_OnLoad(JavaVM *vm, void *reserved)
{
- JNIEnv *env = NULL;
- JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
- //c_set_callback(&java_jni_callback);
- if (vm->GetEnv((void **)&env, JNI_VERSION_1_4) != JNI_OK) {
- JNI_DBG("Error GetEnv\n");
- return -1;
- }
-
- assert(env != NULL);
- if (register_android_MyFunc(env) < 0) {
- JNI_DBG("register_android_test_hdi error.\n");
- return -1;
- }
-
- m_vm = vm;
- return JNI_VERSION_1_4;
+ JNIEnv *env = NULL;
+ JNI_DBG("%s %s %d be called.", __FILE__, __FUNCTION__, __LINE__);
+ //c_set_callback(&java_jni_callback);
+ if (vm->GetEnv((void **)&env, JNI_VERSION_1_4) != JNI_OK) {
+ JNI_DBG("Error GetEnv\n");
+ return -1;
+ }
+
+ assert(env != NULL);
+ if (register_android_MyFunc(env) < 0) {
+ JNI_DBG("register_android_test_hdi error.\n");
+ return -1;
+ }
+
+ m_vm = vm;
+ return JNI_VERSION_1_4;
}