|  | //===- RemoteTarget.h - LLVM Remote process JIT execution ----------------===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // Definition of the RemoteTarget class which executes JITed code in a | 
|  | // separate address range from where it was built. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef REMOTEPROCESS_H | 
|  | #define REMOTEPROCESS_H | 
|  |  | 
|  | #include "llvm/ADT/SmallVector.h" | 
|  | #include "llvm/ADT/StringRef.h" | 
|  | #include "llvm/Support/DataTypes.h" | 
|  | #include "llvm/Support/Memory.h" | 
|  | #include <stdlib.h> | 
|  | #include <string> | 
|  |  | 
|  | namespace llvm { | 
|  |  | 
|  | class RemoteTarget { | 
|  | std::string ErrorMsg; | 
|  | bool IsRunning; | 
|  |  | 
|  | SmallVector<sys::MemoryBlock, 16> Allocations; | 
|  |  | 
|  | public: | 
|  | StringRef getErrorMsg() const { return ErrorMsg; } | 
|  |  | 
|  | /// Allocate space in the remote target address space. | 
|  | /// | 
|  | /// @param      Size      Amount of space, in bytes, to allocate. | 
|  | /// @param      Alignment Required minimum alignment for allocated space. | 
|  | /// @param[out] Address   Remote address of the allocated memory. | 
|  | /// | 
|  | /// @returns False on success. On failure, ErrorMsg is updated with | 
|  | ///          descriptive text of the encountered error. | 
|  | bool allocateSpace(size_t Size, unsigned Alignment, uint64_t &Address); | 
|  |  | 
|  | /// Load data into the target address space. | 
|  | /// | 
|  | /// @param      Address   Destination address in the target process. | 
|  | /// @param      Data      Source address in the host process. | 
|  | /// @param      Size      Number of bytes to copy. | 
|  | /// | 
|  | /// @returns False on success. On failure, ErrorMsg is updated with | 
|  | ///          descriptive text of the encountered error. | 
|  | bool loadData(uint64_t Address, const void *Data, size_t Size); | 
|  |  | 
|  | /// Load code into the target address space and prepare it for execution. | 
|  | /// | 
|  | /// @param      Address   Destination address in the target process. | 
|  | /// @param      Data      Source address in the host process. | 
|  | /// @param      Size      Number of bytes to copy. | 
|  | /// | 
|  | /// @returns False on success. On failure, ErrorMsg is updated with | 
|  | ///          descriptive text of the encountered error. | 
|  | bool loadCode(uint64_t Address, const void *Data, size_t Size); | 
|  |  | 
|  | /// Execute code in the target process. The called function is required | 
|  | /// to be of signature int "(*)(void)". | 
|  | /// | 
|  | /// @param      Address   Address of the loaded function in the target | 
|  | ///                       process. | 
|  | /// @param[out] RetVal    The integer return value of the called function. | 
|  | /// | 
|  | /// @returns False on success. On failure, ErrorMsg is updated with | 
|  | ///          descriptive text of the encountered error. | 
|  | bool executeCode(uint64_t Address, int &RetVal); | 
|  |  | 
|  | /// Minimum alignment for memory permissions. Used to seperate code and | 
|  | /// data regions to make sure data doesn't get marked as code or vice | 
|  | /// versa. | 
|  | /// | 
|  | /// @returns Page alignment return value. Default of 4k. | 
|  | unsigned getPageAlignment() { return 4096; } | 
|  |  | 
|  | /// Start the remote process. | 
|  | void create(); | 
|  |  | 
|  | /// Terminate the remote process. | 
|  | void stop(); | 
|  |  | 
|  | RemoteTarget() : ErrorMsg(""), IsRunning(false) {} | 
|  | ~RemoteTarget() { if (IsRunning) stop(); } | 
|  |  | 
|  | private: | 
|  | // Main processing function for the remote target process. Command messages | 
|  | // are received on file descriptor CmdFD and responses come back on OutFD. | 
|  | static void doRemoteTargeting(int CmdFD, int OutFD); | 
|  | }; | 
|  |  | 
|  | } // end namespace llvm | 
|  |  | 
|  | #endif |