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/android/jni/com_droidlogic_app_tv_TvControlManager.cpp b/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp
new file mode 100644
index 0000000..56ad946
--- a/dev/null
+++ b/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp
@@ -0,0 +1,474 @@
+#define LOG_TAG "Tv-JNI"
+#include <utils/Log.h>
+
+#include "../include/tvcmd.h"
+#include "jni.h"
+#include "JNIHelp.h"
+#include "GraphicsJNI.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;
+ SkBitmap *pSubBmp;//for UI subtitle Bitmap
+ sp<MemoryBase> mSubMemBase;//for subtitle shar memory to tvapi
+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;
+ pSubBmp = NULL;
+ mSubMemBase = NULL;
+ //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;
+ }
+ if (pSubBmp != NULL) {
+ pSubBmp = NULL;
+ }
+ mTv.clear();
+}
+
+// connect to tv service
+static void com_droidlogic_app_tv_TvControlManager_native_setup(JNIEnv *env, jobject thiz, jobject weak_this)
+{
+ sp<Tv> tv = Tv::connect();
+
+ ALOGD("com_droidlogic_app_tv_TvControlManager_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 com/droidlogic/app/tv/TvControlManager!");
+ 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 com_droidlogic_app_tv_TvControlManager_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;
+ }
+ if (msgType == SUBTITLE_UPDATE_CALLBACK) {
+ if (pSubBmp) {
+ SkAutoLockPixels alp(*pSubBmp);
+ char *pDst = (char *) pSubBmp->getPixels();
+ char *pBuf = (char *) mSubMemBase->pointer();
+ for (int i = 0; i < pSubBmp->width() * pSubBmp->height() * 4; i++) {
+ pDst[i] = pBuf[i];
+ }
+ pSubBmp->notifyPixelsChanged();
+ }
+ }
+
+ 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 com_droidlogic_app_tv_TvControlManager_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 com_droidlogic_app_tv_TvControlManager_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 com_droidlogic_app_tv_TvControlManager_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 com_droidlogic_app_tv_TvControlManager_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 com_droidlogic_app_tv_TvControlManager_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 com_droidlogic_app_tv_TvControlManager_create_subtitle_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj)
+{
+ ALOGD("create subtitle bmp");
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+ 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);
+ context->pSubBmp = reinterpret_cast<SkBitmap *>(hbmp);
+ env->DeleteLocalRef(bmp_clazz);
+
+ //alloc share mem
+ sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(context->pSubBmp->width()*context->pSubBmp->height() * 4, 0, "subtitle bmp");
+ ALOGD("heap id = %d", MemHeap->getHeapID());
+ if (MemHeap->getHeapID() < 0) {
+ return;
+ }
+ context->pSubBmp->lockPixels();
+ context->mSubMemBase = new MemoryBase(MemHeap, 0, context->pSubBmp->width()*context->pSubBmp->height() * 4);
+
+
+ //send share mem to server
+ tv->createSubtitle(context->mSubMemBase);
+ return;
+}
+
+static void com_droidlogic_app_tv_TvControlManager_create_video_frame_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj, jint inputSourceMode, jint iCapVideoLayer )
+{
+ 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(1920 * 1080 * 4, 0, "video frame 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->createVideoFrame(MemBase, inputSourceMode, iCapVideoLayer);
+ return;
+}
+
+//-------------------------------------------------
+
+static JNINativeMethod camMethods[] = {
+ {
+ "native_setup",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_native_setup
+ },
+ {
+ "native_release",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_release
+ },
+ {
+ "processCmd",
+ "(Landroid/os/Parcel;Landroid/os/Parcel;)I",
+ (void *)com_droidlogic_app_tv_TvControlManager_processCmd
+ },
+ {
+ "addCallbackBuffer",
+ "([B)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_addCallbackBuffer
+ },
+ {
+ "reconnect",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_reconnect
+ },
+ {
+ "lock",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_lock
+ },
+ {
+ "unlock",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_unlock
+ },
+ {
+ "native_create_subtitle_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_create_subtitle_bitmap
+ },
+ {
+ "native_create_video_frame_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_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_com_droidlogic_app_tv_TvControlManager(JNIEnv *env)
+{
+ field fields_to_find[] = {
+ { "com/droidlogic/app/tv/TvControlManager", "mNativeContext", "I", &fields.context }
+ };
+
+ ALOGD("register_com_droidlogic_app_tv_TvControlManager.");
+
+ if (find_fields(env, fields_to_find, NELEM(fields_to_find)) < 0)
+ return -1;
+
+ jclass clazz = env->FindClass("com/droidlogic/app/tv/TvControlManager");
+ fields.post_event = env->GetStaticMethodID(clazz, "postEventFromNative", "(Ljava/lang/Object;ILandroid/os/Parcel;)V");
+ if (fields.post_event == NULL) {
+ ALOGE("Can't find com/droidlogic/app/tv/TvControlManager.postEventFromNative");
+ return -1;
+ }
+
+ // Register native functions
+ return AndroidRuntime::registerNativeMethods(env, "com/droidlogic/app/tv/TvControlManager", 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_com_droidlogic_app_tv_TvControlManager(env);
+
+ /* success -- return valid version number */
+ result = JNI_VERSION_1_4;
+bail:
+ return result;
+}
+