1*0797b24eSAndroid Build Coastguard Worker /* 2*0797b24eSAndroid Build Coastguard Worker * Copyright (C) 2013 The Android Open Source Project 3*0797b24eSAndroid Build Coastguard Worker * 4*0797b24eSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*0797b24eSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*0797b24eSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*0797b24eSAndroid Build Coastguard Worker * 8*0797b24eSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*0797b24eSAndroid Build Coastguard Worker * 10*0797b24eSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*0797b24eSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*0797b24eSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*0797b24eSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*0797b24eSAndroid Build Coastguard Worker * limitations under the License. 15*0797b24eSAndroid Build Coastguard Worker */ 16*0797b24eSAndroid Build Coastguard Worker 17*0797b24eSAndroid Build Coastguard Worker #pragma once 18*0797b24eSAndroid Build Coastguard Worker 19*0797b24eSAndroid Build Coastguard Worker #include <sys/cdefs.h> 20*0797b24eSAndroid Build Coastguard Worker 21*0797b24eSAndroid Build Coastguard Worker #include <stdbool.h> 22*0797b24eSAndroid Build Coastguard Worker 23*0797b24eSAndroid Build Coastguard Worker __BEGIN_DECLS 24*0797b24eSAndroid Build Coastguard Worker 25*0797b24eSAndroid Build Coastguard Worker /* 26*0797b24eSAndroid Build Coastguard Worker * The JNI invocation API exists to allow a choice of library responsible for managing virtual 27*0797b24eSAndroid Build Coastguard Worker * machines. 28*0797b24eSAndroid Build Coastguard Worker */ 29*0797b24eSAndroid Build Coastguard Worker 30*0797b24eSAndroid Build Coastguard Worker /* 31*0797b24eSAndroid Build Coastguard Worker * Opaque structure used to hold JNI invocation internal state. 32*0797b24eSAndroid Build Coastguard Worker */ 33*0797b24eSAndroid Build Coastguard Worker struct JniInvocationImpl; 34*0797b24eSAndroid Build Coastguard Worker 35*0797b24eSAndroid Build Coastguard Worker /* 36*0797b24eSAndroid Build Coastguard Worker * Creates an instance of a JniInvocationImpl. 37*0797b24eSAndroid Build Coastguard Worker */ 38*0797b24eSAndroid Build Coastguard Worker struct JniInvocationImpl* JniInvocationCreate(); 39*0797b24eSAndroid Build Coastguard Worker 40*0797b24eSAndroid Build Coastguard Worker /* 41*0797b24eSAndroid Build Coastguard Worker * Associates a library with a JniInvocationImpl instance. The library should export C symbols for 42*0797b24eSAndroid Build Coastguard Worker * JNI_GetDefaultJavaVMInitArgs, JNI_CreateJavaVM and JNI_GetDefaultJavaVMInitArgs. 43*0797b24eSAndroid Build Coastguard Worker * 44*0797b24eSAndroid Build Coastguard Worker * The specified |library| should be the filename of a shared library. The |library| is opened with 45*0797b24eSAndroid Build Coastguard Worker * dlopen(3). 46*0797b24eSAndroid Build Coastguard Worker * 47*0797b24eSAndroid Build Coastguard Worker * If there is an error opening the specified |library|, then function will fallback to the 48*0797b24eSAndroid Build Coastguard Worker * default library "libart.so". If the fallback library is successfully used then a warning is 49*0797b24eSAndroid Build Coastguard Worker * written to the Android log buffer. Use of the fallback library is not considered an error. 50*0797b24eSAndroid Build Coastguard Worker * 51*0797b24eSAndroid Build Coastguard Worker * If the fallback library cannot be opened or the expected symbols are not found in the library 52*0797b24eSAndroid Build Coastguard Worker * opened, then an error message is written to the Android log buffer and the function returns 0. 53*0797b24eSAndroid Build Coastguard Worker * 54*0797b24eSAndroid Build Coastguard Worker * Returns true on success, false otherwise. 55*0797b24eSAndroid Build Coastguard Worker */ 56*0797b24eSAndroid Build Coastguard Worker bool JniInvocationInit(struct JniInvocationImpl* instance, const char* library); 57*0797b24eSAndroid Build Coastguard Worker 58*0797b24eSAndroid Build Coastguard Worker /* 59*0797b24eSAndroid Build Coastguard Worker * Release resources associated with JniInvocationImpl instance. 60*0797b24eSAndroid Build Coastguard Worker */ 61*0797b24eSAndroid Build Coastguard Worker void JniInvocationDestroy(struct JniInvocationImpl* instance); 62*0797b24eSAndroid Build Coastguard Worker 63*0797b24eSAndroid Build Coastguard Worker /* 64*0797b24eSAndroid Build Coastguard Worker * Gets the default library for JNI invocation. The default library is "libart.so". This value may 65*0797b24eSAndroid Build Coastguard Worker * be overridden for debuggable builds using the persist.sys.dalvik.vm.lib.2 system property. 66*0797b24eSAndroid Build Coastguard Worker * 67*0797b24eSAndroid Build Coastguard Worker * The |library| argument is the preferred library to use on debuggable builds (when 68*0797b24eSAndroid Build Coastguard Worker * ro.debuggable=1). If the |library| argument is nullptr, then the system preferred value will be 69*0797b24eSAndroid Build Coastguard Worker * queried from persist.sys.dalvik.vm.lib.2 if the caller has provided |buffer| argument. 70*0797b24eSAndroid Build Coastguard Worker * 71*0797b24eSAndroid Build Coastguard Worker * The |buffer| argument is used for reading system properties in debuggable builds. It is 72*0797b24eSAndroid Build Coastguard Worker * optional, but should be provisioned to be PROP_VALUE_MAX bytes if provided to ensure it is 73*0797b24eSAndroid Build Coastguard Worker * large enough to hold a system property. 74*0797b24eSAndroid Build Coastguard Worker * 75*0797b24eSAndroid Build Coastguard Worker * Returns the filename of the invocation library determined from the inputs and system 76*0797b24eSAndroid Build Coastguard Worker * properties. The returned value may be |library|, |buffer|, or a pointer to a string constant 77*0797b24eSAndroid Build Coastguard Worker * "libart.so". 78*0797b24eSAndroid Build Coastguard Worker */ 79*0797b24eSAndroid Build Coastguard Worker const char* JniInvocationGetLibrary(const char* library, char* buffer); 80*0797b24eSAndroid Build Coastguard Worker 81*0797b24eSAndroid Build Coastguard Worker __END_DECLS 82*0797b24eSAndroid Build Coastguard Worker 83*0797b24eSAndroid Build Coastguard Worker #ifdef __cplusplus 84*0797b24eSAndroid Build Coastguard Worker 85*0797b24eSAndroid Build Coastguard Worker // JniInvocation adds a layer of indirection for applications using 86*0797b24eSAndroid Build Coastguard Worker // the JNI invocation API to allow the JNI implementation to be 87*0797b24eSAndroid Build Coastguard Worker // selected dynamically. Apps can specify a specific implementation to 88*0797b24eSAndroid Build Coastguard Worker // be used by calling InitJniInvocation. If this is not done, the 89*0797b24eSAndroid Build Coastguard Worker // library will chosen based on the value of Android system property 90*0797b24eSAndroid Build Coastguard Worker // persist.sys.dalvik.vm.lib on the device, and otherwise fall back to 91*0797b24eSAndroid Build Coastguard Worker // a hard-coded default implementation. 92*0797b24eSAndroid Build Coastguard Worker class JniInvocation final { 93*0797b24eSAndroid Build Coastguard Worker public: JniInvocation()94*0797b24eSAndroid Build Coastguard Worker JniInvocation() { 95*0797b24eSAndroid Build Coastguard Worker impl_ = JniInvocationCreate(); 96*0797b24eSAndroid Build Coastguard Worker } 97*0797b24eSAndroid Build Coastguard Worker ~JniInvocation()98*0797b24eSAndroid Build Coastguard Worker ~JniInvocation() { 99*0797b24eSAndroid Build Coastguard Worker JniInvocationDestroy(impl_); 100*0797b24eSAndroid Build Coastguard Worker } 101*0797b24eSAndroid Build Coastguard Worker 102*0797b24eSAndroid Build Coastguard Worker // Initialize JNI invocation API. library should specify a valid 103*0797b24eSAndroid Build Coastguard Worker // shared library for opening via dlopen providing a JNI invocation 104*0797b24eSAndroid Build Coastguard Worker // implementation, or null to allow defaulting via 105*0797b24eSAndroid Build Coastguard Worker // persist.sys.dalvik.vm.lib. Init(const char * library)106*0797b24eSAndroid Build Coastguard Worker bool Init(const char* library) { 107*0797b24eSAndroid Build Coastguard Worker return JniInvocationInit(impl_, library) != 0; 108*0797b24eSAndroid Build Coastguard Worker } 109*0797b24eSAndroid Build Coastguard Worker 110*0797b24eSAndroid Build Coastguard Worker // Exposes which library is actually loaded from the given name. The 111*0797b24eSAndroid Build Coastguard Worker // buffer of size PROPERTY_VALUE_MAX will be used to load the system 112*0797b24eSAndroid Build Coastguard Worker // property for the default library, if necessary. If no buffer is 113*0797b24eSAndroid Build Coastguard Worker // provided, the fallback value will be used. GetLibrary(const char * library,char * buffer)114*0797b24eSAndroid Build Coastguard Worker static const char* GetLibrary(const char* library, char* buffer) { 115*0797b24eSAndroid Build Coastguard Worker return JniInvocationGetLibrary(library, buffer); 116*0797b24eSAndroid Build Coastguard Worker } 117*0797b24eSAndroid Build Coastguard Worker 118*0797b24eSAndroid Build Coastguard Worker private: 119*0797b24eSAndroid Build Coastguard Worker JniInvocation(const JniInvocation&) = delete; 120*0797b24eSAndroid Build Coastguard Worker JniInvocation& operator=(const JniInvocation&) = delete; 121*0797b24eSAndroid Build Coastguard Worker 122*0797b24eSAndroid Build Coastguard Worker JniInvocationImpl* impl_; 123*0797b24eSAndroid Build Coastguard Worker }; 124*0797b24eSAndroid Build Coastguard Worker 125*0797b24eSAndroid Build Coastguard Worker #endif // __cplusplus 126