48 lines
1.7 KiB
C++
48 lines
1.7 KiB
C++
//===- ELFObjHandler.h ------------------------------------------*- 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
|
|
//
|
|
//===-----------------------------------------------------------------------===/
|
|
///
|
|
/// This supports reading and writing of elf dynamic shared objects.
|
|
///
|
|
//===-----------------------------------------------------------------------===/
|
|
|
|
#ifndef LLVM_TOOLS_ELFABI_ELFOBJHANDLER_H
|
|
#define LLVM_TOOLS_ELFABI_ELFOBJHANDLER_H
|
|
|
|
#include "llvm/InterfaceStub/ELFStub.h"
|
|
#include "llvm/Object/ELFObjectFile.h"
|
|
#include "llvm/Object/ELFTypes.h"
|
|
#include "llvm/Support/FileSystem.h"
|
|
|
|
namespace llvm {
|
|
|
|
class MemoryBuffer;
|
|
|
|
namespace elfabi {
|
|
|
|
enum class ELFTarget { ELF32LE, ELF32BE, ELF64LE, ELF64BE };
|
|
|
|
/// Attempt to read a binary ELF file from a MemoryBuffer.
|
|
Expected<std::unique_ptr<ELFStub>> readELFFile(MemoryBufferRef Buf);
|
|
|
|
/// Attempt to write a binary ELF stub.
|
|
/// This function determines appropriate ELFType using the passed ELFTarget and
|
|
/// then writes a binary ELF stub to a specified file path.
|
|
///
|
|
/// @param FilePath File path for writing the ELF binary.
|
|
/// @param Stub Source ELFStub to generate a binary ELF stub from.
|
|
/// @param OutputFormat Target ELFType to write binary as.
|
|
/// @param WriteIfChanged Whether or not to preserve timestamp if
|
|
/// the output stays the same.
|
|
Error writeBinaryStub(StringRef FilePath, const ELFStub &Stub,
|
|
ELFTarget OutputFormat, bool WriteIfChanged = false);
|
|
|
|
} // end namespace elfabi
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_TOOLS_ELFABI_ELFOBJHANDLER_H
|