LLVM 22.0.0git
Object.cpp
Go to the documentation of this file.
1//===- Object.cpp - C bindings to the object file library--------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the C bindings to the file-format-independent object
10// library.
11//
12//===----------------------------------------------------------------------===//
13
14#include "llvm-c/Object.h"
16#include "llvm/IR/LLVMContext.h"
20
21using namespace llvm;
22using namespace object;
23
25 return reinterpret_cast<OwningBinary<ObjectFile> *>(OF);
26}
27
29 return reinterpret_cast<LLVMObjectFileRef>(
30 const_cast<OwningBinary<ObjectFile> *>(OF));
31}
32
34 return reinterpret_cast<section_iterator*>(SI);
35}
36
39 return reinterpret_cast<LLVMSectionIteratorRef>
40 (const_cast<section_iterator*>(SI));
41}
42
44 return reinterpret_cast<symbol_iterator*>(SI);
45}
46
49 return reinterpret_cast<LLVMSymbolIteratorRef>
50 (const_cast<symbol_iterator*>(SI));
51}
52
54 return reinterpret_cast<relocation_iterator*>(SI);
55}
56
59 return reinterpret_cast<LLVMRelocationIteratorRef>
60 (const_cast<relocation_iterator*>(SI));
61}
62
63/*--.. Operations on binary files ..........................................--*/
64
66 LLVMContextRef Context,
67 char **ErrorMessage) {
68 auto maybeContext = Context ? unwrap(Context) : nullptr;
70 createBinary(unwrap(MemBuf)->getMemBufferRef(), maybeContext));
71 if (!ObjOrErr) {
72 *ErrorMessage = strdup(toString(ObjOrErr.takeError()).c_str());
73 return nullptr;
74 }
75
76 return wrap(ObjOrErr.get().release());
77}
78
80 auto Buf = unwrap(BR)->getMemoryBufferRef();
82 Buf.getBuffer(), Buf.getBufferIdentifier(),
83 /*RequiresNullTerminator*/false).release());
84}
85
87 delete unwrap(BR);
88}
89
91 class BinaryTypeMapper final : public Binary {
92 public:
93 static LLVMBinaryType mapBinaryTypeToLLVMBinaryType(unsigned Kind) {
94 switch (Kind) {
95 case ID_Archive:
101 case ID_IR:
102 return LLVMBinaryTypeIR;
103 case ID_WinRes:
105 case ID_COFF:
106 return LLVMBinaryTypeCOFF;
107 case ID_ELF32L:
109 case ID_ELF32B:
111 case ID_ELF64L:
113 case ID_ELF64B:
115 case ID_MachO32L:
117 case ID_MachO32B:
119 case ID_MachO64L:
121 case ID_MachO64B:
123 case ID_Offload:
125 case ID_Wasm:
126 return LLVMBinaryTypeWasm;
127 case ID_DXContainer:
129 case ID_StartObjects:
130 case ID_EndObjects:
131 llvm_unreachable("Marker types are not valid binary kinds!");
132 default:
133 llvm_unreachable("Unknown binary kind!");
134 }
135 }
136 };
137 return BinaryTypeMapper::mapBinaryTypeToLLVMBinaryType(unwrap(BR)->getType());
138}
139
141 const char *Arch,
142 size_t ArchLen,
143 char **ErrorMessage) {
144 auto universal = cast<MachOUniversalBinary>(unwrap(BR));
146 universal->getMachOObjectForArch({Arch, ArchLen}));
147 if (!ObjOrErr) {
148 *ErrorMessage = strdup(toString(ObjOrErr.takeError()).c_str());
149 return nullptr;
150 }
151 return wrap(ObjOrErr.get().release());
152}
153
155 auto OF = cast<ObjectFile>(unwrap(BR));
156 auto sections = OF->sections();
157 if (sections.begin() == sections.end())
158 return nullptr;
159 return wrap(new section_iterator(sections.begin()));
160}
161
164 auto OF = cast<ObjectFile>(unwrap(BR));
165 return (*unwrap(SI) == OF->section_end()) ? 1 : 0;
166}
167
169 auto OF = cast<ObjectFile>(unwrap(BR));
170 auto symbols = OF->symbols();
171 if (symbols.begin() == symbols.end())
172 return nullptr;
173 return wrap(new symbol_iterator(symbols.begin()));
174}
175
178 auto OF = cast<ObjectFile>(unwrap(BR));
179 return (*unwrap(SI) == OF->symbol_end()) ? 1 : 0;
180}
181
182// ObjectFile creation
184 std::unique_ptr<MemoryBuffer> Buf(unwrap(MemBuf));
186 ObjectFile::createObjectFile(Buf->getMemBufferRef()));
187 if (!ObjOrErr) {
188 // TODO: Actually report errors helpfully.
189 consumeError(ObjOrErr.takeError());
190 return nullptr;
191 }
192
193 auto *Ret = new OwningBinary<ObjectFile>(std::move(ObjOrErr.get()), std::move(Buf));
194 return wrap(Ret);
195}
196
198 delete unwrap(ObjectFile);
199}
200
201// ObjectFile Section iterators
204 section_iterator SI = OB->getBinary()->section_begin();
205 return wrap(new section_iterator(SI));
206}
207
209 delete unwrap(SI);
210}
211
215 return (*unwrap(SI) == OB->getBinary()->section_end()) ? 1 : 0;
216}
217
219 ++(*unwrap(SI));
220}
221
225 if (!SecOrErr) {
226 std::string Buf;
230 }
231 *unwrap(Sect) = *SecOrErr;
232}
233
234// ObjectFile Symbol iterators
237 symbol_iterator SI = OB->getBinary()->symbol_begin();
238 return wrap(new symbol_iterator(SI));
239}
240
242 delete unwrap(SI);
243}
244
248 return (*unwrap(SI) == OB->getBinary()->symbol_end()) ? 1 : 0;
249}
250
252 ++(*unwrap(SI));
253}
254
255// SectionRef accessors
257 auto NameOrErr = (*unwrap(SI))->getName();
258 if (!NameOrErr)
259 report_fatal_error(NameOrErr.takeError());
260 return NameOrErr->data();
261}
262
264 return (*unwrap(SI))->getSize();
265}
266
268 if (Expected<StringRef> E = (*unwrap(SI))->getContents())
269 return E->data();
270 else
271 report_fatal_error(E.takeError());
272}
273
275 return (*unwrap(SI))->getAddress();
276}
277
280 return (*unwrap(SI))->containsSymbol(**unwrap(Sym));
281}
282
283// Section Relocation iterators
285 relocation_iterator SI = (*unwrap(Section))->relocation_begin();
286 return wrap(new relocation_iterator(SI));
287}
288
290 delete unwrap(SI);
291}
292
295 return (*unwrap(SI) == (*unwrap(Section))->relocation_end()) ? 1 : 0;
296}
297
299 ++(*unwrap(SI));
300}
301
302
303// SymbolRef accessors
305 Expected<StringRef> Ret = (*unwrap(SI))->getName();
306 if (!Ret) {
307 std::string Buf;
309 logAllUnhandledErrors(Ret.takeError(), OS);
311 }
312 return Ret->data();
313}
314
316 Expected<uint64_t> Ret = (*unwrap(SI))->getAddress();
317 if (!Ret) {
318 std::string Buf;
320 logAllUnhandledErrors(Ret.takeError(), OS);
322 }
323 return *Ret;
324}
325
327 return (*unwrap(SI))->getCommonSize();
328}
329
330// RelocationRef accessors
332 return (*unwrap(RI))->getOffset();
333}
334
336 symbol_iterator ret = (*unwrap(RI))->getSymbol();
337 return wrap(new symbol_iterator(ret));
338}
339
341 return (*unwrap(RI))->getType();
342}
343
344// NOTE: Caller takes ownership of returned string.
347 (*unwrap(RI))->getTypeName(ret);
348 char *str = static_cast<char*>(safe_malloc(ret.size()));
349 llvm::copy(ret, str);
350 return str;
351}
352
353// NOTE: Caller takes ownership of returned string.
355 return strdup("");
356}
357
bbsections Prepares for basic block sections
Symbol * Sym
Definition: ELF_riscv.cpp:479
This file defines counterparts of C library allocation functions defined in the namespace 'std'.
LLVMObjectFileRef wrap(const OwningBinary< ObjectFile > *OF)
Definition: Object.cpp:28
OwningBinary< ObjectFile > * unwrap(LLVMObjectFileRef OF)
Definition: Object.cpp:24
static StringRef getName(Value *V)
raw_pwrite_stream & OS
This file defines the SmallVector class.
static SymbolRef::Type getType(const Symbol *Sym)
Definition: TapiFile.cpp:39
Tagged union holding either a T or a Error.
Definition: Error.h:485
Error takeError()
Take ownership of the stored error.
Definition: Error.h:612
reference get()
Returns a reference to the stored T value.
Definition: Error.h:582
static std::unique_ptr< MemoryBuffer > getMemBuffer(StringRef InputData, StringRef BufferName="", bool RequiresNullTerminator=true)
Open the specified memory range as a MemoryBuffer.
size_t size() const
Definition: SmallVector.h:79
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Definition: SmallVector.h:1197
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition: Twine.h:82
This class is the base class for all object file types.
Definition: ObjectFile.h:231
static Expected< OwningBinary< ObjectFile > > createObjectFile(StringRef ObjectPath)
Definition: ObjectFile.cpp:211
A raw_ostream that writes to an std::string.
Definition: raw_ostream.h:662
void LLVMMoveToNextRelocation(LLVMRelocationIteratorRef SI)
Definition: Object.cpp:298
void LLVMDisposeSectionIterator(LLVMSectionIteratorRef SI)
Definition: Object.cpp:208
uint64_t LLVMGetSymbolSize(LLVMSymbolIteratorRef SI)
Definition: Object.cpp:326
LLVMSymbolIteratorRef LLVMGetSymbols(LLVMObjectFileRef OF)
Deprecated: Use LLVMObjectFileCopySymbolIterator instead.
Definition: Object.cpp:235
uint64_t LLVMGetSectionAddress(LLVMSectionIteratorRef SI)
Definition: Object.cpp:274
LLVMBool LLVMObjectFileIsSymbolIteratorAtEnd(LLVMBinaryRef BR, LLVMSymbolIteratorRef SI)
Returns whether the given symbol iterator is at the end.
Definition: Object.cpp:176
struct LLVMOpaqueSymbolIterator * LLVMSymbolIteratorRef
Definition: Object.h:38
LLVMBinaryRef LLVMMachOUniversalBinaryCopyObjectForArch(LLVMBinaryRef BR, const char *Arch, size_t ArchLen, char **ErrorMessage)
Definition: Object.cpp:140
uint64_t LLVMGetSymbolAddress(LLVMSymbolIteratorRef SI)
Definition: Object.cpp:315
uint64_t LLVMGetSectionSize(LLVMSectionIteratorRef SI)
Definition: Object.cpp:263
LLVMSymbolIteratorRef LLVMObjectFileCopySymbolIterator(LLVMBinaryRef BR)
Retrieve a copy of the symbol iterator for this object file.
Definition: Object.cpp:168
uint64_t LLVMGetRelocationType(LLVMRelocationIteratorRef RI)
Definition: Object.cpp:340
const char * LLVMGetRelocationValueString(LLVMRelocationIteratorRef RI)
Definition: Object.cpp:354
void LLVMMoveToContainingSection(LLVMSectionIteratorRef Sect, LLVMSymbolIteratorRef Sym)
Definition: Object.cpp:222
void LLVMDisposeSymbolIterator(LLVMSymbolIteratorRef SI)
Definition: Object.cpp:241
LLVMBool LLVMIsSectionIteratorAtEnd(LLVMObjectFileRef OF, LLVMSectionIteratorRef SI)
Deprecated: Use LLVMObjectFileIsSectionIteratorAtEnd instead.
Definition: Object.cpp:212
void LLVMMoveToNextSection(LLVMSectionIteratorRef SI)
Definition: Object.cpp:218
LLVMSymbolIteratorRef LLVMGetRelocationSymbol(LLVMRelocationIteratorRef RI)
Definition: Object.cpp:335
const char * LLVMGetSymbolName(LLVMSymbolIteratorRef SI)
Definition: Object.cpp:304
uint64_t LLVMGetRelocationOffset(LLVMRelocationIteratorRef RI)
Definition: Object.cpp:331
void LLVMDisposeRelocationIterator(LLVMRelocationIteratorRef SI)
Definition: Object.cpp:289
LLVMSectionIteratorRef LLVMObjectFileCopySectionIterator(LLVMBinaryRef BR)
Retrieve a copy of the section iterator for this object file.
Definition: Object.cpp:154
LLVMSectionIteratorRef LLVMGetSections(LLVMObjectFileRef OF)
Deprecated: Use LLVMObjectFileCopySectionIterator instead.
Definition: Object.cpp:202
LLVMBinaryType LLVMBinaryGetType(LLVMBinaryRef BR)
Retrieve the specific type of a binary.
Definition: Object.cpp:90
LLVMRelocationIteratorRef LLVMGetRelocations(LLVMSectionIteratorRef Section)
Definition: Object.cpp:284
void LLVMDisposeBinary(LLVMBinaryRef BR)
Dispose of a binary file.
Definition: Object.cpp:86
struct LLVMOpaqueSectionIterator * LLVMSectionIteratorRef
Definition: Object.h:37
LLVMBinaryType
Definition: Object.h:41
const char * LLVMGetSectionName(LLVMSectionIteratorRef SI)
Definition: Object.cpp:256
LLVMBool LLVMIsRelocationIteratorAtEnd(LLVMSectionIteratorRef Section, LLVMRelocationIteratorRef SI)
Definition: Object.cpp:293
LLVMMemoryBufferRef LLVMBinaryCopyMemoryBuffer(LLVMBinaryRef BR)
Retrieves a copy of the memory buffer associated with this object file.
Definition: Object.cpp:79
struct LLVMOpaqueRelocationIterator * LLVMRelocationIteratorRef
Definition: Object.h:39
const char * LLVMGetRelocationTypeName(LLVMRelocationIteratorRef RI)
Definition: Object.cpp:345
struct LLVMOpaqueObjectFile * LLVMObjectFileRef
Deprecated: Use LLVMBinaryRef instead.
Definition: Object.h:209
LLVMBool LLVMIsSymbolIteratorAtEnd(LLVMObjectFileRef OF, LLVMSymbolIteratorRef SI)
Deprecated: Use LLVMObjectFileIsSymbolIteratorAtEnd instead.
Definition: Object.cpp:245
LLVMObjectFileRef LLVMCreateObjectFile(LLVMMemoryBufferRef MemBuf)
Deprecated: Use LLVMCreateBinary instead.
Definition: Object.cpp:183
LLVMBool LLVMGetSectionContainsSymbol(LLVMSectionIteratorRef SI, LLVMSymbolIteratorRef Sym)
Definition: Object.cpp:278
void LLVMDisposeObjectFile(LLVMObjectFileRef ObjectFile)
Deprecated: Use LLVMDisposeBinary instead.
Definition: Object.cpp:197
const char * LLVMGetSectionContents(LLVMSectionIteratorRef SI)
Definition: Object.cpp:267
LLVMBinaryRef LLVMCreateBinary(LLVMMemoryBufferRef MemBuf, LLVMContextRef Context, char **ErrorMessage)
Create a binary file from the given memory buffer.
Definition: Object.cpp:65
void LLVMMoveToNextSymbol(LLVMSymbolIteratorRef SI)
Definition: Object.cpp:251
LLVMBool LLVMObjectFileIsSectionIteratorAtEnd(LLVMBinaryRef BR, LLVMSectionIteratorRef SI)
Returns whether the given section iterator is at the end.
Definition: Object.cpp:162
@ LLVMBinaryTypeIR
LLVM IR.
Definition: Object.h:45
@ LLVMBinaryTypeDXcontainer
DirectX Binary Container.
Definition: Object.h:58
@ LLVMBinaryTypeELF64B
ELF 64-bit, big endian.
Definition: Object.h:51
@ LLVMBinaryTypeArchive
Archive file.
Definition: Object.h:42
@ LLVMBinaryTypeMachO32B
MachO 32-bit, big endian.
Definition: Object.h:53
@ LLVMBinaryTypeWasm
Web Assembly.
Definition: Object.h:56
@ LLVMBinaryTypeELF64L
ELF 64-bit, little endian.
Definition: Object.h:50
@ LLVMBinaryTypeWinRes
Windows resource (.res) file.
Definition: Object.h:46
@ LLVMBinaryTypeMachOUniversalBinary
Mach-O Universal Binary file.
Definition: Object.h:43
@ LLVMBinaryTypeMachO64B
MachO 64-bit, big endian.
Definition: Object.h:55
@ LLVMBinaryTypeCOFF
COFF Object file.
Definition: Object.h:47
@ LLVMBinaryTypeCOFFImportFile
COFF Import file.
Definition: Object.h:44
@ LLVMBinaryTypeELF32B
ELF 32-bit, big endian.
Definition: Object.h:49
@ LLVMBinaryTypeELF32L
ELF 32-bit, little endian.
Definition: Object.h:48
@ LLVMBinaryTypeMachO32L
MachO 32-bit, little endian.
Definition: Object.h:52
@ LLVMBinaryTypeMachO64L
MachO 64-bit, little endian.
Definition: Object.h:54
@ LLVMBinaryTypeOffload
Offloading fatbinary.
Definition: Object.h:57
int LLVMBool
Definition: Types.h:28
struct LLVMOpaqueBinary * LLVMBinaryRef
Definition: Types.h:170
struct LLVMOpaqueMemoryBuffer * LLVMMemoryBufferRef
LLVM uses a polymorphic type hierarchy which C cannot represent, therefore parameters must be passed ...
Definition: Types.h:48
struct LLVMOpaqueContext * LLVMContextRef
The top-level container for all LLVM global data.
Definition: Types.h:53
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
Expected< const typename ELFT::Shdr * > getSection(typename ELFT::ShdrRange Sections, uint32_t Index)
Definition: ELF.h:539
content_iterator< SectionRef > section_iterator
Definition: ObjectFile.h:49
content_iterator< RelocationRef > relocation_iterator
Definition: ObjectFile.h:79
LLVM_ABI Expected< std::unique_ptr< Binary > > createBinary(MemoryBufferRef Source, LLVMContext *Context=nullptr, bool InitContent=true)
Create a Binary from Source, autodetecting the file type.
Definition: Binary.cpp:45
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
LLVM_ABI void logAllUnhandledErrors(Error E, raw_ostream &OS, Twine ErrorBanner={})
Log all errors (if any) in E to OS.
Definition: Error.cpp:65
LLVM_GET_TYPE_NAME_CONSTEXPR StringRef getTypeName()
We provide a function which tries to compute the (demangled) name of a type statically.
Definition: TypeName.h:40
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition: Error.cpp:167
LLVM_ATTRIBUTE_RETURNS_NONNULL void * safe_malloc(size_t Sz)
Definition: MemAlloc.h:25
OutputIt copy(R &&Range, OutputIt Out)
Definition: STLExtras.h:1854
const char * toString(DWARFSectionKind Kind)
void consumeError(Error Err)
Consume a Error without doing anything.
Definition: Error.h:1083