Mercurial > hg > graal-compiler
view c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/VMExitsNative.java @ 1421:6223633ce7dd
changed VMExit/VMEntries to non-static, added eclipse c++ project, CIR interface changes
author | Lukas Stadler <lukas.stadler@oracle.com> |
---|---|
date | Fri, 23 Jul 2010 15:53:02 -0700 |
parents | c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/VMExits.java@44efca8a02d6 |
children | 3483ec571caf |
line wrap: on
line source
/* * Copyright (c) 2009 Sun Microsystems, Inc. All rights reserved. * * Sun Microsystems, Inc. has intellectual property rights relating to technology embodied in the product that is * described in this document. In particular, and without limitation, these intellectual property rights may include one * or more of the U.S. patents listed at http://www.sun.com/patents and one or more additional patents or pending patent * applications in the U.S. and in other countries. * * U.S. Government Rights - Commercial software. Government users are subject to the Sun Microsystems, Inc. standard * license agreement and applicable provisions of the FAR and its supplements. * * Use is subject to license terms. Sun, Sun Microsystems, the Sun logo, Java and Solaris are trademarks or registered * trademarks of Sun Microsystems, Inc. in the U.S. and other countries. All SPARC trademarks are used under license and * are trademarks or registered trademarks of SPARC International, Inc. in the U.S. and other countries. * * UNIX is a registered trademark in the U.S. and other countries, exclusively licensed through X/Open Company, Ltd. */ package com.sun.hotspot.c1x; import com.sun.cri.ci.*; import com.sun.cri.ri.*; /** * * @author Thomas Wuerthinger * * Exits from the HotSpot VM into Java code. * */ public class VMExitsNative implements VMExits { @Override public void compileMethod(RiMethod method, int entry_bci) { try { assert method instanceof RiMethod : "And YES, this assert is necessary and a potential life saver as this method is called from the VM ;-)"; Compiler compiler = Compiler.getInstance(); CiResult result = compiler.getCompiler().compileMethod(method, null); if (result.bailout() != null) { System.out.println("Bailout:"); result.bailout().printStackTrace(); } else { System.out.println("Compilation result: "); System.out.println(result.targetMethod()); HotSpotTargetMethod.installCode(compiler.getConfig(), method, result.targetMethod()); } } catch (Throwable t) { System.out.println("Compilation interrupted:"); t.printStackTrace(); if (t instanceof RuntimeException) { throw (RuntimeException) t; } throw new RuntimeException(t); } } @Override public RiMethod createRiMethod(Object methodOop) { System.out.println("creating RiMethod object"); RiMethod m = new HotSpotMethod(methodOop); System.out.println("returning " + m); return m; } @Override public RiSignature createRiSignature(Object symbolOop) { System.out.println("Creating RiSignature object"); String name = Compiler.getVMEntries().RiSignature_symbolToString(symbolOop); System.out.println("Signature name: " + name); return new HotSpotSignature(name); } @Override public RiField createRiField(RiType holder, Object nameSymbol, RiType type, int offset) { System.out.println("creating RiField object"); return new HotSpotField(holder, nameSymbol, type, offset); } @Override public RiType createRiType(Object klassOop) { System.out.println("creating RiType object"); return new HotSpotType(klassOop); } @Override public RiType createRiTypePrimitive(int basicType) { System.out.println("Creating primitive type with basicType " + basicType); CiKind kind = null; switch (basicType) { case 4: kind = CiKind.Boolean; break; case 5: kind = CiKind.Char; break; case 6: kind = CiKind.Float; break; case 7: kind = CiKind.Double; break; case 8: kind = CiKind.Byte; break; case 9: kind = CiKind.Short; break; case 10: kind = CiKind.Int; break; case 11: kind = CiKind.Long; break; case 14: kind = CiKind.Void; break; default: throw new IllegalArgumentException("Unknown basic type: " + basicType); } System.out.println("Chosen kind: " + kind); return new HotSpotTypePrimitive(kind); } @Override public RiType createRiTypeUnresolved(Object symbolOop, Object accessingKlassOop) { System.out.println("Creating unresolved RiType object"); String name = Compiler.getVMEntries().RiSignature_symbolToString(symbolOop); System.out.println("Class name: " + name); return new HotSpotTypeUnresolved(name); } @Override public RiConstantPool createRiConstantPool(Object constantPoolOop) { System.out.println("creating RiConstantPool object"); return new HotSpotConstantPool(constantPoolOop); } @Override public CiConstant createCiConstantInt(int value) { return CiConstant.forInt(value); } @Override public CiConstant createCiConstantLong(long value) { return CiConstant.forLong(value); } @Override public CiConstant createCiConstantFloat(float value) { return CiConstant.forFloat(value); } @Override public CiConstant createCiConstantDouble(double value) { return CiConstant.forDouble(value); } @Override public CiConstant createCiConstantObject(Object value) { return CiConstant.forObject(value); } @Override public void main(String[] args) throws InterruptedException { System.out.println(C1XHotSpotTests.add(1, 2)); Thread.sleep(5000); System.out.println(C1XHotSpotTests.add(1, 2)); } }