mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-08 19:25:47 +00:00
[ORC] Add NullResolver
Summary: This is an implementation of RuntimeDyld::SymbolResolver that simply rejects all resolution requests; useful for clients that do not have any cross-object symbol references. Reviewers: lhames Reviewed By: lhames Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D10455 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@240288 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
36
include/llvm/ExecutionEngine/Orc/NullResolver.h
Normal file
36
include/llvm/ExecutionEngine/Orc/NullResolver.h
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
//===------ NullResolver.h - Reject symbol lookup requests ------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// Defines a RuntimeDyld::SymbolResolver subclass that rejects all symbol
|
||||||
|
// resolution requests, for clients that have no cross-object fixups.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef LLVM_EXECUTIONENGINE_ORC_NULLRESOLVER_H
|
||||||
|
#define LLVM_EXECUTIONENGINE_ORC_NULLRESOLVER_H
|
||||||
|
|
||||||
|
#include "llvm/ExecutionEngine/RuntimeDyld.h"
|
||||||
|
|
||||||
|
namespace llvm {
|
||||||
|
namespace orc {
|
||||||
|
|
||||||
|
/// SymbolResolver impliementation that rejects all resolution requests.
|
||||||
|
/// Useful for clients that have no cross-object fixups.
|
||||||
|
class NullResolver : public RuntimeDyld::SymbolResolver {
|
||||||
|
public:
|
||||||
|
RuntimeDyld::SymbolInfo findSymbol(const std::string &Name) final;
|
||||||
|
|
||||||
|
RuntimeDyld::SymbolInfo
|
||||||
|
findSymbolInLogicalDylib(const std::string &Name) final;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // End namespace orc.
|
||||||
|
} // End namespace llvm.
|
||||||
|
|
||||||
|
#endif // LLVM_EXECUTIONENGINE_ORC_NULLRESOLVER_H
|
@@ -1,12 +1,13 @@
|
|||||||
add_llvm_library(LLVMOrcJIT
|
add_llvm_library(LLVMOrcJIT
|
||||||
ExecutionUtils.cpp
|
ExecutionUtils.cpp
|
||||||
IndirectionUtils.cpp
|
IndirectionUtils.cpp
|
||||||
OrcMCJITReplacement.cpp
|
NullResolver.cpp
|
||||||
OrcTargetSupport.cpp
|
OrcMCJITReplacement.cpp
|
||||||
|
OrcTargetSupport.cpp
|
||||||
ADDITIONAL_HEADER_DIRS
|
|
||||||
${LLVM_MAIN_INCLUDE_DIR}/llvm/ExecutionEngine/Orc
|
ADDITIONAL_HEADER_DIRS
|
||||||
|
${LLVM_MAIN_INCLUDE_DIR}/llvm/ExecutionEngine/Orc
|
||||||
DEPENDS
|
|
||||||
intrinsics_gen
|
DEPENDS
|
||||||
)
|
intrinsics_gen
|
||||||
|
)
|
||||||
|
27
lib/ExecutionEngine/Orc/NullResolver.cpp
Normal file
27
lib/ExecutionEngine/Orc/NullResolver.cpp
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
//===---------- NullResolver.cpp - Reject symbol lookup requests ----------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/ExecutionEngine/Orc/NullResolver.h"
|
||||||
|
|
||||||
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
|
|
||||||
|
namespace llvm {
|
||||||
|
namespace orc {
|
||||||
|
|
||||||
|
RuntimeDyld::SymbolInfo NullResolver::findSymbol(const std::string &Name) {
|
||||||
|
llvm_unreachable("Unexpected cross-object symbol reference");
|
||||||
|
}
|
||||||
|
|
||||||
|
RuntimeDyld::SymbolInfo
|
||||||
|
NullResolver::findSymbolInLogicalDylib(const std::string &Name) {
|
||||||
|
llvm_unreachable("Unexpected cross-object symbol reference");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // End namespace orc.
|
||||||
|
} // End namespace llvm.
|
Reference in New Issue
Block a user