package sun.jvm.hotspot.oops;
import sun.jvm.hotspot.utilities.Observable;
import sun.jvm.hotspot.utilities.Observer;
import sun.jvm.hotspot.debugger.Address;
import sun.jvm.hotspot.runtime.VM;
import sun.jvm.hotspot.types.AddressField;
import sun.jvm.hotspot.types.CIntegerField;
import sun.jvm.hotspot.types.Type;
import sun.jvm.hotspot.types.TypeDataBase;
public class CompressedOops {
private static AddressField baseField;
private static CIntegerField shiftField;
public enum Mode {
UnscaledNarrowOop,
ZeroBasedNarrowOop,
HeapBasedNarrowOop
}
static {
VM.registerVMInitializedObserver(new Observer() {
public void update(Observable o, Object data) {
initialize(VM.getVM().getTypeDataBase());
}
});
}
private static boolean typeExists(TypeDataBase db, String type) {
try {
db.lookupType(type);
} catch (RuntimeException e) {
return false;
}
return true;
}
private static synchronized void initialize(TypeDataBase db) {
Type type = db.lookupType("CompressedOops");
baseField = type.getAddressField("_narrow_oop._base");
shiftField = type.getCIntegerField("_narrow_oop._shift");
}
public CompressedOops() {
}
public static String modeToString(Mode mode) {
switch (mode) {
case UnscaledNarrowOop:
return "32-bits Oops";
case ZeroBasedNarrowOop:
return "zero based Compressed Oops";
case HeapBasedNarrowOop:
return "Compressed Oops with base";
}
return "";
}
public static long getBase() {
if (baseField.getValue() == null) {
return 0;
} else {
return baseField.getValue().minus(null);
}
}
public static int getShift() {
return (int)shiftField.getValue();
}
}