Class DyldCacheSlideInfoCommon
java.lang.Object
ghidra.app.util.bin.format.macho.dyld.DyldCacheSlideInfoCommon
- All Implemented Interfaces:
StructConverter
- Direct Known Subclasses:
DyldCacheSlideInfo1
,DyldCacheSlideInfo2
,DyldCacheSlideInfo3
,DyldCacheSlideInfo4
,DyldCacheSlideInfo5
Class for representing the common components of the various dyld_cache_slide_info structures.
The intent is for the the full dyld_cache_slide_info structures to extend this and add their
specific parts.
- See Also:
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
static final int
static final int
protected long
protected long
protected long
protected long
protected int
-
Constructor Summary
ConstructorDescriptionDyldCacheSlideInfoCommon
(BinaryReader reader, long mappingAddress, long mappingSize, long mappingFileOffset) Create a newDyldCacheSlideInfoCommon
. -
Method Summary
Modifier and TypeMethodDescriptionvoid
fixupSlidePointers
(Program program, boolean markup, boolean addRelocations, MessageLog log, TaskMonitor monitor) Fixes up the program's slide pointerslong
Returns The base address of where the slide fixups will take place.long
Returns The base file offset of where the slide fixups will take place.long
Returns The size of the slide fixups block.getSlideFixups
(BinaryReader reader, int pointerSize, MessageLog log, TaskMonitor monitor) long
Returns The original slide info offset.int
Returns The version of the DYLD slide info.static DyldCacheSlideInfoCommon
parseSlideInfo
(BinaryReader reader, long slideInfoOffset, long mappingAddress, long mappingSize, long mappingFileOffset, MessageLog log, TaskMonitor monitor) Parses the slide infoReturns a structure datatype representing the contents of the implementor of this interface.
-
Field Details
-
DATA_PAGE_MAP_ENTRY
public static final int DATA_PAGE_MAP_ENTRY- See Also:
-
BYTES_PER_CHAIN_OFFSET
public static final int BYTES_PER_CHAIN_OFFSET- See Also:
-
CHAIN_OFFSET_MASK
public static final int CHAIN_OFFSET_MASK- See Also:
-
version
protected int version -
slideInfoOffset
protected long slideInfoOffset -
mappingAddress
protected long mappingAddress -
mappingSize
protected long mappingSize -
mappingFileOffset
protected long mappingFileOffset
-
-
Constructor Details
-
DyldCacheSlideInfoCommon
public DyldCacheSlideInfoCommon(BinaryReader reader, long mappingAddress, long mappingSize, long mappingFileOffset) throws IOException Create a newDyldCacheSlideInfoCommon
.- Parameters:
reader
- ABinaryReader
positioned at the start of a DYLD slide infomappingAddress
- The base address of where the slide fixups will take placemappingSize
- The size of the slide fixups blockmappingFileOffset
- The base file offset of where the slide fixups will take place- Throws:
IOException
- if there was an IO-related problem creating the DYLD slide info
-
-
Method Details
-
parseSlideInfo
public static DyldCacheSlideInfoCommon parseSlideInfo(BinaryReader reader, long slideInfoOffset, long mappingAddress, long mappingSize, long mappingFileOffset, MessageLog log, TaskMonitor monitor) Parses the slide info- Parameters:
reader
- ABinaryReader
positioned at the start of a DYLD slide infoslideInfoOffset
- The offset of the slide info to parsemappingAddress
- The base address of where the slide fixups will take placemappingSize
- The size of the slide fixups blockmappingFileOffset
- The base file offset of where the slide fixups will take placelog
- The logmonitor
- A cancelable task monitor- Returns:
- The slide info object
-
getVersion
public int getVersion()Returns The version of the DYLD slide info.- Returns:
- The version of the DYLD slide info
-
getSlideInfoOffset
public long getSlideInfoOffset()Returns The original slide info offset.- Returns:
- The original slide info offset
-
getMappingAddress
public long getMappingAddress()Returns The base address of where the slide fixups will take place.- Returns:
- The base address of where the slide fixups will take place
-
getMappingSize
public long getMappingSize()Returns The size of the slide fixups block.- Returns:
- The size of the slide fixups block
-
getMappingFileOffset
public long getMappingFileOffset()Returns The base file offset of where the slide fixups will take place.- Returns:
- The base file offset of where the slide fixups will take place
-
getSlideFixups
public abstract List<DyldFixup> getSlideFixups(BinaryReader reader, int pointerSize, MessageLog log, TaskMonitor monitor) throws IOException, CancelledException Walks the slide fixup information and collects aList
ofDyldFixup
s that will need to be applied to the image- Parameters:
reader
- ABinaryReader
positioned at the start of the segment to fix uppointerSize
- The size of a pointer in byteslog
- The logmonitor
- A cancellable monitor- Returns:
- A
List
ofDyldFixup
s - Throws:
IOException
- If there was an IO-related issueCancelledException
- If the user cancelled the operation
-
fixupSlidePointers
public void fixupSlidePointers(Program program, boolean markup, boolean addRelocations, MessageLog log, TaskMonitor monitor) throws MemoryAccessException, CancelledException Fixes up the program's slide pointers- Parameters:
program
- TheProgram
markup
- True if the slide pointers should be marked up; otherwise, falseaddRelocations
- True if slide pointer locations should be added to the relocation table; otherwise, falselog
- The logmonitor
- A cancellable monitor- Throws:
MemoryAccessException
- If there was a problem accessing memoryCancelledException
- If the user cancelled the operation
-
toDataType
Description copied from interface:StructConverter
Returns a structure datatype representing the contents of the implementor of this interface.For example, given:
class A { int foo; double bar; }
The return value should be a structure data type with two data type components; an INT and a DOUBLE. The structure should contain field names and, if possible, field comments.
- Specified by:
toDataType
in interfaceStructConverter
- Returns:
- returns a structure datatype representing the implementor of this interface
- Throws:
DuplicateNameException
- when a datatype of the same name already existsIOException
- if an IO-related error occurs- See Also:
-