8087133: Improve sharing of native wrappers in SignatureHandlerLibrary

Fingerprint normalization for arm32

Reviewed-by: dholmes, coleenp
This commit is contained in:
Bertrand Delsart 2015-06-23 17:48:34 +02:00
parent f65b2271ab
commit bf69556039
3 changed files with 47 additions and 16 deletions

View File

@ -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");

View File

@ -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);

View File

@ -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);
}
}; };