|
reference, declaration → definition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
|
Derived Classes
tools/lld/lib/ReaderWriter/YAML/ReaderWriterYAML.cpp 1139 class NormalizedAtom : public lld::AbsoluteAtom {
Declarations
tools/lld/include/lld/Core/SymbolTable.h 21 class AbsoluteAtom;
References
include/llvm/Support/Casting.h 58 return To::classof(&Val);
106 return isa_impl<To, From>::doit(*Val);
122 return isa_impl_wrap<To, SimpleFrom,
132 return isa_impl_cl<To,FromTy>::doit(Val);
142 return isa_impl_wrap<X, const Y,
172 using ret_type = To *; // Pointer arg case, return Ty*
176 using ret_type = const To *; // Constant pointer arg case, return const Ty*
198 using ret_type = typename cast_retty<To, SimpleFrom>::ret_type;
204 using ret_type = typename cast_retty_impl<To,FromTy>::ret_type;
210 To, From, typename simplify_type<From>::SimpleType>::ret_type;
227 static typename cast_retty<To, FromTy>::ret_type doit(const FromTy &Val) {
228 typename cast_retty<To, FromTy>::ret_type Res2
256 inline typename cast_retty<X, Y>::ret_type cast(Y &Val) {
263 inline typename cast_retty<X, Y *>::ret_type cast(Y *Val) {
265 return cast_convert_val<X, Y*,
337 LLVM_NODISCARD inline typename cast_retty<X, Y>::ret_type dyn_cast(Y &Val) {
342 LLVM_NODISCARD inline typename cast_retty<X, Y *>::ret_type dyn_cast(Y *Val) {
343 return isa<X>(Val) ? cast<X>(Val) : nullptr;
343 return isa<X>(Val) ? cast<X>(Val) : nullptr;
tools/lld/include/lld/Core/AbsoluteAtom.h 34 static bool classof(const AbsoluteAtom *) { return true; }
tools/lld/include/lld/Core/Atom.h 88 OwningAtomPtr(T *atom) : atom(atom) { }
110 T *const &get() const {
114 T *&get() {
118 T *release() {
119 auto *v = atom;
125 T *atom = nullptr;
tools/lld/include/lld/Core/File.h 114 AtomRange(AtomVector<T> &v) : _v(v) {}
115 AtomRange(const AtomVector<T> &v) : _v(const_cast<AtomVector<T> &>(v)) {}
117 using ConstDerefFn = const T* (*)(const OwningAtomPtr<T>&);
117 using ConstDerefFn = const T* (*)(const OwningAtomPtr<T>&);
118 using DerefFn = T* (*)(OwningAtomPtr<T>&);
118 using DerefFn = T* (*)(OwningAtomPtr<T>&);
120 typedef llvm::mapped_iterator<typename AtomVector<T>::const_iterator,
122 typedef llvm::mapped_iterator<typename AtomVector<T>::iterator,
125 static const T* DerefConst(const OwningAtomPtr<T> &p) {
125 static const T* DerefConst(const OwningAtomPtr<T> &p) {
129 static T* Deref(OwningAtomPtr<T> &p) {
129 static T* Deref(OwningAtomPtr<T> &p) {
147 llvm::iterator_range<typename AtomVector<T>::iterator> owning_ptrs() {
151 llvm::iterator_range<typename AtomVector<T>::iterator> owning_ptrs() const {
163 const OwningAtomPtr<T> &operator[](size_t idx) const {
167 OwningAtomPtr<T> &operator[](size_t idx) {
172 AtomVector<T> &_v;
189 virtual const AtomRange<AbsoluteAtom> absolute() const = 0;
227 static AtomVector<AbsoluteAtom> _noAbsoluteAtoms;
263 const AtomRange<AbsoluteAtom> absolute() const override {
tools/lld/include/lld/Core/Resolver.h 40 void doAbsoluteAtom(OwningAtomPtr<AbsoluteAtom> atom);
tools/lld/include/lld/Core/SharedLibraryFile.h 46 const AtomRange<AbsoluteAtom> absolute() const override {
64 AtomVector<AbsoluteAtom> _absoluteAtoms;
tools/lld/include/lld/Core/Simple.h 59 void addAtom(AbsoluteAtom &a) {
70 } else if (auto *p = dyn_cast<AbsoluteAtom>(&atom)) {
96 const AtomRange<AbsoluteAtom> absolute() const override {
111 AtomVector<AbsoluteAtom> _absolute;
tools/lld/include/lld/Core/SymbolTable.h 46 bool add(const AbsoluteAtom &);
tools/lld/lib/Core/File.cpp 19 File::AtomVector<AbsoluteAtom> File::_noAbsoluteAtoms;
tools/lld/lib/Core/Resolver.cpp 164 void Resolver::doAbsoluteAtom(OwningAtomPtr<AbsoluteAtom> atom) {
360 if (const AbsoluteAtom *absAtom = dyn_cast<AbsoluteAtom>(atom.get()))
360 if (const AbsoluteAtom *absAtom = dyn_cast<AbsoluteAtom>(atom.get()))
tools/lld/lib/Core/SymbolTable.cpp 34 bool SymbolTable::add(const AbsoluteAtom &atom) { return addByName(atom); }
tools/lld/lib/ReaderWriter/FileArchive.cpp 113 const AtomRange<AbsoluteAtom> absolute() const override {
tools/lld/lib/ReaderWriter/MachO/ExecutableAtoms.h 135 const AtomRange<AbsoluteAtom> absolute() const override {
tools/lld/lib/ReaderWriter/MachO/FlatNamespaceFile.h 47 const AtomRange<AbsoluteAtom> absolute() const override {
tools/lld/lib/ReaderWriter/MachO/SectCreateFile.h 83 const AtomRange<AbsoluteAtom> absolute() const override {
tools/lld/lib/ReaderWriter/YAML/ReaderWriterYAML.cpp 107 for (const lld::AbsoluteAtom *absAtom : file.absolute()) {
210 using Ty = std::vector<OwningAtomPtr<T>>;
518 static size_t size(IO &io, AtomList<T> &seq) { return seq._atoms.size(); }
519 static T *&element(IO &io, AtomList<T> &seq, size_t index) {
519 static T *&element(IO &io, AtomList<T> &seq, size_t index) {
528 static size_t size(IO &io, File::AtomRange<T> &seq) { return seq.size(); }
529 static T *&element(IO &io, File::AtomRange<T> &seq, size_t index) {
529 static T *&element(IO &io, File::AtomRange<T> &seq, size_t index) {
596 const AtomRange<lld::AbsoluteAtom> absolute() const override {
659 const AtomRange<lld::AbsoluteAtom> absolute() const override {
684 AtomList<lld::AbsoluteAtom> _absoluteAtoms;
688 AtomRange<lld::AbsoluteAtom> _absoluteAtomsRef;
1139 class NormalizedAtom : public lld::AbsoluteAtom {
1144 NormalizedAtom(IO &io, const lld::AbsoluteAtom *atom)
1150 const lld::AbsoluteAtom *denormalize(IO &io) {
1185 static void mapping(IO &io, const lld::AbsoluteAtom *&atom) {
1187 MappingNormalizationHeap<NormalizedAtom, const lld::AbsoluteAtom *> keys(
1210 static void mapping(IO &io, lld::AbsoluteAtom *&atom) {
1211 const lld::AbsoluteAtom *atomPtr = atom;
1212 MappingTraits<const lld::AbsoluteAtom *>::mapping(io, atomPtr);
1237 typedef MappingTraits<const lld::AbsoluteAtom *>::NormalizedAtom NormAbsAtom;
1238 for (const lld::AbsoluteAtom *a : file->absolute()) {