Mercurial > hg > truffle
diff agent/src/share/classes/sun/jvm/hotspot/debugger/posix/DSO.java @ 0:a61af66fc99e jdk7-b24
Initial load
author | duke |
---|---|
date | Sat, 01 Dec 2007 00:00:00 +0000 |
parents | |
children | c18cbe5936b8 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/agent/src/share/classes/sun/jvm/hotspot/debugger/posix/DSO.java Sat Dec 01 00:00:00 2007 +0000 @@ -0,0 +1,160 @@ +/* + * Copyright 2001-2003 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + * + */ +package sun.jvm.hotspot.debugger.posix; + +import sun.jvm.hotspot.debugger.*; +import sun.jvm.hotspot.debugger.cdbg.*; +import sun.jvm.hotspot.debugger.posix.elf.*; +import sun.jvm.hotspot.utilities.memo.*; + +/** Provides a simple wrapper around the ELF library which handles + relocation. */ +public abstract class DSO implements LoadObject { + + private MemoizedObject file; // contains ELFFile + private String filename; + private Address addr; + private long size; + private IsDSO dso = new IsDSO(); + + class IsDSO extends MemoizedBoolean { + protected boolean computeValue() { + return getFile().getHeader().getFileType() == ELFHeader.FT_DYN; + } + }; + + class ELFFileByName extends MemoizedObject { + protected Object computeValue() { + return ELFFileParser.getParser().parse(DSO.this.filename); + } + }; + + class ELFFileByAddress extends MemoizedObject { + protected Object computeValue() { + return ELFFileParser.getParser().parse(new AddressDataSource(DSO.this.addr)); + } + }; + + public DSO(String filename, long size, Address relocation) throws ELFException { + this.filename = filename; + this.size = size; + this.addr = relocation; + this.file = new ELFFileByName(); + } + + public DSO(long size, Address relocation) throws ELFException { + this.addr = relocation; + this.size = size; + this.file = new ELFFileByAddress(); + } + + public String getName() { + return filename; + } + + public Address getBase() { + return addr; + } + + /** if this .so is unloaded and re-loaded in the same process at a different + base, change the base by calling this to avoid re-parsing the ELF. */ + public void setBase(Address newBase) { + addr = newBase; + if (filename == null) { + // ELFFile was created by address. we have to re-parse it. + file = new ELFFileByAddress(); + dso = new IsDSO(); + } + } + + public long getSize() { + return size; + } + + public CDebugInfoDataBase getDebugInfoDataBase() throws DebuggerException { + // FIXME: after stabs parser + return null; + } + + public BlockSym debugInfoForPC(Address pc) throws DebuggerException { + // FIXME: after stabs parser + return null; + } + + public ClosestSymbol closestSymbolToPC(Address pcAsAddr) throws DebuggerException { + boolean dso = isDSO(); + long offset = dso? pcAsAddr.minus(addr) : getAddressValue(pcAsAddr); + ELFSymbol sym = getFile().getHeader().getELFSymbol(offset); + return (sym != null)? createClosestSymbol(sym.getName(), offset - sym.getValue()) : null; + } + + public LineNumberInfo lineNumberForPC(Address pc) throws DebuggerException { + // FIXME: after stabs parser + return null; + } + + /** return true if file is a .so */ + public boolean isDSO() { + return dso.getValue(); + } + + /** Look up a symbol; returns absolute address or null if symbol was + not found. */ + public Address lookupSymbol(String symbol) throws ELFException { + ELFSymbol sym = getFile().getHeader().getELFSymbol(symbol); + if (sym == null) { + return null; + } + + long value = sym.getValue(); + if (isDSO()) { + return addr.addOffsetTo(value); + } else { + return newAddress(value); + } + } + + public boolean equals(Object o) { + if (o == null || !(o instanceof DSO)) { + return false; + } + DSO other = (DSO)o; + return getBase().equals(other.getBase()); + } + + public int hashCode() { + return getBase().hashCode(); + } + + protected ELFFile getFile() { + return (ELFFile) file.getValue(); + } + + protected abstract Address newAddress(long addr); + protected abstract long getAddressValue(Address addr); + + protected ClosestSymbol createClosestSymbol(String name, long diff) { + return new ClosestSymbol(name, diff); + } +}