diff c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/HotSpotTypeResolved.java @ 1433:efba53f86c4f

various fixes and enhancements * correct refmap->oopmap conversion (register numbering, stack slot numbering) * fixes for inlining (correct scoping in exception handler lookup, NPE in scope conversion) * support for "jump to runtime stub" (patching code needs to be aware of jmp instruction) * provide more information about methods (to allow inlining: has_balanced_monitors, etc.) * fixes to signature type lookup * isSubTypeOf: correct handling of array classes * RiType: componentType/arrayOf * prologue: inline cache check, icmiss stub * klass state check (resolved but not initialized) in newinstance * card table write barriers * c1x classes are optional (to allow running c1 without them) * correct for stored frame pointer in calling conventions (methods with arguments on stack) * getType(Class<?>) for some basic types, used for optimizations and folding * RiMethod/RiType: throw exception instead of silent failure on unsupported operations * RiType: resolved/unresolved array type support * refactoring: new on-demand template generation mechanism * optimizations: template specialization for no_null_check, given length, etc.
author Lukas Stadler <lukas.stadler@oracle.com>
date Thu, 16 Sep 2010 19:42:20 -0700
parents 949ade3f2ff3
children 72cfb36c6bb2
line wrap: on
line diff
--- a/c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/HotSpotTypeResolved.java	Wed Sep 01 17:13:38 2010 -0700
+++ b/c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/HotSpotTypeResolved.java	Thu Sep 16 19:42:20 2010 -0700
@@ -17,8 +17,11 @@
  */
 package com.sun.hotspot.c1x;
 
+import java.lang.reflect.*;
+
 import com.sun.cri.ci.*;
 import com.sun.cri.ri.*;
+import com.sun.hotspot.c1x.logging.*;
 
 /**
  * Implementation of RiType for resolved non-primitive HotSpot classes.
@@ -39,9 +42,10 @@
     private final boolean isInstanceClass;
     private final boolean isInterface;
     private final int instanceSize;
+    private final RiType componentType;
 
     public HotSpotTypeResolved(long vmId, long javaMirrorVmId, String name, int accessFlags, boolean hasFinalizer, boolean hasSubclass, boolean hasFinalizableSubclass, boolean isInitialized,
-                    boolean isArrayClass, boolean isInstanceClass, boolean isInterface, int instanceSize) {
+                    boolean isArrayClass, boolean isInstanceClass, boolean isInterface, int instanceSize, RiType componentType) {
         this.vmId = vmId;
         this.javaMirrorVmId = javaMirrorVmId;
         this.name = name;
@@ -54,6 +58,7 @@
         this.isInstanceClass = isInstanceClass;
         this.isInterface = isInterface;
         this.instanceSize = instanceSize;
+        this.componentType = componentType;
     }
 
     @Override
@@ -63,16 +68,23 @@
 
     @Override
     public RiType arrayOf() {
+        Logger.log("arrayOf " + name);
         return null;
+        //return Compiler.getVMEntries().RiType_arrayOf(vmId);
     }
 
     @Override
     public RiType componentType() {
-        return null;
+        Logger.log("componentType " + name + " isarray: " + isArrayClass);
+        return Compiler.getVMEntries().RiType_componentType(vmId);
     }
 
     @Override
     public RiType exactType() {
+        // TODO is this correct? what's this exactType good for?
+        if (Modifier.isFinal(accessFlags)) {
+            return this;
+        }
         return null;
     }
 
@@ -124,8 +136,7 @@
 
     @Override
     public boolean isInstance(Object obj) {
-
-        return false;
+        throw new UnsupportedOperationException();
     }
 
     @Override
@@ -145,7 +156,7 @@
 
     @Override
     public boolean isSubtypeOf(RiType other) {
-        assert other instanceof HotSpotType  : "unexpected 'other' type: " + other;
+        assert other instanceof HotSpotType : "unexpected 'other' type: " + other;
         if (other instanceof HotSpotTypeResolved)
             return Compiler.getVMEntries().RiType_isSubtypeOf(vmId, other);
         // no resolved type is a subtype of an unresolved type
@@ -168,6 +179,11 @@
     }
 
     @Override
+    public String simpleName() {
+        return name;
+    }
+
+    @Override
     public RiMethod resolveMethodImpl(RiMethod method) {
         assert method instanceof HotSpotMethod;
         return Compiler.getVMEntries().RiType_resolveMethodImpl(vmId, method.name(), method.signature().asString());