[llvm] 0d527e5 - GlobalIFunc: Make ifunc respect function address spaces
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 22 18:42:53 PST 2022
Author: Matt Arsenault
Date: 2022-11-22T21:42:44-05:00
New Revision: 0d527e56a5ee3fd0435e6f99a10692e5115f36b7
URL: https://github.com/llvm/llvm-project/commit/0d527e56a5ee3fd0435e6f99a10692e5115f36b7
DIFF: https://github.com/llvm/llvm-project/commit/0d527e56a5ee3fd0435e6f99a10692e5115f36b7.diff
LOG: GlobalIFunc: Make ifunc respect function address spaces
Added:
llvm/test/Assembler/ifunc-program-addrspace.ll
Modified:
llvm/lib/Bitcode/Reader/BitcodeReader.cpp
llvm/lib/IR/Verifier.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
index c4805602d1ad1..198fe331daff9 100644
--- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
+++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
@@ -2873,8 +2873,8 @@ Error BitcodeReader::resolveGlobalAndIndirectSymbolInits() {
Type *ResolverFTy =
GlobalIFunc::getResolverFunctionType(GI->getValueType());
// Transparently fix up the type for compatibility with older bitcode
- GI->setResolver(
- ConstantExpr::getBitCast(C, ResolverFTy->getPointerTo()));
+ GI->setResolver(ConstantExpr::getBitCast(
+ C, ResolverFTy->getPointerTo(GI->getAddressSpace())));
} else {
return error("Expected an alias or an ifunc");
}
diff --git a/llvm/lib/IR/Verifier.cpp b/llvm/lib/IR/Verifier.cpp
index 002b5210830fe..ce0d4da8f4e8c 100644
--- a/llvm/lib/IR/Verifier.cpp
+++ b/llvm/lib/IR/Verifier.cpp
@@ -889,7 +889,7 @@ void Verifier::visitGlobalIFunc(const GlobalIFunc &GI) {
const Type *ResolverTy = GI.getResolver()->getType();
const Type *ResolverFuncTy =
GlobalIFunc::getResolverFunctionType(GI.getValueType());
- Check(ResolverTy == ResolverFuncTy->getPointerTo(),
+ Check(ResolverTy == ResolverFuncTy->getPointerTo(GI.getAddressSpace()),
"IFunc resolver has incorrect type", &GI);
}
diff --git a/llvm/test/Assembler/ifunc-program-addrspace.ll b/llvm/test/Assembler/ifunc-program-addrspace.ll
new file mode 100644
index 0000000000000..8933812525f94
--- /dev/null
+++ b/llvm/test/Assembler/ifunc-program-addrspace.ll
@@ -0,0 +1,33 @@
+; RUN: llvm-as < %s | llvm-dis | FileCheck %s
+
+target datalayout = "P1"
+
+; CHECK: @ifunc_as0 = ifunc void (), ptr @resolver_as0
+ at ifunc_as0 = ifunc void (), ptr @resolver_as0
+
+; CHECK: @ifunc_as1 = ifunc void (), ptr addrspace(1) @resolver_as1
+ at ifunc_as1 = ifunc void (), ptr addrspace(1) @resolver_as1
+
+; CHECK: define ptr @resolver_as0() addrspace(0) {
+define ptr @resolver_as0() addrspace(0) {
+ ret ptr null
+}
+
+; CHECK: define ptr @resolver_as1() addrspace(1) {
+define ptr @resolver_as1() addrspace(1) {
+ ret ptr null
+}
+
+; CHECK: define void @call_ifunc_as0() addrspace(1) {
+; CHECK-NEXT: call addrspace(0) void @ifunc_as0()
+define void @call_ifunc_as0() addrspace(1) {
+ call addrspace(0) void @ifunc_as0()
+ ret void
+}
+
+; CHECK: define void @call_ifunc_as1() addrspace(1) {
+; CHECK-NEXT: call addrspace(1) void @ifunc_as1()
+define void @call_ifunc_as1() addrspace(1) {
+ call addrspace(1) void @ifunc_as1()
+ ret void
+}
More information about the llvm-commits
mailing list