Code in plugins-nextgen reading ELF files is currently hard-coded to assume a 64-bit little-endian ELF format. Unfortunately, this assumption is even embedded in the interface between GlobalHandler and Utils/ELF routines, which use ELF64LE types. To fix this, I've refactored the interface to use generic types, in particular by using (a unique_ptr to) ObjectFile instead of ELF64LEObjectFile, and ELFSymbolRef instead of ELF64LE::Sym. This allows properly templating over multiple ELF format variants inside Utils/ELF; specifically, this patch adds support for 64-bit big-endian ELF files in addition to 64-bit little-endian files.
45 lines
1.6 KiB
C++
45 lines
1.6 KiB
C++
//===-- Utils/ELF.h - Common ELF functionality ------------------*- C++ -*-===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Common ELF functionality for target plugins.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_OPENMP_LIBOMPTARGET_PLUGINS_ELF_UTILS_H
|
|
#define LLVM_OPENMP_LIBOMPTARGET_PLUGINS_ELF_UTILS_H
|
|
|
|
#include "Shared/PluginAPI.h"
|
|
|
|
#include "llvm/Object/ELF.h"
|
|
#include "llvm/Object/ELFObjectFile.h"
|
|
|
|
namespace utils {
|
|
namespace elf {
|
|
|
|
/// Returns true or false if the \p Buffer is an ELF file.
|
|
bool isELF(llvm::StringRef Buffer);
|
|
|
|
/// Checks if the given \p Object is a valid ELF matching the e_machine value.
|
|
llvm::Expected<bool> checkMachine(llvm::StringRef Object, uint16_t EMachine);
|
|
|
|
/// Returns a pointer to the given \p Symbol inside of an ELF object.
|
|
llvm::Expected<const void *>
|
|
getSymbolAddress(const llvm::object::ELFSymbolRef &Symbol);
|
|
|
|
/// Returns the symbol associated with the \p Name in the \p ELFObj. It will
|
|
/// first search for the hash sections to identify symbols from the hash table.
|
|
/// If that fails it will fall back to a linear search in the case of an
|
|
/// executable file without a hash table.
|
|
llvm::Expected<std::optional<llvm::object::ELFSymbolRef>>
|
|
getSymbol(const llvm::object::ObjectFile &ELFObj, llvm::StringRef Name);
|
|
|
|
} // namespace elf
|
|
} // namespace utils
|
|
|
|
#endif // LLVM_OPENMP_LIBOMPTARGET_PLUGINS_ELF_UTILS_H
|