blob: a9e8a608c0330036aeb559714d74346eb0077833 [file] [log] [blame]
Henrik Kjellanderff761fb2015-11-04 08:31:52 +01001/*
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_UTILITY_INCLUDE_HELPERS_ANDROID_H_
12#define MODULES_UTILITY_INCLUDE_HELPERS_ANDROID_H_
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010013
14#include <jni.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020015
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010016#include <string>
17
Niels Möllera12c42a2018-07-25 16:05:48 +020018#include "rtc_base/system/arch.h"
19
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010020// Abort the process if |jni| has a Java exception pending.
21// TODO(henrika): merge with CHECK_JNI_EXCEPTION() in jni_helpers.h.
22#define CHECK_EXCEPTION(jni) \
23 RTC_CHECK(!jni->ExceptionCheck()) \
24 << (jni->ExceptionDescribe(), jni->ExceptionClear(), "")
25
Yura Yaroshevich278d03a2018-03-23 11:47:19 +030026#if defined(WEBRTC_ARCH_X86)
27// Dalvik JIT generated code doesn't guarantee 16-byte stack alignment on
28// x86 - use force_align_arg_pointer to realign the stack at the JNI
29// boundary. bugs.webrtc.org/9050
30#define JNI_FUNCTION_ALIGN __attribute__((force_align_arg_pointer))
31#else
32#define JNI_FUNCTION_ALIGN
33#endif
34
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010035namespace webrtc {
36
37// Return a |JNIEnv*| usable on this thread or NULL if this thread is detached.
38JNIEnv* GetEnv(JavaVM* jvm);
39
40// Return a |jlong| that will correctly convert back to |ptr|. This is needed
41// because the alternative (of silently passing a 32-bit pointer to a vararg
42// function expecting a 64-bit param) picks up garbage in the high 32 bits.
43jlong PointerTojlong(void* ptr);
44
45// JNIEnv-helper methods that wraps the API which uses the JNI interface
46// pointer (JNIEnv*). It allows us to RTC_CHECK success and that no Java
47// exception is thrown while calling the method.
Yves Gerey665174f2018-06-19 15:03:05 +020048jmethodID GetMethodID(JNIEnv* jni,
49 jclass c,
50 const char* name,
51 const char* signature);
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010052
Yves Gerey665174f2018-06-19 15:03:05 +020053jmethodID GetStaticMethodID(JNIEnv* jni,
54 jclass c,
55 const char* name,
56 const char* signature);
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010057
58jclass FindClass(JNIEnv* jni, const char* name);
59
60jobject NewGlobalRef(JNIEnv* jni, jobject o);
61
62void DeleteGlobalRef(JNIEnv* jni, jobject o);
63
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010064// Attach thread to JVM if necessary and detach at scope end if originally
65// attached.
66class AttachThreadScoped {
67 public:
68 explicit AttachThreadScoped(JavaVM* jvm);
69 ~AttachThreadScoped();
70 JNIEnv* env();
71
72 private:
73 bool attached_;
74 JavaVM* jvm_;
75 JNIEnv* env_;
76};
77
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010078} // namespace webrtc
79
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020080#endif // MODULES_UTILITY_INCLUDE_HELPERS_ANDROID_H_