//===- 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> 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