/* * This file is part of the Jikes RVM project (http://jikesrvm.org). * * This file is licensed to You under the Common Public License (CPL); * You may not use this file except in compliance with the License. You * may obtain a copy of the License at * * http://www.opensource.org/licenses/cpl1.0.php * * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. */ package org.jikesrvm.ia32; import org.jikesrvm.ArchitectureSpecific; import org.jikesrvm.VM; import org.jikesrvm.memorymanagers.mminterface.MM_Interface; import org.vmmagic.pragma.Uninterruptible; /** * VM_CodeArray represents a code object (contiguous memory region containing code). * The types of the access methods are platform-dependent. */ @Uninterruptible public abstract class VM_CodeArray extends org.jikesrvm.VM_CodeArray { private byte[] data; public VM_CodeArray(int size) { if (VM.runningVM) VM._assert(false); // should be unreachable data = new byte[size]; } public byte get(int index) { if (VM.runningVM) VM._assert(false); // should be hijacked return data[index]; } public void set(int index, byte v) { if (VM.runningVM) VM._assert(false); // should be hijacked data[index] = v; } public int length() { if (VM.runningVM) VM._assert(false); // should be hijacked return data.length; } public Object getBacking() { if (!VM.writingImage) { VM.sysFail("VM_CodeArray.getBacking called when not writing boot image"); } return data; } /** * A helper class to contain the 'real' methods of VM_CodeArray. * Because Jikes RVM believes that VM_CodeArray is really a Code[] * (ie, an array of primitives), we cannot define non-hijacked methods * on the 'class' VM_CodeArray. */ public static class Factory { /** * Allocate a code array big enough to contain numInstrs instructions. * @param numInstrs the number of instructions to copy from instrs * @param isHot is this an allocation of code for a hot method? * @return a VM_CodeArray containing the instructions */ public static ArchitectureSpecific.VM_CodeArray create(int numInstrs, boolean isHot) { if (VM.runningVM) { return MM_Interface.allocateCode(numInstrs, isHot); } else { return ArchitectureSpecific.VM_CodeArray.create(numInstrs); } } } }