1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- #pragma once
- #ifdef __GNUC__
- #pragma GCC diagnostic push
- #pragma GCC diagnostic ignored "-Wunused-parameter"
- #endif
- //===- EPCDebugObjectRegistrar.h - EPC-based debug registration -*- 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
- //
- //===----------------------------------------------------------------------===//
- //
- // ExecutorProcessControl based registration of debug objects.
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_EXECUTIONENGINE_ORC_EPCDEBUGOBJECTREGISTRAR_H
- #define LLVM_EXECUTIONENGINE_ORC_EPCDEBUGOBJECTREGISTRAR_H
- #include "llvm/ExecutionEngine/JITSymbol.h"
- #include "llvm/ExecutionEngine/Orc/Shared/ExecutorAddress.h"
- #include "llvm/ExecutionEngine/Orc/Shared/WrapperFunctionUtils.h"
- #include "llvm/Support/Error.h"
- #include "llvm/Support/Memory.h"
- #include <cstdint>
- #include <memory>
- #include <vector>
- namespace llvm {
- namespace orc {
- class ExecutionSession;
- /// Abstract interface for registering debug objects in the executor process.
- class DebugObjectRegistrar {
- public:
- virtual Error registerDebugObject(ExecutorAddrRange TargetMem) = 0;
- virtual ~DebugObjectRegistrar() = default;
- };
- /// Use ExecutorProcessControl to register debug objects locally or in a remote
- /// executor process.
- class EPCDebugObjectRegistrar : public DebugObjectRegistrar {
- public:
- EPCDebugObjectRegistrar(ExecutionSession &ES, ExecutorAddr RegisterFn)
- : ES(ES), RegisterFn(RegisterFn) {}
- Error registerDebugObject(ExecutorAddrRange TargetMem) override;
- private:
- ExecutionSession &ES;
- ExecutorAddr RegisterFn;
- };
- /// Create a ExecutorProcessControl-based DebugObjectRegistrar that emits debug
- /// objects to the GDB JIT interface. This will use the EPC's lookupSymbols
- /// method to find the registration/deregistration funciton addresses by name.
- ///
- /// If RegistrationFunctionsDylib is non-None then it will be searched to find
- /// the registration functions. If it is None then the process dylib will be
- /// loaded to find the registration functions.
- Expected<std::unique_ptr<EPCDebugObjectRegistrar>> createJITLoaderGDBRegistrar(
- ExecutionSession &ES,
- std::optional<ExecutorAddr> RegistrationFunctionDylib = std::nullopt);
- } // end namespace orc
- } // end namespace llvm
- #endif // LLVM_EXECUTIONENGINE_ORC_EPCDEBUGOBJECTREGISTRAR_H
- #ifdef __GNUC__
- #pragma GCC diagnostic pop
- #endif
|