Mercurial > hg > truffle
view graal/GraalCompiler/src/com/sun/c1x/asm/TargetMethodAssembler.java @ 2763:5e8a69041cd7
Model phi inputs as direct inputs in the graph instead of referring to the framestates of the predecessors.
author | Thomas Wuerthinger <thomas@wuerthinger.net> |
---|---|
date | Mon, 23 May 2011 14:51:18 +0200 |
parents | c1ce2a53d6c3 |
children | 1cd59ca9ac86 |
line wrap: on
line source
/* * Copyright (c) 2011, 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.sun.c1x.asm; import java.util.*; import com.oracle.max.asm.*; import com.sun.c1x.*; import com.sun.c1x.debug.*; import com.sun.c1x.lir.*; import com.sun.c1x.util.*; import com.sun.cri.ci.*; import com.sun.cri.ri.*; public class TargetMethodAssembler { public final AbstractAssembler asm; public final CiTargetMethod targetMethod; public List<ExceptionInfo> exceptionInfoList; protected int lastSafepointPos; public TargetMethodAssembler(AbstractAssembler asm) { this.asm = asm; this.targetMethod = new CiTargetMethod(); } public void setFrameSize(int frameSize) { targetMethod.setFrameSize(frameSize); } public CiTargetMethod.Mark recordMark(Object id, CiTargetMethod.Mark[] references) { return targetMethod.recordMark(asm.codeBuffer.position(), id, references); } public void blockComment(String s) { targetMethod.addAnnotation(new CiTargetMethod.CodeComment(asm.codeBuffer.position(), s)); } public CiTargetMethod finishTargetMethod(Object name, RiRuntime runtime, int registerRestoreEpilogueOffset, boolean isStub) { // Install code, data and frame size targetMethod.setTargetCode(asm.codeBuffer.close(false), asm.codeBuffer.position()); targetMethod.setRegisterRestoreEpilogueOffset(registerRestoreEpilogueOffset); // Record exception handlers if they exist if (exceptionInfoList != null) { for (ExceptionInfo ei : exceptionInfoList) { int codeOffset = ei.codeOffset; targetMethod.recordExceptionHandler(codeOffset, -1, 0, ei.exceptionEdge.blockEntryPco, -1, null); } } if (C1XOptions.PrintMetrics) { C1XMetrics.TargetMethods++; C1XMetrics.CodeBytesEmitted += targetMethod.targetCodeSize(); C1XMetrics.SafepointsEmitted += targetMethod.safepoints.size(); C1XMetrics.DirectCallSitesEmitted += targetMethod.directCalls.size(); C1XMetrics.IndirectCallSitesEmitted += targetMethod.indirectCalls.size(); C1XMetrics.DataPatches += targetMethod.dataReferences.size(); C1XMetrics.ExceptionHandlersEmitted += targetMethod.exceptionHandlers.size(); } if (C1XOptions.PrintAssembly && !TTY.isSuppressed() && !isStub) { Util.printSection("Target Method", Util.SECTION_CHARACTER); TTY.println("Name: " + name); TTY.println("Frame size: " + targetMethod.frameSize()); TTY.println("Register size: " + asm.target.arch.registerReferenceMapBitCount); if (C1XOptions.PrintCodeBytes) { Util.printSection("Code", Util.SUB_SECTION_CHARACTER); TTY.println("Code: %d bytes", targetMethod.targetCodeSize()); Util.printBytes(0L, targetMethod.targetCode(), 0, targetMethod.targetCodeSize(), C1XOptions.PrintAssemblyBytesPerLine); } Util.printSection("Disassembly", Util.SUB_SECTION_CHARACTER); String disassembly = runtime.disassemble(targetMethod); TTY.println(disassembly); boolean noDis = disassembly == null || disassembly.length() == 0; Util.printSection("Safepoints", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.Safepoint x : targetMethod.safepoints) { TTY.println(x.toString()); if (noDis && x.debugInfo != null) { TTY.println(CiUtil.indent(x.debugInfo.toString(), " ")); } } Util.printSection("Direct Call Sites", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.Call x : targetMethod.directCalls) { TTY.println(x.toString()); if (noDis && x.debugInfo != null) { TTY.println(CiUtil.indent(x.debugInfo.toString(), " ")); } } Util.printSection("Indirect Call Sites", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.Call x : targetMethod.indirectCalls) { TTY.println(x.toString()); if (noDis && x.debugInfo != null) { TTY.println(CiUtil.indent(x.debugInfo.toString(), " ")); } } Util.printSection("Data Patches", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.DataPatch x : targetMethod.dataReferences) { TTY.println(x.toString()); } Util.printSection("Marks", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.Mark x : targetMethod.marks) { TTY.println(x.toString()); } Util.printSection("Exception Handlers", Util.SUB_SECTION_CHARACTER); for (CiTargetMethod.ExceptionHandler x : targetMethod.exceptionHandlers) { TTY.println(x.toString()); } } return targetMethod; } public void recordExceptionHandlers(int pcOffset, LIRDebugInfo info) { if (info != null) { if (info.exceptionEdge != null) { if (exceptionInfoList == null) { exceptionInfoList = new ArrayList<ExceptionInfo>(4); } exceptionInfoList.add(new ExceptionInfo(pcOffset, info.exceptionEdge, info.state.bci)); } } } public void recordImplicitException(int pcOffset, LIRDebugInfo info) { // record an implicit exception point if (info != null) { assert lastSafepointPos < pcOffset; lastSafepointPos = pcOffset; targetMethod.recordSafepoint(pcOffset, info.debugInfo()); recordExceptionHandlers(pcOffset, info); } } public void recordDirectCall(int posBefore, int posAfter, Object target, LIRDebugInfo info) { CiDebugInfo debugInfo = info != null ? info.debugInfo() : null; assert lastSafepointPos < posAfter; lastSafepointPos = posAfter; targetMethod.recordCall(posBefore, target, debugInfo, true); } public void recordIndirectCall(int posBefore, int posAfter, Object target, LIRDebugInfo info) { CiDebugInfo debugInfo = info != null ? info.debugInfo() : null; assert lastSafepointPos < posAfter; lastSafepointPos = posAfter; targetMethod.recordCall(posBefore, target, debugInfo, false); } public void recordSafepoint(int pos, LIRDebugInfo info) { // safepoints always need debug info CiDebugInfo debugInfo = info.debugInfo(); assert lastSafepointPos < pos; lastSafepointPos = pos; targetMethod.recordSafepoint(pos, debugInfo); } public CiAddress recordDataReferenceInCode(CiConstant data) { assert data != null; int pos = asm.codeBuffer.position(); if (C1XOptions.TraceRelocation) { TTY.print("Data reference in code: pos = %d, data = %s", pos, data.toString()); } targetMethod.recordDataReference(pos, data); return CiAddress.Placeholder; } public int lastSafepointPos() { return lastSafepointPos; } }