mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-26 22:34:27 +02:00
8232050: Improve inlining of Klass accessors
Reviewed-by: lfoltan, tschatzl, coleenp, dholmes, jiangli
This commit is contained in:
parent
9751b5669a
commit
88d28a2bf9
14 changed files with 32 additions and 23 deletions
|
@ -57,10 +57,6 @@ void Klass::set_java_mirror(Handle m) {
|
|||
_java_mirror = class_loader_data()->add_handle(m);
|
||||
}
|
||||
|
||||
oop Klass::java_mirror() const {
|
||||
return _java_mirror.resolve();
|
||||
}
|
||||
|
||||
oop Klass::java_mirror_no_keepalive() const {
|
||||
return _java_mirror.peek();
|
||||
}
|
||||
|
@ -681,8 +677,6 @@ void Klass::check_array_allocation_length(int length, int max_length, TRAPS) {
|
|||
}
|
||||
}
|
||||
|
||||
oop Klass::class_loader() const { return class_loader_data()->class_loader(); }
|
||||
|
||||
// In product mode, this function doesn't have virtual function calls so
|
||||
// there might be some performance advantage to handling InstanceKlass here.
|
||||
const char* Klass::external_name() const {
|
||||
|
@ -826,14 +820,6 @@ bool Klass::is_valid(Klass* k) {
|
|||
return ClassLoaderDataGraph::is_valid(k->class_loader_data());
|
||||
}
|
||||
|
||||
klassVtable Klass::vtable() const {
|
||||
return klassVtable(const_cast<Klass*>(this), start_of_vtable(), vtable_length() / vtableEntry::size());
|
||||
}
|
||||
|
||||
vtableEntry* Klass::start_of_vtable() const {
|
||||
return (vtableEntry*) ((address)this + in_bytes(vtable_start_offset()));
|
||||
}
|
||||
|
||||
Method* Klass::method_at_vtable(int index) {
|
||||
#ifndef PRODUCT
|
||||
assert(index >= 0, "valid vtable index");
|
||||
|
@ -844,9 +830,6 @@ Method* Klass::method_at_vtable(int index) {
|
|||
return start_of_vtable()[index].method();
|
||||
}
|
||||
|
||||
ByteSize Klass::vtable_start_offset() {
|
||||
return in_ByteSize(InstanceKlass::header_size() * wordSize);
|
||||
}
|
||||
|
||||
#ifndef PRODUCT
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue