[llvm] 7d44645 - [GVN] Add test with different captures attributes (NFC)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri Jun 6 02:24:32 PDT 2025
Author: Nikita Popov
Date: 2025-06-06T11:24:24+02:00
New Revision: 7d4464599f2072154adf724c83aa812b538fd669
URL: https://github.com/llvm/llvm-project/commit/7d4464599f2072154adf724c83aa812b538fd669
DIFF: https://github.com/llvm/llvm-project/commit/7d4464599f2072154adf724c83aa812b538fd669.diff
LOG: [GVN] Add test with different captures attributes (NFC)
Added:
llvm/test/Transforms/GVN/captures.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/GVN/captures.ll b/llvm/test/Transforms/GVN/captures.ll
new file mode 100644
index 0000000000000..ae47e92da0f2b
--- /dev/null
+++ b/llvm/test/Transforms/GVN/captures.ll
@@ -0,0 +1,93 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
+; RUN: opt -S -passes=gvn < %s | FileCheck %s
+
+declare void @capture(ptr)
+declare void @unknown_call()
+
+define i32 @full_capture() {
+; CHECK-LABEL: define i32 @full_capture() {
+; CHECK-NEXT: [[A:%.*]] = alloca i32, align 4
+; CHECK-NEXT: call void @capture(ptr [[A]])
+; CHECK-NEXT: store i32 1, ptr [[A]], align 4
+; CHECK-NEXT: call void @unknown_call()
+; CHECK-NEXT: [[V:%.*]] = load i32, ptr [[A]], align 4
+; CHECK-NEXT: ret i32 [[V]]
+;
+ %a = alloca i32
+ call void @capture(ptr %a)
+ store i32 1, ptr %a
+ call void @unknown_call()
+ %v = load i32, ptr %a
+ ret i32 %v
+}
+
+define i32 @address_capture() {
+; CHECK-LABEL: define i32 @address_capture() {
+; CHECK-NEXT: [[A:%.*]] = alloca i32, align 4
+; CHECK-NEXT: call void @capture(ptr captures(address) [[A]])
+; CHECK-NEXT: store i32 1, ptr [[A]], align 4
+; CHECK-NEXT: call void @unknown_call()
+; CHECK-NEXT: ret i32 1
+;
+ %a = alloca i32
+ call void @capture(ptr captures(address) %a)
+ store i32 1, ptr %a
+ call void @unknown_call()
+ %v = load i32, ptr %a
+ ret i32 %v
+}
+
+define i32 @read_provenance_capture() {
+; CHECK-LABEL: define i32 @read_provenance_capture() {
+; CHECK-NEXT: [[A:%.*]] = alloca i32, align 4
+; CHECK-NEXT: call void @capture(ptr captures(address, read_provenance) [[A]])
+; CHECK-NEXT: store i32 1, ptr [[A]], align 4
+; CHECK-NEXT: call void @unknown_call()
+; CHECK-NEXT: [[V:%.*]] = load i32, ptr [[A]], align 4
+; CHECK-NEXT: ret i32 [[V]]
+;
+ %a = alloca i32
+ call void @capture(ptr captures(address, read_provenance) %a)
+ store i32 1, ptr %a
+ call void @unknown_call()
+ %v = load i32, ptr %a
+ ret i32 %v
+}
+
+define i32 @read_provenance_capture_and_full_capture() {
+; CHECK-LABEL: define i32 @read_provenance_capture_and_full_capture() {
+; CHECK-NEXT: [[A:%.*]] = alloca i32, align 4
+; CHECK-NEXT: call void @capture(ptr captures(address, read_provenance) [[A]])
+; CHECK-NEXT: call void @capture(ptr [[A]])
+; CHECK-NEXT: store i32 1, ptr [[A]], align 4
+; CHECK-NEXT: call void @unknown_call()
+; CHECK-NEXT: [[V:%.*]] = load i32, ptr [[A]], align 4
+; CHECK-NEXT: ret i32 [[V]]
+;
+ %a = alloca i32
+ call void @capture(ptr captures(address, read_provenance) %a)
+ call void @capture(ptr %a)
+ store i32 1, ptr %a
+ call void @unknown_call()
+ %v = load i32, ptr %a
+ ret i32 %v
+}
+
+define i32 @read_provenance_capture_and_full_capture_commuted() {
+; CHECK-LABEL: define i32 @read_provenance_capture_and_full_capture_commuted() {
+; CHECK-NEXT: [[A:%.*]] = alloca i32, align 4
+; CHECK-NEXT: call void @capture(ptr [[A]])
+; CHECK-NEXT: call void @capture(ptr captures(address, read_provenance) [[A]])
+; CHECK-NEXT: store i32 1, ptr [[A]], align 4
+; CHECK-NEXT: call void @unknown_call()
+; CHECK-NEXT: [[V:%.*]] = load i32, ptr [[A]], align 4
+; CHECK-NEXT: ret i32 [[V]]
+;
+ %a = alloca i32
+ call void @capture(ptr %a)
+ call void @capture(ptr captures(address, read_provenance) %a)
+ store i32 1, ptr %a
+ call void @unknown_call()
+ %v = load i32, ptr %a
+ ret i32 %v
+}
More information about the llvm-commits
mailing list