forked from len0rd/rockbox
Android: Don't share the JNI environment across threads, but obtain it the
correct way git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29569 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
2e5b7aebde
commit
66f2a08f8a
10 changed files with 60 additions and 16 deletions
|
@ -27,7 +27,7 @@
|
|||
|
||||
|
||||
/* global fields for use with various JNI calls */
|
||||
JNIEnv *env_ptr;
|
||||
JavaVM *vm_ptr;
|
||||
jobject RockboxService_instance;
|
||||
jclass RockboxService_class;
|
||||
|
||||
|
@ -44,8 +44,11 @@ void system_reboot(void) { }
|
|||
|
||||
void power_off(void)
|
||||
{
|
||||
JNIEnv *env_ptr = getJavaEnvironment();
|
||||
|
||||
lcd_deinit();
|
||||
pcm_deinit();
|
||||
|
||||
(*env_ptr)->DeleteGlobalRef(env_ptr, RockboxService_class);
|
||||
}
|
||||
|
||||
|
@ -68,8 +71,8 @@ Java_org_rockbox_RockboxService_main(JNIEnv *env, jobject this)
|
|||
|
||||
volatile uintptr_t stack = 0;
|
||||
stackbegin = stackend = (uintptr_t*) &stack;
|
||||
env_ptr = env;
|
||||
|
||||
(*env)->GetJavaVM(env, &vm_ptr);
|
||||
RockboxService_instance = (*env)->NewGlobalRef(env, this);
|
||||
RockboxService_class = (*env)->NewGlobalRef(env, class);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue