8087133: Improve sharing of native wrappers in SignatureHandlerLibrary
Fingerprint normalization for arm32 Reviewed-by: dholmes, coleenp
This commit is contained in:
parent
f65b2271ab
commit
bf69556039
@ -26,6 +26,7 @@
|
|||||||
#include "classfile/javaClasses.inline.hpp"
|
#include "classfile/javaClasses.inline.hpp"
|
||||||
#include "classfile/systemDictionary.hpp"
|
#include "classfile/systemDictionary.hpp"
|
||||||
#include "classfile/vmSymbols.hpp"
|
#include "classfile/vmSymbols.hpp"
|
||||||
|
#include "code/codeCache.hpp"
|
||||||
#include "compiler/compileBroker.hpp"
|
#include "compiler/compileBroker.hpp"
|
||||||
#include "compiler/disassembler.hpp"
|
#include "compiler/disassembler.hpp"
|
||||||
#include "gc/shared/collectedHeap.hpp"
|
#include "gc/shared/collectedHeap.hpp"
|
||||||
@ -1129,6 +1130,14 @@ IRT_END
|
|||||||
|
|
||||||
// Implementation of SignatureHandlerLibrary
|
// Implementation of SignatureHandlerLibrary
|
||||||
|
|
||||||
|
#ifndef SHARING_FAST_NATIVE_FINGERPRINTS
|
||||||
|
// Dummy definition (else normalization method is defined in CPU
|
||||||
|
// dependant code)
|
||||||
|
uint64_t InterpreterRuntime::normalize_fast_native_fingerprint(uint64_t fingerprint) {
|
||||||
|
return fingerprint;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
address SignatureHandlerLibrary::set_handler_blob() {
|
address SignatureHandlerLibrary::set_handler_blob() {
|
||||||
BufferBlob* handler_blob = BufferBlob::create("native signature handlers", blob_size);
|
BufferBlob* handler_blob = BufferBlob::create("native signature handlers", blob_size);
|
||||||
if (handler_blob == NULL) {
|
if (handler_blob == NULL) {
|
||||||
@ -1184,6 +1193,8 @@ void SignatureHandlerLibrary::add(methodHandle method) {
|
|||||||
initialize();
|
initialize();
|
||||||
// lookup method signature's fingerprint
|
// lookup method signature's fingerprint
|
||||||
uint64_t fingerprint = Fingerprinter(method).fingerprint();
|
uint64_t fingerprint = Fingerprinter(method).fingerprint();
|
||||||
|
// allow CPU dependant code to optimize the fingerprints for the fast handler
|
||||||
|
fingerprint = InterpreterRuntime::normalize_fast_native_fingerprint(fingerprint);
|
||||||
handler_index = _fingerprints->find(fingerprint);
|
handler_index = _fingerprints->find(fingerprint);
|
||||||
// create handler if necessary
|
// create handler if necessary
|
||||||
if (handler_index < 0) {
|
if (handler_index < 0) {
|
||||||
@ -1209,13 +1220,18 @@ void SignatureHandlerLibrary::add(methodHandle method) {
|
|||||||
buffer.insts_size());
|
buffer.insts_size());
|
||||||
Disassembler::decode(handler, handler + buffer.insts_size());
|
Disassembler::decode(handler, handler + buffer.insts_size());
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
tty->print_cr(" --- associated result handler ---");
|
|
||||||
address rh_begin = Interpreter::result_handler(method()->result_type());
|
address rh_begin = Interpreter::result_handler(method()->result_type());
|
||||||
address rh_end = rh_begin;
|
if (CodeCache::contains(rh_begin)) {
|
||||||
while (*(int*)rh_end != 0) {
|
// else it might be special platform dependent values
|
||||||
rh_end += sizeof(int);
|
tty->print_cr(" --- associated result handler ---");
|
||||||
|
address rh_end = rh_begin;
|
||||||
|
while (*(int*)rh_end != 0) {
|
||||||
|
rh_end += sizeof(int);
|
||||||
|
}
|
||||||
|
Disassembler::decode(rh_begin, rh_end);
|
||||||
|
} else {
|
||||||
|
tty->print_cr(" associated result handler: " PTR_FORMAT, p2i(rh_begin));
|
||||||
}
|
}
|
||||||
Disassembler::decode(rh_begin, rh_end);
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
// add handler to library
|
// add handler to library
|
||||||
@ -1227,13 +1243,13 @@ void SignatureHandlerLibrary::add(methodHandle method) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Set handler under SignatureHandlerLibrary_lock
|
// Set handler under SignatureHandlerLibrary_lock
|
||||||
if (handler_index < 0) {
|
if (handler_index < 0) {
|
||||||
// use generic signature handler
|
// use generic signature handler
|
||||||
method->set_signature_handler(Interpreter::slow_signature_handler());
|
method->set_signature_handler(Interpreter::slow_signature_handler());
|
||||||
} else {
|
} else {
|
||||||
// set handler
|
// set handler
|
||||||
method->set_signature_handler(_handlers->at(handler_index));
|
method->set_signature_handler(_handlers->at(handler_index));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
CHECK_UNHANDLED_OOPS_ONLY(Thread::current()->clear_unhandled_oops());
|
CHECK_UNHANDLED_OOPS_ONLY(Thread::current()->clear_unhandled_oops());
|
||||||
// use generic signature handler
|
// use generic signature handler
|
||||||
@ -1250,9 +1266,11 @@ void SignatureHandlerLibrary::add(methodHandle method) {
|
|||||||
// have to protect this read access here with the same mutex as well!
|
// have to protect this read access here with the same mutex as well!
|
||||||
MutexLocker mu(SignatureHandlerLibrary_lock);
|
MutexLocker mu(SignatureHandlerLibrary_lock);
|
||||||
if (_handlers != NULL) {
|
if (_handlers != NULL) {
|
||||||
handler_index = _handlers->find(method->signature_handler());
|
handler_index = _handlers->find(method->signature_handler());
|
||||||
fingerprint_index = _fingerprints->find(Fingerprinter(method).fingerprint());
|
uint64_t fingerprint = Fingerprinter(method).fingerprint();
|
||||||
}
|
fingerprint = InterpreterRuntime::normalize_fast_native_fingerprint(fingerprint);
|
||||||
|
fingerprint_index = _fingerprints->find(fingerprint);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
assert(method->signature_handler() == Interpreter::slow_signature_handler() ||
|
assert(method->signature_handler() == Interpreter::slow_signature_handler() ||
|
||||||
handler_index == fingerprint_index, "sanity check");
|
handler_index == fingerprint_index, "sanity check");
|
||||||
|
@ -183,6 +183,8 @@ class InterpreterRuntime: AllStatic {
|
|||||||
# include "interpreterRT_aarch64.hpp"
|
# include "interpreterRT_aarch64.hpp"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// optional normalization of fingerprints to reduce the number of adapters
|
||||||
|
static uint64_t normalize_fast_native_fingerprint(uint64_t fingerprint);
|
||||||
|
|
||||||
// Interpreter's frequency counter overflow
|
// Interpreter's frequency counter overflow
|
||||||
static nmethod* frequency_counter_overflow(JavaThread* thread, address branch_bcp);
|
static nmethod* frequency_counter_overflow(JavaThread* thread, address branch_bcp);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -63,6 +63,8 @@ class SignatureIterator: public ResourceObj {
|
|||||||
// Fingerprinter.
|
// Fingerprinter.
|
||||||
enum {
|
enum {
|
||||||
static_feature_size = 1,
|
static_feature_size = 1,
|
||||||
|
is_static_bit = 1,
|
||||||
|
|
||||||
result_feature_size = 4,
|
result_feature_size = 4,
|
||||||
result_feature_mask = 0xF,
|
result_feature_mask = 0xF,
|
||||||
parameter_feature_size = 4,
|
parameter_feature_size = 4,
|
||||||
@ -114,6 +116,15 @@ class SignatureIterator: public ResourceObj {
|
|||||||
// Object types (begin indexes the first character of the entry, end indexes the first character after the entry)
|
// Object types (begin indexes the first character of the entry, end indexes the first character after the entry)
|
||||||
virtual void do_object(int begin, int end) = 0;
|
virtual void do_object(int begin, int end) = 0;
|
||||||
virtual void do_array (int begin, int end) = 0;
|
virtual void do_array (int begin, int end) = 0;
|
||||||
|
|
||||||
|
static bool is_static(uint64_t fingerprint) {
|
||||||
|
assert(fingerprint != (uint64_t)CONST64(-1), "invalid fingerprint");
|
||||||
|
return fingerprint & is_static_bit;
|
||||||
|
}
|
||||||
|
static BasicType return_type(uint64_t fingerprint) {
|
||||||
|
assert(fingerprint != (uint64_t)CONST64(-1), "invalid fingerprint");
|
||||||
|
return (BasicType) ((fingerprint >> static_feature_size) & result_feature_mask);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user