Mercurial > hg > truffle
view c1x4hotspotsrc/HotSpotVM/src/com/sun/hotspot/c1x/InvocationSocket.java @ 1936:8d88c9ac9247
Correct deopt handler entry. New flag -XX:+TraceSignals. More detailed deopt printing.
author | Thomas Wuerthinger <wuerthinger@ssw.jku.at> |
---|---|
date | Thu, 23 Dec 2010 18:13:28 +0100 |
parents | 9e5e83ca2259 |
children | 569d3fe7d65c |
line wrap: on
line source
/* * Copyright (c) 2010 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 java.io.*; import java.lang.reflect.*; import com.sun.hotspot.c1x.logging.*; /** * A java.lang.reflect proxy that communicates over a socket connection. * * Calling a method sends the method name and the parameters through the socket. Afterwards this class waits for a result. * While waiting for a result three types of objects can arrive through the socket: a method invocation, a method result or an exception. * Method invocation can thus be recursive. * * @author Lukas Stadler */ public class InvocationSocket implements InvocationHandler { private final ObjectOutputStream output; private final ObjectInputStream input; private Object delegate; public InvocationSocket(ObjectOutputStream output, ObjectInputStream input) { this.output = output; this.input = input; } public void setDelegate(Object delegate) { this.delegate = delegate; } private static class Invocation implements Serializable { public String methodName; public Object[] args; public Invocation(String methodName, Object[] args) { this.methodName = methodName; this.args = args; } } private static class Result implements Serializable { public Object result; public Result(Object result) { this.result = result; } } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { try { Logger.startScope("invoking remote " + method.getName()); output.writeObject(new Invocation(method.getName(), args)); output.flush(); return waitForResult(); } catch (Throwable t) { t.printStackTrace(); throw t; } finally { Logger.endScope(""); } } public Object waitForResult() throws IOException, ClassNotFoundException { while (true) { Object in = input.readObject(); if (in instanceof Result) { return ((Result) in).result; } else if (in instanceof RuntimeException) { throw (RuntimeException) in; } else if (in instanceof Throwable) { throw new RuntimeException((Throwable) in); } Invocation invoke = (Invocation) in; Method method = null; for (Method m : delegate.getClass().getDeclaredMethods()) { if (invoke.methodName.equals(m.getName())) { method = m; break; } } if (method == null) { Exception e = new UnsupportedOperationException("unknown method " + invoke.methodName); e.printStackTrace(); output.writeObject(e); output.flush(); } else { Object result; try { Logger.startScope("invoking local " + invoke.methodName); if (invoke.args == null) { result = method.invoke(delegate); } else { result = method.invoke(delegate, invoke.args); } result = new Result(result); } catch (IllegalArgumentException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } catch (InvocationTargetException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } catch (IllegalAccessException e) { System.out.println("error while invoking " + invoke.methodName); e.getCause().printStackTrace(); result = e.getCause(); } finally { Logger.endScope(""); } output.writeObject(result); output.flush(); } } } }