Source/PLCrashAsyncDwarfFDE.hpp (32 lines of code) (raw):
/*
* Copyright (c) 2013 Plausible Labs Cooperative, Inc.
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef PLCRASH_ASYNC_DWARF_FDE_H
#define PLCRASH_ASYNC_DWARF_FDE_H 1
#include "PLCrashAsync.h"
#include "PLCrashAsyncImageList.h"
#include "PLCrashAsyncThread.h"
#include "PLCrashFeatureConfig.h"
#include "PLCrashMacros.h"
#if PLCRASH_FEATURE_UNWIND_DWARF
PLCR_CPP_BEGIN_NS
namespace async {
/**
* @internal
* @ingroup plcrash_async_dwarf
* @{
*/
/**
* @internal
*
* DWARF Frame Descriptor Entry.
*/
typedef struct plcrash_async_dwarf_fde_info {
/** The starting address of the entry (not including the initial length field),
* relative to the eh_frame/debug_frame section base. */
pl_vm_address_t fde_offset;
/** The FDE entry length, not including the initial length field. */
uint64_t fde_length;
/** Offset to the CIE associated with this FDE, relative to the eh_frame/debug_frame section base. */
pl_vm_address_t cie_offset;
/** The start of the IP range covered by this FDE. The address is the in-memory load address, rather than the on-disk VM address. */
uint64_t pc_start;
/** The end of the IP range covered by this FDE (exclusive). he address is the in-memory load address, rather than the on-disk VM address.*/
uint64_t pc_end;
/** The address of the FDE instructions, relative to the eh_frame/debug_frame section base. */
pl_vm_address_t instructions_offset;
/** The length, in bytes, of the FDE instructions. */
pl_vm_size_t instructions_length;
} plcrash_async_dwarf_fde_info_t;
template <typename machine_ptr>
plcrash_error_t plcrash_async_dwarf_fde_info_init (plcrash_async_dwarf_fde_info_t *info,
plcrash_async_mobject_t *mobj,
const plcrash_async_byteorder_t *byteorder,
pl_vm_address_t fde_address,
bool debug_frame);
pl_vm_address_t plcrash_async_dwarf_fde_info_instructions_offset (plcrash_async_dwarf_fde_info_t *info);
pl_vm_size_t plcrash_async_dwarf_fde_info_instructions_length (plcrash_async_dwarf_fde_info_t *info);
void plcrash_async_dwarf_fde_info_free (plcrash_async_dwarf_fde_info_t *fde_info);
/*
* @}
*/
}
PLCR_CPP_END_NS
#endif /* PLCRASH_FEATURE_UNWIND_DWARF */
#endif /* !PLCRASH_ASYNC_DWARF_FDE_H */