1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-26 04:32:44 +01:00
llvm-mirror/examples/OrcV2Examples/ExampleModules.h
Lang Hames 4ce58a4d70 [Orc] Add basic OrcV2 C bindings and example.
Renames the llvm/examples/LLJITExamples directory to llvm/examples/OrcV2Examples
since it is becoming a home for all OrcV2 examples, not just LLJIT.

See http://llvm.org/PR31103.
2020-03-14 14:41:22 -07:00

55 lines
1.6 KiB
C++

//===----- ExampleModules.h - IR modules for LLJIT examples -----*- 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
//
//===----------------------------------------------------------------------===//
//
// Example modules for LLJIT examples
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_EXAMPLES_HOWTOUSELLJIT_EXAMPLEMODULES_H
#define LLVM_EXAMPLES_HOWTOUSELLJIT_EXAMPLEMODULES_H
#include "llvm/ADT/StringRef.h"
#include "llvm/ExecutionEngine/Orc/ThreadSafeModule.h"
#include "llvm/IR/LLVMContext.h"
#include "llvm/IR/Module.h"
#include "llvm/IRReader/IRReader.h"
#include "llvm/Support/Error.h"
#include "llvm/Support/SourceMgr.h"
const llvm::StringRef Add1Example =
R"(
define i32 @add1(i32 %x) {
entry:
%r = add nsw i32 %x, 1
ret i32 %r
}
)";
inline llvm::Expected<llvm::orc::ThreadSafeModule>
parseExampleModule(llvm::StringRef Source, llvm::StringRef Name) {
using namespace llvm;
using namespace llvm::orc;
auto Ctx = std::make_unique<LLVMContext>();
SMDiagnostic Err;
auto M = parseIR(MemoryBufferRef(Source, Name), Err, *Ctx);
if (!M) {
std::string ErrMsg;
{
raw_string_ostream ErrStream(ErrMsg);
Err.print("", ErrStream);
}
return make_error<StringError>(std::move(ErrMsg), inconvertibleErrorCode());
}
return ThreadSafeModule(std::move(M), std::move(Ctx));
}
#endif // LLVM_EXAMPLES_HOWTOUSELLJIT_EXAMPLEMODULES_H