Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Transforms / Attributor / ArgumentPromotion / invalidation.ll
blobeee4e38ad9870044bcf77a43653423f491b1fb23
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature --check-attributes --check-globals
2 ; Check that when argument promotion changes a function in some parent node of
3 ; the call graph, any analyses that happened to be cached for that function are
4 ; actually invalidated. We are using `demanded-bits` here because when printed
5 ; it will end up caching a value for every instruction, making it easy to
6 ; detect the instruction-level changes that will fail here. With improper
7 ; invalidation this will crash in the second printer as it tries to reuse
8 ; now-invalid demanded bits.
10 ; RUN: opt < %s -passes='function(print<demanded-bits>),attributor,function(print<demanded-bits>)' -S | FileCheck %s
12 @G = constant i32 0
15 ; CHECK: @G = constant i32 0
17 define internal i32 @a(ptr %x) {
18 entry:
19   %v = load i32, ptr %x
20   ret i32 %v
23 define i32 @b() {
24 ; CHECK: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(none)
25 ; CHECK-LABEL: define {{[^@]+}}@b
26 ; CHECK-SAME: () #[[ATTR0:[0-9]+]] {
27 ; CHECK-NEXT:  entry:
28 ; CHECK-NEXT:    ret i32 0
30 entry:
31   %v = call i32 @a(ptr @G)
32   ret i32 %v
35 define i32 @c() {
36 ; CHECK: Function Attrs: mustprogress nofree norecurse nosync nounwind willreturn memory(none)
37 ; CHECK-LABEL: define {{[^@]+}}@c
38 ; CHECK-SAME: () #[[ATTR0]] {
39 ; CHECK-NEXT:  entry:
40 ; CHECK-NEXT:    ret i32 0
42 entry:
43   %v1 = call i32 @a(ptr @G)
44   %v2 = call i32 @b()
45   %result = add i32 %v1, %v2
46   ret i32 %result
49 ; CHECK: attributes #[[ATTR0]] = { mustprogress nofree norecurse nosync nounwind willreturn memory(none) }