summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Martitz <kugel@rockbox.org>2011-03-11 22:48:10 +0000
committerThomas Martitz <kugel@rockbox.org>2011-03-11 22:48:10 +0000
commit662ba4868af3981dcc64e271f49ee0bd72cd19e5 (patch)
treef3e1d716cfd9bceb62c13301e3043387e0d168b4
parent00f75c92bf4f9b04cd919ef7f61ca68ddc93f94b (diff)
downloadrockbox-662ba4868af3981dcc64e271f49ee0bd72cd19e5.zip
rockbox-662ba4868af3981dcc64e271f49ee0bd72cd19e5.tar.gz
rockbox-662ba4868af3981dcc64e271f49ee0bd72cd19e5.tar.bz2
rockbox-662ba4868af3981dcc64e271f49ee0bd72cd19e5.tar.xz
Create GlobalRef in surfaceCreated, in accordance to r29572.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29574 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/target/hosted/android/lcd-android.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/firmware/target/hosted/android/lcd-android.c b/firmware/target/hosted/android/lcd-android.c
index b1d2728..172e832 100644
--- a/firmware/target/hosted/android/lcd-android.c
+++ b/firmware/target/hosted/android/lcd-android.c
@@ -46,15 +46,8 @@ static bool display_on;
void connect_with_java(JNIEnv* env, jobject fb_instance)
{
JNIEnv e = *env;
- /* Update RockboxFramebuffer_instance */
- if (!e->IsSameObject(env, RockboxFramebuffer_instance, fb_instance)) {
- if (RockboxFramebuffer_instance != NULL)
- e->DeleteGlobalRef(env, RockboxFramebuffer_instance);
-
- RockboxFramebuffer_instance = e->NewGlobalRef(env, fb_instance);
- }
-
static bool have_class;
+
if (!have_class)
{
jclass fb_class = e->GetObjectClass(env, fb_instance);
@@ -123,6 +116,8 @@ Java_org_rockbox_RockboxFramebuffer_surfaceCreated(JNIEnv *env, jobject this,
jobject surfaceholder)
{
(void)surfaceholder;
+ /* Update RockboxFramebuffer_instance */
+ RockboxFramebuffer_instance = (*env)->NewGlobalRef(env, this);
/* possibly a new instance - reconnect */
connect_with_java(env, this);
display_on = true;