changeset in /hg/icedtea6: 2009-02-24 Gary Benson <gbenson at red...

Gary Benson gbenson at redhat.com
Tue Feb 24 06:53:49 PST 2009


changeset 1847391cef9c in /hg/icedtea6
details: http://icedtea.classpath.org/hg/icedtea6?cmd=changeset;node=1847391cef9c
description:
	2009-02-24  Gary Benson  <gbenson at redhat.com>

		* ports/hotspot/src/share/vm/shark/sharkBlock.cpp
		(SharkBlock::get_basic_callee): Removed.
		(SharkBlock::get_direct_callee): New method.
		(SharkBlock::get_virtual_callee): Likewise.
		(SharkBlock::get_interface_callee): Removed cache parameter.
		(SharkBlock::get_callee): Removed.
		(SharkBlock::do_call): Perform caller selection inline.

		* ports/hotspot/src/share/vm/shark/sharkBlock.hpp
		(SharkBlock::get_basic_callee): Removed.
		(SharkBlock::get_direct_callee): New method.
		(SharkBlock::get_virtual_callee): Likewise.
		(SharkBlock::get_interface_callee): Changed prototype.
		(SharkBlock::get_callee): Removed.

diffstat:

3 files changed, 81 insertions(+), 30 deletions(-)
ChangeLog                                       |   17 ++++
ports/hotspot/src/share/vm/shark/sharkBlock.cpp |   86 ++++++++++++++++-------
ports/hotspot/src/share/vm/shark/sharkBlock.hpp |    8 +-

diffs (165 lines):

diff -r 1be2224bd96c -r 1847391cef9c ChangeLog
--- a/ChangeLog	Mon Feb 23 17:14:33 2009 -0500
+++ b/ChangeLog	Tue Feb 24 14:53:39 2009 +0000
@@ -1,3 +1,20 @@ 2009-02-23  Deepak Bhole <dbhole at redhat.
+2009-02-24  Gary Benson  <gbenson at redhat.com>
+
+	* ports/hotspot/src/share/vm/shark/sharkBlock.cpp
+	(SharkBlock::get_basic_callee): Removed.
+	(SharkBlock::get_direct_callee): New method.
+	(SharkBlock::get_virtual_callee): Likewise.
+	(SharkBlock::get_interface_callee): Removed cache parameter.
+	(SharkBlock::get_callee): Removed.
+	(SharkBlock::do_call): Perform caller selection inline.
+
+	* ports/hotspot/src/share/vm/shark/sharkBlock.hpp
+	(SharkBlock::get_basic_callee): Removed.
+	(SharkBlock::get_direct_callee): New method.
+	(SharkBlock::get_virtual_callee): Likewise.
+	(SharkBlock::get_interface_callee): Changed prototype.
+	(SharkBlock::get_callee): Removed.
+
 2009-02-23  Deepak Bhole <dbhole at redhat.com>
 
 	* IcedTeaPlugin.cc: Supply cookie info to Java side.
diff -r 1be2224bd96c -r 1847391cef9c ports/hotspot/src/share/vm/shark/sharkBlock.cpp
--- a/ports/hotspot/src/share/vm/shark/sharkBlock.cpp	Mon Feb 23 17:14:33 2009 -0500
+++ b/ports/hotspot/src/share/vm/shark/sharkBlock.cpp	Tue Feb 24 14:53:39 2009 +0000
@@ -1726,14 +1726,58 @@ void SharkBlock::do_switch()
   }
 }
 
-Value* SharkBlock::get_basic_callee(Value *cache)
-{
+// Direct calls can be made when the callee is fixed.
+// invokestatic and invokespecial are always direct;
+// invokevirtual is direct in some circumstances.
+Value *SharkBlock::get_direct_callee(ciMethod* method)
+{
+  SharkConstantPool constants(this);
+  Value *cache = constants.cache_entry_at(iter()->get_method_index());
   return builder()->CreateValueOfStructEntry(
-    cache, ConstantPoolCacheEntry::f1_offset(),
+    cache,
+    bc() == Bytecodes::_invokevirtual ?
+      ConstantPoolCacheEntry::f2_offset() :
+      ConstantPoolCacheEntry::f1_offset(),
     SharkType::methodOop_type(),
     "callee");
 }
 
+// Non-direct virtual calls are handled here
+Value *SharkBlock::get_virtual_callee(SharkValue *receiver, ciMethod* method)
+{
+  Value *klass = builder()->CreateValueOfStructEntry(
+    receiver->jobject_value(),
+    in_ByteSize(oopDesc::klass_offset_in_bytes()),
+    SharkType::jobject_type(),
+    "klass");
+
+  Value *index;
+  if (!method->holder()->is_linked()) {
+    // Yuck, we have to do this one slow :(
+    // XXX should we trap on this?
+    NOT_PRODUCT(warning("unresolved invokevirtual in %s", function()->name()));
+    SharkConstantPool constants(this);
+    Value *cache = constants.cache_entry_at(iter()->get_method_index());
+    index = builder()->CreateValueOfStructEntry(
+      cache, ConstantPoolCacheEntry::f2_offset(),
+      SharkType::intptr_type(),
+      "index");
+  }
+  else {
+    index = LLVMValue::intptr_constant(method->vtable_index());
+  }
+
+  return builder()->CreateLoad(
+    builder()->CreateArrayAddress(
+      klass,
+      SharkType::methodOop_type(),
+      vtableEntry::size() * wordSize,
+      in_ByteSize(instanceKlass::vtable_start_offset() * wordSize),
+      index),
+    "callee");
+}
+
+// Interpreter-style virtual call lookup
 Value* SharkBlock::get_virtual_callee(Value *cache, SharkValue *receiver)
 {
   BasicBlock *final      = function()->CreateBlock("final");
@@ -1792,8 +1836,12 @@ Value* SharkBlock::get_virtual_callee(Va
   return callee;
 }
 
-Value* SharkBlock::get_interface_callee(Value *cache, SharkValue *receiver)
-{
+// Interpreter-style interface call lookup
+Value* SharkBlock::get_interface_callee(SharkValue *receiver)
+{
+  SharkConstantPool constants(this);
+  Value *cache = constants.cache_entry_at(iter()->get_method_index());
+
   BasicBlock *hacky      = function()->CreateBlock("hacky");
   BasicBlock *normal     = function()->CreateBlock("normal");
   BasicBlock *loop       = function()->CreateBlock("loop");
@@ -1947,24 +1995,6 @@ Value* SharkBlock::get_interface_callee(
   return callee;
 } 
 
-Value* SharkBlock::get_callee(Value *cache, SharkValue *receiver)
-{
-  switch (bc()) {
-  case Bytecodes::_invokestatic:
-  case Bytecodes::_invokespecial:
-    return get_basic_callee(cache);
-
-  case Bytecodes::_invokevirtual:
-    return get_virtual_callee(cache, receiver);
-
-  case Bytecodes::_invokeinterface:
-    return get_interface_callee(cache, receiver);
-
-  default:
-    ShouldNotReachHere();
-  }
-}
-
 void SharkBlock::do_call()
 {
   bool will_link;
@@ -1979,9 +2009,13 @@ void SharkBlock::do_call()
   }
 
   // Find the method we are calling
-  SharkConstantPool constants(this);
-  Value *cache = constants.cache_entry_at(iter()->get_method_index());
-  Value *callee = get_callee(cache, receiver);
+  Value *callee;
+  if (bc() == Bytecodes::_invokeinterface)
+    callee = get_interface_callee(receiver);
+  else if (bc() == Bytecodes::_invokevirtual && !method->is_final_method())
+    callee = get_virtual_callee(receiver, method);
+  else
+    callee = get_direct_callee(method);
 
   Value *base_pc = builder()->CreateValueOfStructEntry(
     callee, methodOopDesc::from_interpreted_offset(),
diff -r 1be2224bd96c -r 1847391cef9c ports/hotspot/src/share/vm/shark/sharkBlock.hpp
--- a/ports/hotspot/src/share/vm/shark/sharkBlock.hpp	Mon Feb 23 17:14:33 2009 -0500
+++ b/ports/hotspot/src/share/vm/shark/sharkBlock.hpp	Tue Feb 24 14:53:39 2009 +0000
@@ -493,11 +493,11 @@ class SharkBlock : public ResourceObj {
 
   // invoke*
  private:
-  llvm::Value* get_basic_callee(llvm::Value* cache);
+  llvm::Value* get_direct_callee(ciMethod* method);
+  llvm::Value* get_virtual_callee(SharkValue* receiver, ciMethod* method);
+
   llvm::Value* get_virtual_callee(llvm::Value* cache, SharkValue* receiver);
-  llvm::Value* get_interface_callee(llvm::Value* cache, SharkValue* receiver);
-
-  llvm::Value* get_callee(llvm::Value* cache, SharkValue* receiver);
+  llvm::Value* get_interface_callee(SharkValue* receiver);
 
   void do_call();
 



More information about the distro-pkg-dev mailing list