mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
4ca606f22f
This change implements basic support for DWARF alternate sections proposal: http://www.dwarfstd.org/ShowIssue.php?issue=120604.1&type=open LLVM tools now understand new forms: DW_FORM_GNU_ref_alt and DW_FORM_GNU_strp_alt, which are used as references to .debug_info and .debug_str sections respectively, stored in a separate file, and possibly shared between different executables / shared objects. llvm-dwarfdump and llvm-symbolizer don't yet know how to access this alternate debug file (usually pointed by .gnu_debugaltlink section), but they can at lease properly parse and dump regular files, which refer to it. This change should fix crashes of llvm-dwarfdump and llvm-symbolizer on files produced by running "dwz" tool. Such files are already installed on some modern Linux distributions. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@237721 91177308-0d34-0410-b5e6-96231b3b80d8
97 lines
2.8 KiB
C++
97 lines
2.8 KiB
C++
//===-- DWARFFormValue.h ----------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_DEBUGINFO_DWARFFORMVALUE_H
|
|
#define LLVM_DEBUGINFO_DWARFFORMVALUE_H
|
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
#include "llvm/ADT/Optional.h"
|
|
#include "llvm/Support/DataExtractor.h"
|
|
|
|
namespace llvm {
|
|
|
|
class DWARFUnit;
|
|
class raw_ostream;
|
|
|
|
class DWARFFormValue {
|
|
public:
|
|
enum FormClass {
|
|
FC_Unknown,
|
|
FC_Address,
|
|
FC_Block,
|
|
FC_Constant,
|
|
FC_String,
|
|
FC_Flag,
|
|
FC_Reference,
|
|
FC_Indirect,
|
|
FC_SectionOffset,
|
|
FC_Exprloc
|
|
};
|
|
|
|
private:
|
|
struct ValueType {
|
|
ValueType() : data(nullptr) {
|
|
uval = 0;
|
|
}
|
|
|
|
union {
|
|
uint64_t uval;
|
|
int64_t sval;
|
|
const char* cstr;
|
|
};
|
|
const uint8_t* data;
|
|
};
|
|
|
|
uint16_t Form; // Form for this value.
|
|
ValueType Value; // Contains all data for the form.
|
|
|
|
public:
|
|
DWARFFormValue(uint16_t Form = 0) : Form(Form) {}
|
|
uint16_t getForm() const { return Form; }
|
|
bool isFormClass(FormClass FC) const;
|
|
|
|
void dump(raw_ostream &OS, const DWARFUnit *U) const;
|
|
|
|
/// \brief extracts a value in data at offset *offset_ptr.
|
|
///
|
|
/// The passed DWARFUnit is allowed to be nullptr, in which
|
|
/// case no relocation processing will be performed and some
|
|
/// kind of forms that depend on Unit information are disallowed.
|
|
/// \returns whether the extraction succeeded.
|
|
bool extractValue(DataExtractor data, uint32_t *offset_ptr,
|
|
const DWARFUnit *u);
|
|
bool isInlinedCStr() const {
|
|
return Value.data != nullptr && Value.data == (const uint8_t*)Value.cstr;
|
|
}
|
|
|
|
/// getAsFoo functions below return the extracted value as Foo if only
|
|
/// DWARFFormValue has form class is suitable for representing Foo.
|
|
Optional<uint64_t> getAsReference(const DWARFUnit *U) const;
|
|
Optional<uint64_t> getAsUnsignedConstant() const;
|
|
Optional<int64_t> getAsSignedConstant() const;
|
|
Optional<const char *> getAsCString(const DWARFUnit *U) const;
|
|
Optional<uint64_t> getAsAddress(const DWARFUnit *U) const;
|
|
Optional<uint64_t> getAsSectionOffset() const;
|
|
Optional<ArrayRef<uint8_t>> getAsBlock() const;
|
|
|
|
bool skipValue(DataExtractor debug_info_data, uint32_t *offset_ptr,
|
|
const DWARFUnit *u) const;
|
|
static bool skipValue(uint16_t form, DataExtractor debug_info_data,
|
|
uint32_t *offset_ptr, const DWARFUnit *u);
|
|
|
|
static ArrayRef<uint8_t> getFixedFormSizes(uint8_t AddrSize,
|
|
uint16_t Version);
|
|
private:
|
|
void dumpString(raw_ostream &OS, const DWARFUnit *U) const;
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|