forked from len0rd/rockbox
Partly revert "Android: use NewGlobalRef for references that are used globally"
The added complexity wasn't needed for most subsystems, as main() never returns so local references can't be freed. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29570 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
66f2a08f8a
commit
c2ee32b22a
6 changed files with 23 additions and 48 deletions
|
@ -46,7 +46,6 @@ 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)
|
||||
|
@ -55,7 +54,7 @@ void connect_with_java(JNIEnv* env, jobject fb_instance)
|
|||
RockboxFramebuffer_instance = e->NewGlobalRef(env, fb_instance);
|
||||
}
|
||||
|
||||
static bool have_class = false;
|
||||
static bool have_class;
|
||||
if (!have_class)
|
||||
{
|
||||
jclass fb_class = e->GetObjectClass(env, fb_instance);
|
||||
|
@ -77,13 +76,10 @@ void connect_with_java(JNIEnv* env, jobject fb_instance)
|
|||
java_lcd_init = e->GetMethodID(env, fb_class,
|
||||
"java_lcd_init",
|
||||
"(IILjava/nio/ByteBuffer;)V");
|
||||
|
||||
jobject buffer = e->NewDirectByteBuffer(env,
|
||||
|
||||
native_buffer = e->NewDirectByteBuffer(env,
|
||||
lcd_framebuffer,
|
||||
(jlong)sizeof(lcd_framebuffer));
|
||||
|
||||
native_buffer = e->NewGlobalRef(env, buffer);
|
||||
|
||||
have_class = true;
|
||||
}
|
||||
/* we need to setup parts for the java object every time */
|
||||
|
@ -96,7 +92,6 @@ void lcd_deinit(void)
|
|||
JNIEnv *env_ptr = getJavaEnvironment();
|
||||
|
||||
(*env_ptr)->DeleteGlobalRef(env_ptr, RockboxFramebuffer_instance);
|
||||
(*env_ptr)->DeleteGlobalRef(env_ptr, native_buffer);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue