summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJari Vetoniemi <mailroxas@gmail.com>2018-11-19 14:41:36 +0200
committerJari Vetoniemi <mailroxas@gmail.com>2018-11-19 14:41:36 +0200
commit934fe74bbbee9517134035a5c8ad9abb624e1ad6 (patch)
tree6ed9916f52985406e82e96e80750ceb167f2cd25
parent14b74dee835f5fb87174626f193b090532206f9a (diff)
loader: don't JNI_OnLoad if there's entrypoint
-rw-r--r--src/loader.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/loader.c b/src/loader.c
index 419a39a..8706f23 100644
--- a/src/loader.c
+++ b/src/loader.c
@@ -227,15 +227,15 @@ main(int argc, const char *argv[])
}
int ret = EXIT_FAILURE;
- if ((entry.JNI_OnLoad.ptr = bionic_dlsym(handle, "JNI_OnLoad"))) {
+ if (entry.start.ptr) {
+ printf("jumping to %p\n", entry.start.ptr);
+ raw_start(entry.start.ptr, argc - 1, &argv[1]);
+ } else if ((entry.JNI_OnLoad.ptr = bionic_dlsym(handle, "JNI_OnLoad"))) {
struct jvm jvm;
jvm_init(&jvm);
entry.JNI_OnLoad.fun(&jvm.vm, NULL);
ret = run_jni_game(&jvm);
jvm_release(&jvm);
- } else if (entry.start.ptr) {
- printf("jumping to %p\n", entry.start.ptr);
- raw_start(entry.start.ptr, argc - 1, &argv[1]);
} else {
warnx("no entrypoint found in %s", argv[1]);
}