src/hotspot/share/prims/nativeLookup.cpp
author thartmann
Wed, 31 Jul 2019 08:05:14 +0200
changeset 57600 3d44a84147cc
parent 54847 59ea39bb2809
child 57710 05ff6e27de45
permissions -rw-r--r--
8193042: NativeLookup::lookup_critical_entry() should only load shared library once Summary: Avoids repeated loads/unloads of the same shared library. Reviewed-by: dholmes, dlong, thartmann Contributed-by: Christian Hagedorn <christian.hagedorn@oracle.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
53582
881c5fbeb849 8218041: Assorted wrong/missing includes
rehn
parents: 51997
diff changeset
     2
 * Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4571
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4571
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4571
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    25
#include "precompiled.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    26
#include "classfile/javaClasses.hpp"
54786
ebf733a324d4 8223624: Cleanup includes of universe.hpp
stefank
parents: 54432
diff changeset
    27
#include "classfile/symbolTable.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    28
#include "classfile/systemDictionary.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    29
#include "classfile/vmSymbols.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    30
#include "memory/oopFactory.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    31
#include "memory/resourceArea.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    32
#include "oops/instanceKlass.hpp"
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13396
diff changeset
    33
#include "oops/method.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    34
#include "oops/oop.inline.hpp"
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
    35
#include "oops/symbol.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    36
#include "prims/jvm_misc.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    37
#include "prims/nativeLookup.hpp"
36551
77f29c57ed2e 8149159: Clean up Unsafe
mikael
parents: 35235
diff changeset
    38
#include "prims/unsafe.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    39
#include "runtime/arguments.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    40
#include "runtime/handles.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    41
#include "runtime/javaCalls.hpp"
53582
881c5fbeb849 8218041: Assorted wrong/missing includes
rehn
parents: 51997
diff changeset
    42
#include "runtime/os.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    43
#include "runtime/sharedRuntime.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    44
#include "runtime/signature.hpp"
15482
470d0b0c09f1 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 14488
diff changeset
    45
#include "utilities/macros.hpp"
54347
235883996bc7 8221698: Remove redundant includes from popular header files
iklam
parents: 53582
diff changeset
    46
#include "utilities/utf8.hpp"
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49359
diff changeset
    47
#if INCLUDE_JFR
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49359
diff changeset
    48
#include "jfr/jfr.hpp"
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 35235
diff changeset
    49
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
    51
static void mangle_name_on(outputStream* st, Symbol* name, int begin, int end) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  char* bytes = (char*)name->bytes() + begin;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  char* end_bytes = (char*)name->bytes() + end;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
  while (bytes < end_bytes) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
    jchar c;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
    bytes = UTF8::next(bytes, &c);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
    if (c <= 0x7f && isalnum(c)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
      st->put((char) c);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
           if (c == '_') st->print("_1");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
      else if (c == '/') st->print("_");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
      else if (c == ';') st->print("_2");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
      else if (c == '[') st->print("_3");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
      else               st->print("_%.5x", c);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
    70
static void mangle_name_on(outputStream* st, Symbol* name) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
  mangle_name_on(st, name, 0, name->utf8_length());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
    75
char* NativeLookup::pure_jni_name(const methodHandle& method) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  stringStream st;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
  // Prefix
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
  st.print("Java_");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  // Klass name
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  mangle_name_on(&st, method->klass_name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  st.print("_");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
  // Method name
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  mangle_name_on(&st, method->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  return st.as_string();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
    88
char* NativeLookup::critical_jni_name(const methodHandle& method) {
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    89
  stringStream st;
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    90
  // Prefix
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    91
  st.print("JavaCritical_");
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    92
  // Klass name
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    93
  mangle_name_on(&st, method->klass_name());
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    94
  st.print("_");
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    95
  // Method name
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    96
  mangle_name_on(&st, method->name());
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    97
  return st.as_string();
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    98
}
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
    99
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   100
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   101
char* NativeLookup::long_jni_name(const methodHandle& method) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
  // Signature ignore the wrapping parenteses and the trailing return type
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
  stringStream st;
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
   104
  Symbol* signature = method->signature();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  st.print("__");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  // find ')'
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  int end;
51997
9ce37fa2e179 8209138: Symbol constructor uses u1 as the element type of its name argument
hseigel
parents: 50113
diff changeset
   108
  for (end = 0; end < signature->utf8_length() && signature->char_at(end) != ')'; end++);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
  // skip first '('
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  mangle_name_on(&st, signature, 1, end);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  return st.as_string();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
extern "C" {
2534
08dac9ce0cd7 6655638: dynamic languages need method handles
jrose
parents: 1
diff changeset
   115
  void JNICALL JVM_RegisterMethodHandleMethods(JNIEnv *env, jclass unsafecls);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
  void JNICALL JVM_RegisterPerfMethods(JNIEnv *env, jclass perfclass);
12095
cc3d6f08a4c4 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 11637
diff changeset
   117
  void JNICALL JVM_RegisterWhiteBoxMethods(JNIEnv *env, jclass wbclass);
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   118
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   119
  jobject  JNICALL JVM_GetJVMCIRuntime(JNIEnv *env, jclass c);
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   120
  void     JNICALL JVM_RegisterJVMCINatives(JNIEnv *env, jclass compilerToVMClass);
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   121
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
8675
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   124
#define CC (char*)  /* cast a literal from (const char*) */
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   125
#define FN_PTR(f) CAST_FROM_FN_PTR(void*, &f)
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   126
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   127
static JNINativeMethod lookup_special_native_methods[] = {
35103
d19354bcbfa6 8143628: Fork sun.misc.Unsafe and jdk.internal.misc.Unsafe native method tables
psandoz
parents: 33606
diff changeset
   128
  { CC"Java_jdk_internal_misc_Unsafe_registerNatives",             NULL, FN_PTR(JVM_RegisterJDKInternalMiscUnsafeMethods) },
8676
9098d4e927e1 7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents: 8675
diff changeset
   129
  { CC"Java_java_lang_invoke_MethodHandleNatives_registerNatives", NULL, FN_PTR(JVM_RegisterMethodHandleMethods) },
34928
23cee048ab91 8146736: Move sun.misc performance counters to jdk.internal.perf
chegar
parents: 33606
diff changeset
   130
  { CC"Java_jdk_internal_perf_Perf_registerNatives",               NULL, FN_PTR(JVM_RegisterPerfMethods)         },
12095
cc3d6f08a4c4 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 11637
diff changeset
   131
  { CC"Java_sun_hotspot_WhiteBox_registerNatives",                 NULL, FN_PTR(JVM_RegisterWhiteBoxMethods)     },
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   132
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   133
  { CC"Java_jdk_vm_ci_runtime_JVMCI_initializeRuntime",            NULL, FN_PTR(JVM_GetJVMCIRuntime)             },
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   134
  { CC"Java_jdk_vm_ci_hotspot_CompilerToVM_registerNatives",       NULL, FN_PTR(JVM_RegisterJVMCINatives)        },
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 28731
diff changeset
   135
#endif
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49359
diff changeset
   136
#if INCLUDE_JFR
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49359
diff changeset
   137
  { CC"Java_jdk_jfr_internal_JVM_registerNatives",                 NULL, FN_PTR(jfr_register_natives)            },
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 35235
diff changeset
   138
#endif
8675
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   139
};
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   140
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   141
static address lookup_special_native(const char* jni_name) {
8675
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   142
  int count = sizeof(lookup_special_native_methods) / sizeof(JNINativeMethod);
20381
ed1047a3ac21 8024087: Remove dead JVM_{Get,Set}PrimitiveFieldValues functions
mikael
parents: 17381
diff changeset
   143
  for (int i = 0; i < count; i++) {
8675
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   144
    // NB: To ignore the jni prefix and jni postfix strstr is used matching.
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   145
    if (strstr(jni_name, lookup_special_native_methods[i].name) != NULL) {
e9fef2a9bef7 6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents: 8076
diff changeset
   146
      return CAST_FROM_FN_PTR(address, lookup_special_native_methods[i].fnPtr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   152
address NativeLookup::lookup_style(const methodHandle& method, char* pure_name, const char* long_name, int args_size, bool os_style, bool& in_base_library, TRAPS) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
  address entry;
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   154
  const char* jni_name = compute_complete_jni_name(pure_name, long_name, args_size, os_style);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   155
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
  // If the loader is null we have a system class, so we attempt a lookup in
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
  // the native Java library. This takes care of any bootstrapping problems.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
  // Note: It is critical for bootstrapping that Java_java_lang_ClassLoader_00024NativeLibrary_find
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
  // gets found the first time around - otherwise an infinite loop can occure. This is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
  // another VM/library dependency
14391
df0a1573d5bd 8000725: NPG: method_holder() and pool_holder() and pool_holder field should be InstanceKlass
coleenp
parents: 13975
diff changeset
   162
  Handle loader(THREAD, method->method_holder()->class_loader());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
  if (loader.is_null()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
    entry = lookup_special_native(jni_name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
    if (entry == NULL) {
7405
e6fc8d3926f8 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 7397
diff changeset
   166
       entry = (address) os::dll_lookup(os::native_java_library(), jni_name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
    if (entry != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
      in_base_library = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
      return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
  // Otherwise call static method findNative in ClassLoader
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 36615
diff changeset
   175
  Klass*   klass = SystemDictionary::ClassLoader_klass();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
  Handle name_arg = java_lang_String::create_from_str(jni_name, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
  JavaValue result(T_LONG);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
  JavaCalls::call_static(&result,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
                         klass,
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
   181
                         vmSymbols::findNative_name(),
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
   182
                         vmSymbols::classloader_string_long_signature(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
                         // Arguments
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
                         loader,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
                         name_arg,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
                         CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
  entry = (address) (intptr_t) result.get_jlong();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
  if (entry == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
    // findNative didn't find it, if there are any agent libraries look in them
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
    AgentLibrary* agent;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
    for (agent = Arguments::agents(); agent != NULL; agent = agent->next()) {
7405
e6fc8d3926f8 6348631: remove the use of the HPI library from Hotspot
ikrylov
parents: 7397
diff changeset
   193
      entry = (address) os::dll_lookup(agent->os_lib(), jni_name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
      if (entry != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
        return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
  return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   203
const char* NativeLookup::compute_complete_jni_name(const char* pure_name, const char* long_name, int args_size, bool os_style) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   204
  stringStream st;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   205
  if (os_style) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   206
    os::print_jni_name_prefix_on(&st, args_size);
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   207
  }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   208
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   209
  st.print_raw(pure_name);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   210
  st.print_raw(long_name);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   211
  if (os_style) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   212
    os::print_jni_name_suffix_on(&st, args_size);
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   213
  }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   214
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   215
  return st.as_string();
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   216
}
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   217
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   218
address NativeLookup::lookup_critical_style(void* dll, const char* pure_name, const char* long_name, int args_size, bool os_style) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   219
  const char* jni_name = compute_complete_jni_name(pure_name, long_name, args_size, os_style);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   220
  assert(dll != NULL, "dll must be loaded");
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   221
  return (address)os::dll_lookup(dll, jni_name);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   222
}
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   223
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
// Check all the formats of native implementation name to see if there is one
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
// for the specified method.
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   226
address NativeLookup::lookup_entry(const methodHandle& method, bool& in_base_library, TRAPS) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
  address entry = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
  in_base_library = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
  // Compute pure name
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
  char* pure_name = pure_jni_name(method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
  // Compute argument size
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
  int args_size = 1                             // JNIEnv
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
                + (method->is_static() ? 1 : 0) // class for static methods
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
                + method->size_of_parameters(); // actual parameters
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
  // 1) Try JNI short style
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  entry = lookup_style(method, pure_name, "",        args_size, true,  in_base_library, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  if (entry != NULL) return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  // Compute long name
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
  char* long_name = long_jni_name(method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
  // 2) Try JNI long style
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
  entry = lookup_style(method, pure_name, long_name, args_size, true,  in_base_library, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
  if (entry != NULL) return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
  // 3) Try JNI short style without os prefix/suffix
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
  entry = lookup_style(method, pure_name, "",        args_size, false, in_base_library, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  if (entry != NULL) return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
  // 4) Try JNI long style without os prefix/suffix
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
  entry = lookup_style(method, pure_name, long_name, args_size, false, in_base_library, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
  return entry; // NULL indicates not found
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   258
// Check all the formats of native implementation name to see if there is one
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   259
// for the specified method.
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   260
address NativeLookup::lookup_critical_entry(const methodHandle& method) {
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   261
  if (!CriticalJNINatives) return NULL;
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   262
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   263
  if (method->is_synchronized() ||
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   264
      !method->is_static()) {
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   265
    // Only static non-synchronized methods are allowed
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   266
    return NULL;
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   267
  }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   268
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   269
  ResourceMark rm;
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   270
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   271
  Symbol* signature = method->signature();
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   272
  for (int end = 0; end < signature->utf8_length(); end++) {
51997
9ce37fa2e179 8209138: Symbol constructor uses u1 as the element type of its name argument
hseigel
parents: 50113
diff changeset
   273
    if (signature->char_at(end) == 'L') {
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   274
      // Don't allow object types
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   275
      return NULL;
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   276
    }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   277
  }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   278
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   279
  // Compute argument size
47782
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   280
  int args_size = method->size_of_parameters();
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   281
  for (SignatureStream ss(signature); !ss.at_return_type(); ss.next()) {
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   282
    if (ss.is_array()) {
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   283
      args_size += T_INT_size; // array length parameter
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   284
    }
d099408b386e 8167408: Invalid critical JNI function lookup
jcm
parents: 47216
diff changeset
   285
  }
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   286
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   287
  void* dll = dll_load(method);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   288
  address entry = NULL;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   289
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   290
  if (dll != NULL) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   291
    entry = lookup_critical_style(dll, method, args_size);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   292
    // Close the handle to avoid keeping the library alive if the native method holder is unloaded.
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   293
    // This is fine because the library is still kept alive by JNI (see JVM_LoadLibrary). As soon
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   294
    // as the holder class and the library are unloaded (see JVM_UnloadLibrary), the native wrapper
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   295
    // that calls 'critical_entry' becomes unreachable and is unloaded as well.
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   296
    os::dll_unload(dll);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   297
  }
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   298
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   299
  return entry; // NULL indicates not found
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   300
}
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   301
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   302
void* NativeLookup::dll_load(const methodHandle& method) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   303
  if (method->has_native_function()) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   304
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   305
    address current_entry = method->native_function();
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   306
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   307
    char dll_name[JVM_MAXPATHLEN];
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   308
    int offset;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   309
    if (os::dll_address_to_library_name(current_entry, dll_name, sizeof(dll_name), &offset)) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   310
      char ebuf[32];
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   311
      return os::dll_load(dll_name, ebuf, sizeof(ebuf));
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   312
    }
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   313
  }
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   314
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   315
  return NULL;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   316
}
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   317
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   318
address NativeLookup::lookup_critical_style(void* dll, const methodHandle& method, int args_size) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   319
  address entry = NULL;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   320
  const char* critical_name = critical_jni_name(method);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   321
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   322
  // 1) Try JNI short style
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   323
  entry = lookup_critical_style(dll, critical_name, "",        args_size, true);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   324
  if (entry != NULL) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   325
    return entry;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   326
  }
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   327
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   328
  const char* long_name = long_jni_name(method);
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   329
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   330
  // 2) Try JNI long style
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   331
  entry = lookup_critical_style(dll, critical_name, long_name, args_size, true);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   332
  if (entry != NULL) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   333
    return entry;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   334
  }
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   335
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   336
  // 3) Try JNI short style without os prefix/suffix
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   337
  entry = lookup_critical_style(dll, critical_name, "",        args_size, false);
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   338
  if (entry != NULL) {
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   339
    return entry;
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   340
  }
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   341
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   342
  // 4) Try JNI long style without os prefix/suffix
57600
3d44a84147cc 8193042: NativeLookup::lookup_critical_entry() should only load shared library once
thartmann
parents: 54847
diff changeset
   343
  return lookup_critical_style(dll, critical_name, long_name, args_size, false);
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   344
}
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 10565
diff changeset
   345
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
// Check if there are any JVM TI prefixes which have been applied to the native method name.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
// If any are found, remove them before attemping the look up of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
// native implementation again.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
// See SetNativeMethodPrefix in the JVM TI Spec for more details.
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   350
address NativeLookup::lookup_entry_prefixed(const methodHandle& method, bool& in_base_library, TRAPS) {
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
   351
#if INCLUDE_JVMTI
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
  ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
  int prefix_count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   355
  char** prefixes = JvmtiExport::get_all_native_method_prefixes(&prefix_count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
  char* in_name = method->name()->as_C_string();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
  char* wrapper_name = in_name;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
  // last applied prefix will be first -- go backwards
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
  for (int i = prefix_count-1; i >= 0; i--) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
    char* prefix = prefixes[i];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
    size_t prefix_len = strlen(prefix);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
    if (strncmp(prefix, wrapper_name, prefix_len) == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
      // has this prefix remove it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
      wrapper_name += prefix_len;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
  if (wrapper_name != in_name) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
    // we have a name for a wrapping method
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
    int wrapper_name_len = (int)strlen(wrapper_name);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
   370
    TempNewSymbol wrapper_symbol = SymbolTable::probe(wrapper_name, wrapper_name_len);
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7405
diff changeset
   371
    if (wrapper_symbol != NULL) {
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 36615
diff changeset
   372
      Klass* k = method->method_holder();
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 36615
diff changeset
   373
      Method* wrapper_method = k->lookup_method(wrapper_symbol, method->signature());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
      if (wrapper_method != NULL && !wrapper_method->is_native()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
        // we found a wrapper method, use its native entry
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
        method->set_is_prefixed_native();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
        return lookup_entry(wrapper_method, in_base_library, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
  }
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
   381
#endif // INCLUDE_JVMTI
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   385
address NativeLookup::lookup_base(const methodHandle& method, bool& in_base_library, TRAPS) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
  address entry = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
  ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
  entry = lookup_entry(method, in_base_library, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
  if (entry != NULL) return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
  // standard native method resolution has failed.  Check if there are any
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
  // JVM TI prefixes which have been applied to the native method name.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
  entry = lookup_entry_prefixed(method, in_base_library, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
  if (entry != NULL) return entry;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
  // Native function not found, throw UnsatisfiedLinkError
54432
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54347
diff changeset
   398
  stringStream ss;
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54347
diff changeset
   399
  ss.print("'");
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54347
diff changeset
   400
  method->print_external_name(&ss);
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54347
diff changeset
   401
  ss.print("'");
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54347
diff changeset
   402
  THROW_MSG_0(vmSymbols::java_lang_UnsatisfiedLinkError(), ss.as_string());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
33593
60764a78fa5c 8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents: 33160
diff changeset
   406
address NativeLookup::lookup(const methodHandle& method, bool& in_base_library, TRAPS) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
  if (!method->has_native_function()) {
17381
a53ac5bf4850 7196277: JSR 292: Two jck/runtime tests crash on java.lang.invoke.MethodHandle.invokeExact
twisti
parents: 15482
diff changeset
   408
    address entry = lookup_base(method, in_base_library, CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
    method->set_native_function(entry,
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13396
diff changeset
   410
      Method::native_bind_event_is_interesting);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
    // -verbose:jni printing
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
    if (PrintJNIResolving) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
      ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
      tty->print_cr("[Dynamic-linking native method %s.%s ... JNI]",
14391
df0a1573d5bd 8000725: NPG: method_holder() and pool_holder() and pool_holder field should be InstanceKlass
coleenp
parents: 13975
diff changeset
   415
        method->method_holder()->external_name(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
        method->name()->as_C_string());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   417
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
  return method->native_function();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
address NativeLookup::base_library_lookup(const char* class_name, const char* method_name, const char* signature) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
  EXCEPTION_MARK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
  bool in_base_library = true;  // SharedRuntime inits some math methods.
54847
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54786
diff changeset
   425
  TempNewSymbol c_name = SymbolTable::new_symbol(class_name);
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54786
diff changeset
   426
  TempNewSymbol m_name = SymbolTable::new_symbol(method_name);
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54786
diff changeset
   427
  TempNewSymbol s_name = SymbolTable::new_symbol(signature);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
  // Find the class
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13396
diff changeset
   430
  Klass* k = SystemDictionary::resolve_or_fail(c_name, true, CATCH);
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 36615
diff changeset
   431
  InstanceKlass* klass  = InstanceKlass::cast(k);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
  // Find method and invoke standard lookup
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
  methodHandle method (THREAD,
28731
f7339cba0a6a 8067480: Crash in klassItable::initialize_itable_for_interface when running vm.runtime.defmeth.StaticMethodsTest.
lfoltan
parents: 25468
diff changeset
   435
                       klass->uncached_lookup_method(m_name, s_name, Klass::find_overpass));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
  address result = lookup(method, in_base_library, CATCH);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
  assert(in_base_library, "must be in basic library");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
  guarantee(result != NULL, "must be non NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
  return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
}