pub struct DebugAddr<R> { /* private fields */ }
Expand description
The raw contents of the .debug_addr
section.
Implementations§
source§impl<R: Reader> DebugAddr<R>
impl<R: Reader> DebugAddr<R>
sourcepub fn get_address(
&self,
address_size: u8,
base: DebugAddrBase<R::Offset>,
index: DebugAddrIndex<R::Offset>
) -> Result<u64>
pub fn get_address(
&self,
address_size: u8,
base: DebugAddrBase<R::Offset>,
index: DebugAddrIndex<R::Offset>
) -> Result<u64>
Returns the address at the given base
and index
.
A set of addresses in the .debug_addr
section consists of a header
followed by a series of addresses.
The base
must be the DW_AT_addr_base
value from the compilation unit DIE.
This is an offset that points to the first address following the header.
The index
is the value of a DW_FORM_addrx
attribute.
The address_size
must be the size of the address for the compilation unit.
This value must also match the header. However, note that we do not parse the
header to validate this, since locating the header is unreliable, and the GNU
extensions do not emit it.
source§impl<T> DebugAddr<T>
impl<T> DebugAddr<T>
sourcepub fn borrow<'a, F, R>(&'a self, borrow: F) -> DebugAddr<R>where
F: FnMut(&'a T) -> R,
pub fn borrow<'a, F, R>(&'a self, borrow: F) -> DebugAddr<R>where
F: FnMut(&'a T) -> R,
Create a DebugAddr
section that references the data in self
.
This is useful when R
implements Reader
but T
does not.
Example Usage
// Read the DWARF section into a `Vec` with whatever object loader you're using.
let owned_section: gimli::DebugAddr<Vec<u8>> = load_section();
// Create a reference to the DWARF section.
let section = owned_section.borrow(|section| {
gimli::EndianSlice::new(§ion, gimli::LittleEndian)
});