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)
});