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/android_amlogic_tv.cpp b/tvapi/android/jni/android_amlogic_tv.cpp
index ec531ef..28dc318 100644
--- a/tvapi/android/jni/android_amlogic_tv.cpp
+++ b/tvapi/android/jni/android_amlogic_tv.cpp
@@ -1,456 +1,455 @@
-#define LOG_TAG "Tv-JNI"
-#include <utils/Log.h>
-
-#include "jni.h"
-#include "JNIHelp.h"
-#include "android_runtime/AndroidRuntime.h"
-#include <utils/Vector.h>
-#include <include/Tv.h>
-#include <binder/IMemory.h>
-#include <binder/Parcel.h>
-#include <binder/MemoryHeapBase.h>
-#include <binder/MemoryBase.h>
-#include <core/SkBitmap.h>
-#include "android_util_Binder.h"
-#include "android_os_Parcel.h"
-using namespace android;
-
-struct fields_t {
- jfieldID context;
- jmethodID post_event;
-};
-
-#ifdef LOG_TAG
-#undef LOG_TAG
-#define LOG_TAG "TvJNI"
-#endif
-
-static fields_t fields;
-static Mutex sLock;
-class JNITvContext: public TvListener
-{
-public:
- JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<Tv> &tv);
- ~JNITvContext()
- {
- release();
- }
- virtual void notify(int32_t msgType, const Parcel &p);
- void addCallbackBuffer(JNIEnv *env, jbyteArray cbb);
- sp<Tv> getTv()
- {
- Mutex::Autolock _l(mLock);
- return mTv;
- }
- void release();
- Parcel *mExtParcel;
-private:
- jobject mTvJObjectWeak; // weak reference to java object
- jclass mTvJClass; // strong reference to java class
- sp<Tv> mTv; // strong reference to native object
- Mutex mLock;
-
- Vector<jbyteArray> mCallbackBuffers; // Global reference application managed byte[]
- bool mManualBufferMode; // Whether to use application managed buffers.
- bool mManualTvCallbackSet; // Whether the callback has been set, used to reduce unnecessary calls to set the callback.
-};
-
-sp<Tv> get_native_tv(JNIEnv *env, jobject thiz, JNITvContext **pContext)
-{
- sp<Tv> tv;
- Mutex::Autolock _l(sLock);
- JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
- if (context != NULL) {
- tv = context->getTv();
- }
- if (tv == 0) {
- jniThrowException(env, "java/lang/RuntimeException", "Method called after release()");
- }
-
- if (pContext != NULL) *pContext = context;
- return tv;
-}
-
-JNITvContext::JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<Tv> &tv)
-{
- mTvJObjectWeak = env->NewGlobalRef(weak_this);
- mTvJClass = (jclass)env->NewGlobalRef(clazz);
- mTv = tv;
- ALOGD("tvjni----------------------JNITvContext::JNITvContext(");
- mManualBufferMode = false;
- mManualTvCallbackSet = false;
- //mExtParcel = parcelForJavaObject(env, ext_parcel);
-}
-
-void JNITvContext::release()
-{
- ALOGD("release");
- Mutex::Autolock _l(mLock);
- JNIEnv *env = AndroidRuntime::getJNIEnv();
-
- if (mTvJObjectWeak != NULL) {
- env->DeleteGlobalRef(mTvJObjectWeak);
- mTvJObjectWeak = NULL;
- }
- if (mTvJClass != NULL) {
- env->DeleteGlobalRef(mTvJClass);
- mTvJClass = NULL;
- }
- mTv.clear();
-}
-
-// connect to tv service
-static void android_amlogic_Tv_native_setup(JNIEnv *env, jobject thiz, jobject weak_this)
-{
- sp<Tv> tv = Tv::connect();
-
- ALOGD("android_amlogic_Tv_native_setup.");
-
- if (tv == NULL) {
- jniThrowException(env, "java/lang/RuntimeException", "Fail to connect to tv service");
- return;
- }
-
- // make sure tv amlogic is alive
- if (tv->getStatus() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "Tv initialization failed!");
- return;
- }
-
- jclass clazz = env->GetObjectClass(thiz);
- if (clazz == NULL) {
- jniThrowException(env, "java/lang/RuntimeException", "Can't find android/amlogic/Tv!");
- return;
- }
-
- sp<JNITvContext> context = new JNITvContext(env, weak_this, clazz, tv);
- context->incStrong(thiz);
- tv->setListener(context);
-
- env->SetIntField(thiz, fields.context, (int)context.get());
-}
-
-
-static void android_amlogic_Tv_release(JNIEnv *env, jobject thiz)
-{
- // TODO: Change to LOGE
- JNITvContext *context = NULL;
- sp<Tv> tv;
- {
- Mutex::Autolock _l(sLock);
- context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
-
- // Make sure we do not attempt to callback on a deleted Java object.
- env->SetIntField(thiz, fields.context, 0);
- }
-
- ALOGD("release tv");
-
- // clean up if release has not been called before
- if (context != NULL) {
- tv = context->getTv();
- context->release();
- ALOGD("native_release: context=%p tv=%p", context, tv.get());
-
- // clear callbacks
- if (tv != NULL) {
- //tv->setPreviewCallbackFlags(FRAME_CALLBACK_FLAG_NOOP);
- tv->disconnect();
- }
-
- // remove context to prevent further Java access
- context->decStrong(thiz);
- }
-}
-
-void JNITvContext::notify(int32_t msgType, const Parcel &p)
-{
- // VM pointer will be NULL if object is released
- Mutex::Autolock _l(mLock);
- if (mTvJObjectWeak == NULL) {
- ALOGW("callback on dead tv object");
- return;
- }
-
- JNIEnv *env = AndroidRuntime::getJNIEnv();
-
- jobject jParcel = createJavaParcelObject(env);
- if (jParcel != NULL) {
- Parcel *nativeParcel = parcelForJavaObject(env, jParcel);
- nativeParcel->write(p.data(), p.dataSize());
- env->CallStaticVoidMethod(mTvJClass, fields.post_event, mTvJObjectWeak, msgType, jParcel);
- env->DeleteLocalRef(jParcel);
- }
-}
-
-
-void JNITvContext::addCallbackBuffer(JNIEnv *env, jbyteArray cbb)
-{
- if (cbb != NULL) {
- Mutex::Autolock _l(mLock);
- jbyteArray callbackBuffer = (jbyteArray)env->NewGlobalRef(cbb);
- mCallbackBuffers.push(cbb);
- ALOGD("Adding callback buffer to queue, %d total", mCallbackBuffers.size());
- } else {
- ALOGE("Null byte array!");
- }
-}
-
-static jint android_amlogic_Tv_processCmd(JNIEnv *env, jobject thiz, jobject pObj, jobject rObj)
-{
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return -1;
-
- Parcel *p = parcelForJavaObject(env, pObj);
- //jclass clazz;
- //clazz = env->FindClass("android/os/Parcel");
- //LOG_FATAL_IF(clazz == NULL, "Unable to find class android.os.Parcel");
-
-
- //jmethodID mConstructor = env->GetMethodID(clazz, "<init>", "(I)V");
- //jobject replayobj = env->NewObject(clazz, mConstructor, 0);
- Parcel *r = parcelForJavaObject(env, rObj);
-
-
- return tv->processCmd(*p, r);
- //if ( != NO_ERROR) {
- // jniThrowException(env, "java/lang/RuntimeException", "StartTv failed");
- // return -1;
- // }
- //return 0;
-}
-
-static void android_amlogic_Tv_addCallbackBuffer(JNIEnv *env, jobject thiz, jbyteArray bytes)
-{
- JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
-
- ALOGD("addCallbackBuffer");
- if (context != NULL) {
- context->addCallbackBuffer(env, bytes);
- }
-}
-
-static void android_amlogic_Tv_reconnect(JNIEnv *env, jobject thiz)
-{
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- if (tv->reconnect() != NO_ERROR) {
- jniThrowException(env, "java/io/IOException", "reconnect failed");
- return;
- }
-}
-
-static void android_amlogic_Tv_lock(JNIEnv *env, jobject thiz)
-{
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- ALOGD("lock");
-
- if (tv->lock() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "lock failed");
- }
-}
-
-static void android_amlogic_Tv_unlock(JNIEnv *env, jobject thiz)
-{
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- ALOGD("unlock");
-
- if (tv->unlock() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "unlock failed");
- }
-}
-
-static void android_amlogic_Tv_create_subtitle_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj)
-{
- ALOGD("create subtitle bmp");
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- //get skbitmap
- jclass bmp_clazz;
- jfieldID skbmp_fid;
- jint hbmp;
- bmp_clazz = env->FindClass("android/graphics/Bitmap");
- skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
- hbmp = env->GetIntField(bmpobj, skbmp_fid);
- SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
- ALOGD("pSkBmp = %d", hbmp);
- ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
- env->DeleteLocalRef(bmp_clazz);
-
- //alloc share mem
- sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1920 * 1080 * 4, 0, "subtitle bmp");
- ALOGD("heap id = %d", MemHeap->getHeapID());
- if (MemHeap->getHeapID() < 0) {
- return;
- }
- sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1920 * 1080 * 4);
- pSkBmp->setPixels(MemBase->pointer());
-
-
- //send share mem to server
- tv->createSubtitle(MemBase);
- return;
-}
-
-static void android_amlogic_Tv_create_video_frame_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj )
-{
- ALOGD("create video frame bmp");
- sp<Tv> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- //get skbitmap
- jclass bmp_clazz;
- jfieldID skbmp_fid;
- jint hbmp;
- bmp_clazz = env->FindClass("android/graphics/Bitmap");
- skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
- hbmp = env->GetIntField(bmpobj, skbmp_fid);
- SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
- ALOGD("pSkBmp = %d", hbmp);
- ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
- env->DeleteLocalRef(bmp_clazz);
-
- //alloc share mem
- sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1280 * 720 * 4 + 1, 0, "video frame bmp");
- ALOGD("heap id = %d", MemHeap->getHeapID());
- if (MemHeap->getHeapID() < 0) {
- return;
- }
- sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1280 * 720 * 4 + 1);
- pSkBmp->setPixels(MemBase->pointer());
-
-
- //send share mem to server
- tv->createVideoFrame(MemBase);
- return;
-}
-
-//-------------------------------------------------
-
-static JNINativeMethod camMethods[] = {
- {
- "native_setup",
- "(Ljava/lang/Object;)V",
- (void *)android_amlogic_Tv_native_setup
- },
- {
- "native_release",
- "()V",
- (void *)android_amlogic_Tv_release
- },
- {
- "processCmd",
- "(Landroid/os/Parcel;Landroid/os/Parcel;)I",
- (void *)android_amlogic_Tv_processCmd
- },
- {
- "addCallbackBuffer",
- "([B)V",
- (void *)android_amlogic_Tv_addCallbackBuffer
- },
- {
- "reconnect",
- "()V",
- (void *)android_amlogic_Tv_reconnect
- },
- {
- "lock",
- "()V",
- (void *)android_amlogic_Tv_lock
- },
- {
- "unlock",
- "()V",
- (void *)android_amlogic_Tv_unlock
- },
- {
- "native_create_subtitle_bitmap",
- "(Ljava/lang/Object;)V",
- (void *)android_amlogic_Tv_create_subtitle_bitmap
- },
- {
- "native_create_video_frame_bitmap",
- "(Ljava/lang/Object;)V",
- (void *)android_amlogic_Tv_create_video_frame_bitmap
- },
-
-};
-
-struct field {
- const char *class_name;
- const char *field_name;
- const char *field_type;
- jfieldID *jfield;
-};
-
-static int find_fields(JNIEnv *env, field *fields, int count)
-{
- for (int i = 0; i < count; i++) {
- field *f = &fields[i];
- jclass clazz = env->FindClass(f->class_name);
- if (clazz == NULL) {
- ALOGE("Can't find %s", f->class_name);
- return -1;
- }
-
- jfieldID field = env->GetFieldID(clazz, f->field_name, f->field_type);
- if (field == NULL) {
- ALOGE("Can't find %s.%s", f->class_name, f->field_name);
- return -1;
- }
-
- *(f->jfield) = field;
- }
-
- return 0;
-}
-
-// Get all the required offsets in java class and register native functions
-int register_android_amlogic_Tv(JNIEnv *env)
-{
- field fields_to_find[] = {
- { "android/amlogic/Tv", "mNativeContext", "I", &fields.context }
- };
-
- ALOGD("register_android_amlogic_Tv.");
-
- if (find_fields(env, fields_to_find, NELEM(fields_to_find)) < 0)
- return -1;
-
- jclass clazz = env->FindClass("android/amlogic/Tv");
- fields.post_event = env->GetStaticMethodID(clazz, "postEventFromNative", "(Ljava/lang/Object;ILandroid/os/Parcel;)V");
- if (fields.post_event == NULL) {
- ALOGE("Can't find android/amlogic/Tv.postEventFromNative");
- return -1;
- }
-
- // Register native functions
- return AndroidRuntime::registerNativeMethods(env, "android/amlogic/Tv", camMethods, NELEM(camMethods));
-}
-
-
-jint JNI_OnLoad(JavaVM *vm, void *reserved)
-{
- JNIEnv *env = NULL;
- jint result = -1;
-
- if (vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
- ALOGE("ERROR: GetEnv failed\n");
- goto bail;
- }
- assert(env != NULL);
-
- register_android_amlogic_Tv(env);
-
- /* success -- return valid version number */
- result = JNI_VERSION_1_4;
-bail:
- return result;
-}
-
+#define LOG_TAG "Tv-JNI"
+#include <utils/Log.h>
+
+#include "jni.h"
+#include "JNIHelp.h"
+#include "android_runtime/AndroidRuntime.h"
+#include <utils/Vector.h>
+#include <include/Tv.h>
+#include <binder/IMemory.h>
+#include <binder/Parcel.h>
+#include <binder/MemoryHeapBase.h>
+#include <binder/MemoryBase.h>
+#include <core/SkBitmap.h>
+#include "android_util_Binder.h"
+#include "android_os_Parcel.h"
+using namespace android;
+
+struct fields_t {
+ jfieldID context;
+ jmethodID post_event;
+};
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#define LOG_TAG "TvJNI"
+#endif
+
+static fields_t fields;
+static Mutex sLock;
+class JNITvContext: public TvListener {
+public:
+ JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<Tv> &tv);
+ ~JNITvContext()
+ {
+ release();
+ }
+ virtual void notify(int32_t msgType, const Parcel &p);
+ void addCallbackBuffer(JNIEnv *env, jbyteArray cbb);
+ sp<Tv> getTv()
+ {
+ Mutex::Autolock _l(mLock);
+ return mTv;
+ }
+ void release();
+ Parcel *mExtParcel;
+private:
+ jobject mTvJObjectWeak; // weak reference to java object
+ jclass mTvJClass; // strong reference to java class
+ sp<Tv> mTv; // strong reference to native object
+ Mutex mLock;
+
+ Vector<jbyteArray> mCallbackBuffers; // Global reference application managed byte[]
+ bool mManualBufferMode; // Whether to use application managed buffers.
+ bool mManualTvCallbackSet; // Whether the callback has been set, used to reduce unnecessary calls to set the callback.
+};
+
+sp<Tv> get_native_tv(JNIEnv *env, jobject thiz, JNITvContext **pContext)
+{
+ sp<Tv> tv;
+ Mutex::Autolock _l(sLock);
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+ if (context != NULL) {
+ tv = context->getTv();
+ }
+ if (tv == 0) {
+ jniThrowException(env, "java/lang/RuntimeException", "Method called after release()");
+ }
+
+ if (pContext != NULL) *pContext = context;
+ return tv;
+}
+
+JNITvContext::JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<Tv> &tv)
+{
+ mTvJObjectWeak = env->NewGlobalRef(weak_this);
+ mTvJClass = (jclass)env->NewGlobalRef(clazz);
+ mTv = tv;
+ ALOGD("tvjni----------------------JNITvContext::JNITvContext(");
+ mManualBufferMode = false;
+ mManualTvCallbackSet = false;
+ //mExtParcel = parcelForJavaObject(env, ext_parcel);
+}
+
+void JNITvContext::release()
+{
+ ALOGD("release");
+ Mutex::Autolock _l(mLock);
+ JNIEnv *env = AndroidRuntime::getJNIEnv();
+
+ if (mTvJObjectWeak != NULL) {
+ env->DeleteGlobalRef(mTvJObjectWeak);
+ mTvJObjectWeak = NULL;
+ }
+ if (mTvJClass != NULL) {
+ env->DeleteGlobalRef(mTvJClass);
+ mTvJClass = NULL;
+ }
+ mTv.clear();
+}
+
+// connect to tv service
+static void android_amlogic_Tv_native_setup(JNIEnv *env, jobject thiz, jobject weak_this)
+{
+ sp<Tv> tv = Tv::connect();
+
+ ALOGD("android_amlogic_Tv_native_setup.");
+
+ if (tv == NULL) {
+ jniThrowException(env, "java/lang/RuntimeException", "Fail to connect to tv service");
+ return;
+ }
+
+ // make sure tv amlogic is alive
+ if (tv->getStatus() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "Tv initialization failed!");
+ return;
+ }
+
+ jclass clazz = env->GetObjectClass(thiz);
+ if (clazz == NULL) {
+ jniThrowException(env, "java/lang/RuntimeException", "Can't find android/amlogic/Tv!");
+ return;
+ }
+
+ sp<JNITvContext> context = new JNITvContext(env, weak_this, clazz, tv);
+ context->incStrong(thiz);
+ tv->setListener(context);
+
+ env->SetIntField(thiz, fields.context, (int)context.get());
+}
+
+
+static void android_amlogic_Tv_release(JNIEnv *env, jobject thiz)
+{
+ // TODO: Change to LOGE
+ JNITvContext *context = NULL;
+ sp<Tv> tv;
+ {
+ Mutex::Autolock _l(sLock);
+ context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+
+ // Make sure we do not attempt to callback on a deleted Java object.
+ env->SetIntField(thiz, fields.context, 0);
+ }
+
+ ALOGD("release tv");
+
+ // clean up if release has not been called before
+ if (context != NULL) {
+ tv = context->getTv();
+ context->release();
+ ALOGD("native_release: context=%p tv=%p", context, tv.get());
+
+ // clear callbacks
+ if (tv != NULL) {
+ //tv->setPreviewCallbackFlags(FRAME_CALLBACK_FLAG_NOOP);
+ tv->disconnect();
+ }
+
+ // remove context to prevent further Java access
+ context->decStrong(thiz);
+ }
+}
+
+void JNITvContext::notify(int32_t msgType, const Parcel &p)
+{
+ // VM pointer will be NULL if object is released
+ Mutex::Autolock _l(mLock);
+ if (mTvJObjectWeak == NULL) {
+ ALOGW("callback on dead tv object");
+ return;
+ }
+
+ JNIEnv *env = AndroidRuntime::getJNIEnv();
+
+ jobject jParcel = createJavaParcelObject(env);
+ if (jParcel != NULL) {
+ Parcel *nativeParcel = parcelForJavaObject(env, jParcel);
+ nativeParcel->write(p.data(), p.dataSize());
+ env->CallStaticVoidMethod(mTvJClass, fields.post_event, mTvJObjectWeak, msgType, jParcel);
+ env->DeleteLocalRef(jParcel);
+ }
+}
+
+
+void JNITvContext::addCallbackBuffer(JNIEnv *env, jbyteArray cbb)
+{
+ if (cbb != NULL) {
+ Mutex::Autolock _l(mLock);
+ jbyteArray callbackBuffer = (jbyteArray)env->NewGlobalRef(cbb);
+ mCallbackBuffers.push(cbb);
+ ALOGD("Adding callback buffer to queue, %d total", mCallbackBuffers.size());
+ } else {
+ ALOGE("Null byte array!");
+ }
+}
+
+static jint android_amlogic_Tv_processCmd(JNIEnv *env, jobject thiz, jobject pObj, jobject rObj)
+{
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return -1;
+
+ Parcel *p = parcelForJavaObject(env, pObj);
+ //jclass clazz;
+ //clazz = env->FindClass("android/os/Parcel");
+ //LOG_FATAL_IF(clazz == NULL, "Unable to find class android.os.Parcel");
+
+
+ //jmethodID mConstructor = env->GetMethodID(clazz, "<init>", "(I)V");
+ //jobject replayobj = env->NewObject(clazz, mConstructor, 0);
+ Parcel *r = parcelForJavaObject(env, rObj);
+
+
+ return tv->processCmd(*p, r);
+ //if ( != NO_ERROR) {
+ // jniThrowException(env, "java/lang/RuntimeException", "StartTv failed");
+ // return -1;
+ // }
+ //return 0;
+}
+
+static void android_amlogic_Tv_addCallbackBuffer(JNIEnv *env, jobject thiz, jbyteArray bytes)
+{
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+
+ ALOGD("addCallbackBuffer");
+ if (context != NULL) {
+ context->addCallbackBuffer(env, bytes);
+ }
+}
+
+static void android_amlogic_Tv_reconnect(JNIEnv *env, jobject thiz)
+{
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ if (tv->reconnect() != NO_ERROR) {
+ jniThrowException(env, "java/io/IOException", "reconnect failed");
+ return;
+ }
+}
+
+static void android_amlogic_Tv_lock(JNIEnv *env, jobject thiz)
+{
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ ALOGD("lock");
+
+ if (tv->lock() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "lock failed");
+ }
+}
+
+static void android_amlogic_Tv_unlock(JNIEnv *env, jobject thiz)
+{
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ ALOGD("unlock");
+
+ if (tv->unlock() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "unlock failed");
+ }
+}
+
+static void android_amlogic_Tv_create_subtitle_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj)
+{
+ ALOGD("create subtitle bmp");
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ //get skbitmap
+ jclass bmp_clazz;
+ jfieldID skbmp_fid;
+ jint hbmp;
+ bmp_clazz = env->FindClass("android/graphics/Bitmap");
+ skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
+ hbmp = env->GetIntField(bmpobj, skbmp_fid);
+ SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
+ ALOGD("pSkBmp = %d", hbmp);
+ ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
+ env->DeleteLocalRef(bmp_clazz);
+
+ //alloc share mem
+ sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1920 * 1080 * 4, 0, "subtitle bmp");
+ ALOGD("heap id = %d", MemHeap->getHeapID());
+ if (MemHeap->getHeapID() < 0) {
+ return;
+ }
+ sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1920 * 1080 * 4);
+ pSkBmp->setPixels(MemBase->pointer());
+
+
+ //send share mem to server
+ tv->createSubtitle(MemBase);
+ return;
+}
+
+static void android_amlogic_Tv_create_video_frame_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj )
+{
+ ALOGD("create video frame bmp");
+ sp<Tv> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ //get skbitmap
+ jclass bmp_clazz;
+ jfieldID skbmp_fid;
+ jint hbmp;
+ bmp_clazz = env->FindClass("android/graphics/Bitmap");
+ skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
+ hbmp = env->GetIntField(bmpobj, skbmp_fid);
+ SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
+ ALOGD("pSkBmp = %d", hbmp);
+ ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
+ env->DeleteLocalRef(bmp_clazz);
+
+ //alloc share mem
+ sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1280 * 720 * 4 + 1, 0, "video frame bmp");
+ ALOGD("heap id = %d", MemHeap->getHeapID());
+ if (MemHeap->getHeapID() < 0) {
+ return;
+ }
+ sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1280 * 720 * 4 + 1);
+ pSkBmp->setPixels(MemBase->pointer());
+
+
+ //send share mem to server
+ tv->createVideoFrame(MemBase);
+ return;
+}
+
+//-------------------------------------------------
+
+static JNINativeMethod camMethods[] = {
+ {
+ "native_setup",
+ "(Ljava/lang/Object;)V",
+ (void *)android_amlogic_Tv_native_setup
+ },
+ {
+ "native_release",
+ "()V",
+ (void *)android_amlogic_Tv_release
+ },
+ {
+ "processCmd",
+ "(Landroid/os/Parcel;Landroid/os/Parcel;)I",
+ (void *)android_amlogic_Tv_processCmd
+ },
+ {
+ "addCallbackBuffer",
+ "([B)V",
+ (void *)android_amlogic_Tv_addCallbackBuffer
+ },
+ {
+ "reconnect",
+ "()V",
+ (void *)android_amlogic_Tv_reconnect
+ },
+ {
+ "lock",
+ "()V",
+ (void *)android_amlogic_Tv_lock
+ },
+ {
+ "unlock",
+ "()V",
+ (void *)android_amlogic_Tv_unlock
+ },
+ {
+ "native_create_subtitle_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)android_amlogic_Tv_create_subtitle_bitmap
+ },
+ {
+ "native_create_video_frame_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)android_amlogic_Tv_create_video_frame_bitmap
+ },
+
+};
+
+struct field {
+ const char *class_name;
+ const char *field_name;
+ const char *field_type;
+ jfieldID *jfield;
+};
+
+static int find_fields(JNIEnv *env, field *fields, int count)
+{
+ for (int i = 0; i < count; i++) {
+ field *f = &fields[i];
+ jclass clazz = env->FindClass(f->class_name);
+ if (clazz == NULL) {
+ ALOGE("Can't find %s", f->class_name);
+ return -1;
+ }
+
+ jfieldID field = env->GetFieldID(clazz, f->field_name, f->field_type);
+ if (field == NULL) {
+ ALOGE("Can't find %s.%s", f->class_name, f->field_name);
+ return -1;
+ }
+
+ *(f->jfield) = field;
+ }
+
+ return 0;
+}
+
+// Get all the required offsets in java class and register native functions
+int register_android_amlogic_Tv(JNIEnv *env)
+{
+ field fields_to_find[] = {
+ { "android/amlogic/Tv", "mNativeContext", "I", &fields.context }
+ };
+
+ ALOGD("register_android_amlogic_Tv.");
+
+ if (find_fields(env, fields_to_find, NELEM(fields_to_find)) < 0)
+ return -1;
+
+ jclass clazz = env->FindClass("android/amlogic/Tv");
+ fields.post_event = env->GetStaticMethodID(clazz, "postEventFromNative", "(Ljava/lang/Object;ILandroid/os/Parcel;)V");
+ if (fields.post_event == NULL) {
+ ALOGE("Can't find android/amlogic/Tv.postEventFromNative");
+ return -1;
+ }
+
+ // Register native functions
+ return AndroidRuntime::registerNativeMethods(env, "android/amlogic/Tv", camMethods, NELEM(camMethods));
+}
+
+
+jint JNI_OnLoad(JavaVM *vm, void *reserved)
+{
+ JNIEnv *env = NULL;
+ jint result = -1;
+
+ if (vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
+ ALOGE("ERROR: GetEnv failed\n");
+ goto bail;
+ }
+ assert(env != NULL);
+
+ register_android_amlogic_Tv(env);
+
+ /* success -- return valid version number */
+ result = JNI_VERSION_1_4;
+bail:
+ return result;
+}
+