[PATCH] D64943: [Clang][OpenMP offload] Eliminate use of OpenMP linker script
Alexey Bataev via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Tue Aug 6 11:37:43 PDT 2019
ABataev added inline comments.
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:69
+
+ using MemoryBuffersVector = SmallVectorImpl<std::unique_ptr<MemoryBuffer>>;
+
----------------
Why not `ArrayRef`?
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:72-75
+ IntegerType *getSizeTTy() {
+ auto PtrSize = M.getDataLayout().getPointerTypeSize(Type::getInt8PtrTy(C));
+ return PtrSize == 8 ? Type::getInt64Ty(C) : Type::getInt32Ty(C);
+ }
----------------
Not sure that this is the best solution, we may end up with incorrect `size_t` type in some cases.
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:73
+ IntegerType *getSizeTTy() {
+ auto PtrSize = M.getDataLayout().getPointerTypeSize(Type::getInt8PtrTy(C));
+ return PtrSize == 8 ? Type::getInt64Ty(C) : Type::getInt32Ty(C);
----------------
Use real type here, not `auto`
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:133
+ GlobalVariable *createBinDesc(const MemoryBuffersVector &Bufs) {
+ auto *EntriesB = new GlobalVariable(M, getEntryTy(), true,
+ GlobalValue::ExternalLinkage, nullptr,
----------------
Add comment for the `true` constant with the name of parameter.
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:136
+ "__omp_offloading_entries_begin");
+ auto *EntriesE = new GlobalVariable(M, getEntryTy(), true,
+ GlobalValue::ExternalLinkage, nullptr,
----------------
Same here
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:143
+
+ SmallVector<Constant *, 4> ImagesInits;
+ for (const auto &Buf : Bufs) {
----------------
Comments?
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:144
+ SmallVector<Constant *, 4> ImagesInits;
+ for (const auto &Buf : Bufs) {
+ auto *Data = ConstantDataArray::get(
----------------
Use real type, not `auto`
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:148
+
+ auto *Image = new GlobalVariable(M, Data->getType(), true,
+ GlobalVariable::InternalLinkage,
----------------
Seems to me the code is not formatted
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:196
+ { getBinDescPtrTy() }, false);
+ auto RegFuncC = M.getOrInsertFunction("__tgt_register_lib",
+ RegFuncTy);
----------------
Use real type, not `auto`
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:209
+ void createUnregisterFunction(GlobalVariable *BinDesc) {
+ auto *FuncTy = FunctionType::get(Type::getVoidTy(C), {}, false);
+ auto *Func = Function::Create(FuncTy, GlobalValue::InternalLinkage,
----------------
`llvm::None` instead of `{}`
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:216
+ auto *UnRegFuncTy = FunctionType::get(Type::getVoidTy(C),
+ { getBinDescPtrTy() }, false);
+ auto UnRegFuncC = M.getOrInsertFunction("__tgt_unregister_lib",
----------------
Remove extra braces here, they are not needed.
================
Comment at: clang/tools/clang-offload-wrapper/ClangOffloadWrapper.cpp:222
+ IRBuilder<> Builder(BasicBlock::Create(C, "entry", Func));
+ Builder.CreateCall(UnRegFuncC, { BinDesc });
+ Builder.CreateRetVoid();
----------------
Extra braces
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64943/new/
https://reviews.llvm.org/D64943
More information about the cfe-commits
mailing list