2010-06-09 00:52:24 +08:00
|
|
|
//===-- DWARFCompileUnit.h --------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2010-06-09 00:52:24 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2011-09-13 07:21:58 +08:00
|
|
|
#ifndef SymbolFileDWARF_DWARFCompileUnit_h_
|
2010-06-09 00:52:24 +08:00
|
|
|
#define SymbolFileDWARF_DWARFCompileUnit_h_
|
|
|
|
|
2018-03-19 04:09:02 +08:00
|
|
|
#include "DWARFUnit.h"
|
2019-03-16 01:32:05 +08:00
|
|
|
#include "llvm/Support/Error.h"
|
2010-09-15 12:15:46 +08:00
|
|
|
|
2018-03-19 04:09:02 +08:00
|
|
|
class DWARFCompileUnit : public DWARFUnit {
|
2010-06-09 00:52:24 +08:00
|
|
|
public:
|
DWARF: Don't compute address ranges for type units
Summary:
Type units don't describe any code, so they should never be the result
of any address lookup queries.
Previously, we would compute the address ranges for the type units for
via the line tables they reference because the type units looked a lot
like line-tables-only compile units. However, this is not correct, as
the line tables are only referenced from type units so that other
declarations can use the file names contained in them.
In this patch I make the BuildAddressRangeTable function virtual, and
implement it only for compile units.
Testing this was a bit tricky, because the behavior depends on the order
in which we add things to the address range map. This rarely caused a
problem with DWARF v4 type units, as they are always added after all
CUs. It happened more frequently with DWARF v5, as there clang emits the
type units first. However, this is still not something that it is
required to do, so for testing I've created an assembly file where I've
deliberately sandwiched a compile unit between two type units, which
should isolate us from both changes in how the compiler emits the units
and changes in the order we process them.
Reviewers: clayborg, aprantl, JDevlieghere
Subscribers: jdoerfert, lldb-commits
Differential Revision: https://reviews.llvm.org/D62178
llvm-svn: 361465
2019-05-23 17:07:51 +08:00
|
|
|
void BuildAddressRangeTable(DWARFDebugAranges *debug_aranges) override;
|
|
|
|
|
2018-04-14 19:12:52 +08:00
|
|
|
void Dump(lldb_private::Stream *s) const override;
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2019-06-12 19:29:50 +08:00
|
|
|
static bool classof(const DWARFUnit *unit) { return !unit->IsTypeUnit(); }
|
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
private:
|
2019-06-14 21:01:16 +08:00
|
|
|
DWARFCompileUnit(SymbolFileDWARF &dwarf, lldb::user_id_t uid,
|
2019-05-21 15:22:34 +08:00
|
|
|
const DWARFUnitHeader &header,
|
2019-05-22 17:09:39 +08:00
|
|
|
const DWARFAbbreviationDeclarationSet &abbrevs,
|
2019-12-18 00:12:29 +08:00
|
|
|
DIERef::Section section, bool is_dwo)
|
|
|
|
: DWARFUnit(dwarf, uid, header, abbrevs, section, is_dwo) {}
|
2019-05-21 15:22:34 +08:00
|
|
|
|
2010-06-09 00:52:24 +08:00
|
|
|
DISALLOW_COPY_AND_ASSIGN(DWARFCompileUnit);
|
2019-05-21 15:22:34 +08:00
|
|
|
|
|
|
|
friend class DWARFUnit;
|
2010-06-09 00:52:24 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // SymbolFileDWARF_DWARFCompileUnit_h_
|