Test Failure: Transforms/GVN/metadata.ll

Test source: git

Comments: LLVM bug: introduces load type punning

Log:

Source: <stdin>
-- 1. ModuleToFunctionPassAdaptor
ERROR: Unsupported metadata: 6
-- 1. PassManager<llvm::Function> : Skipping NOP
-- 2. GVNPass

----------------------------------------
define i32 @test1(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 0, i32 2
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 3. GVNPass

----------------------------------------
define i32 @test1(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 0, i32 2
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test1(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 4. PassManager<llvm::Function> : Skipping NOP
-- 5. PassManager<llvm::Function> : Skipping NOP
-- 6. GVNPass

----------------------------------------
define i32 @test2(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %c = add i32 %a_range, %b
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 7. GVNPass

----------------------------------------
define i32 @test2(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %c = add i32 %a_range, %b
  ret i32 %c
}
=>
define i32 @test2(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %c = add i32 %a, %a
  ret i32 %c
}
Transformation seems to be correct!

-- 8. PassManager<llvm::Function> : Skipping NOP
-- 9. PassManager<llvm::Function> : Skipping NOP
-- 10. GVNPass

----------------------------------------
define i32 @test3(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 11. GVNPass

----------------------------------------
define i32 @test3(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test3(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2, i32 3, i32 5
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 12. PassManager<llvm::Function> : Skipping NOP
-- 13. PassManager<llvm::Function> : Skipping NOP
-- 14. GVNPass

----------------------------------------
define i32 @test4(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 2, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 15. GVNPass

----------------------------------------
define i32 @test4(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 2, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test4(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 5
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 16. PassManager<llvm::Function> : Skipping NOP
-- 17. PassManager<llvm::Function> : Skipping NOP
-- 18. GVNPass

----------------------------------------
define i32 @test5(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 4294967291, i32 4294967294
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 1, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 19. GVNPass

----------------------------------------
define i32 @test5(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 4294967291, i32 4294967294
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 1, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test5(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 4294967291, i32 4294967294, i32 1, i32 5
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 20. PassManager<llvm::Function> : Skipping NOP
-- 21. PassManager<llvm::Function> : Skipping NOP
-- 22. GVNPass

----------------------------------------
define i32 @test6(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 10, i32 1
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 12, i32 16
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 23. GVNPass

----------------------------------------
define i32 @test6(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 10, i32 1
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 12, i32 16
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test6(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 10, i32 1
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 24. PassManager<llvm::Function> : Skipping NOP
-- 25. PassManager<llvm::Function> : Skipping NOP
-- 26. GVNPass

----------------------------------------
define i32 @test7(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 1, i32 2, i32 3, i32 4
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 5, i32 1
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 27. GVNPass

----------------------------------------
define i32 @test7(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 1, i32 2, i32 3, i32 4
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 5, i32 1
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test7(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 3, i32 4, i32 5, i32 2
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 28. PassManager<llvm::Function> : Skipping NOP
-- 29. PassManager<llvm::Function> : Skipping NOP
-- 30. GVNPass

----------------------------------------
define i32 @test8(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 1, i32 5
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 5, i32 1
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 31. GVNPass

----------------------------------------
define i32 @test8(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 1, i32 5
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 5, i32 1
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @test8(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %c = add i32 %a, %a
  ret i32 %c
}
Transformation seems to be correct!

-- 32. PassManager<llvm::Function> : Skipping NOP
-- 33. PassManager<llvm::Function> : Skipping NOP
-- 34. GVNPass

----------------------------------------
define i32 @load_noundef_load(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  assume_welldefined i32 %a_range
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 35. GVNPass

----------------------------------------
define i32 @load_noundef_load(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  assume_welldefined i32 %a_range
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @load_noundef_load(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  assume_welldefined i32 %a_range
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 36. PassManager<llvm::Function> : Skipping NOP
-- 37. PassManager<llvm::Function> : Skipping NOP
-- 38. GVNPass

----------------------------------------
define i32 @load_load_noundef(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  assume_welldefined i32 %b_range
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
Transformation seems to be correct! (syntactically equal)

-- 39. GVNPass

----------------------------------------
define i32 @load_load_noundef(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2
  %b = load i32, ptr %p, align 4
  %b_range = !range i32 %b, i32 3, i32 5
  assume_welldefined i32 %b_range
  %c = add i32 %a_range, %b_range
  ret i32 %c
}
=>
define i32 @load_load_noundef(ptr %p) {
#0:
  %a = load i32, ptr %p, align 4
  %a_range = !range i32 %a, i32 0, i32 2, i32 3, i32 5
  %c = add i32 %a_range, %a_range
  ret i32 %c
}
Transformation seems to be correct!

-- 40. PassManager<llvm::Function> : Skipping NOP
-- 41. PassManager<llvm::Function> : Skipping NOP
-- 42. GVNPass

----------------------------------------
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  assume_dereferenceable ptr %a, i64 10
  %b = load ptr, ptr %p, align 8
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %b) nofree memory(none)
  ret void
}
Transformation seems to be correct! (syntactically equal)

-- 43. GVNPass

----------------------------------------
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  assume_dereferenceable ptr %a, i64 10
  %b = load ptr, ptr %p, align 8
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %b) nofree memory(none)
  ret void
}
=>
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  assume_dereferenceable ptr %a, i64 10
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %a) nofree memory(none)
  ret void
}
Transformation seems to be correct!

-- 44. PassManager<llvm::Function> : Skipping NOP
-- 45. PassManager<llvm::Function> : Skipping NOP
-- 46. GVNPass

----------------------------------------
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_not_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  %b = load ptr, ptr %p, align 8
  assume_dereferenceable ptr %b, i64 10
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %b) nofree memory(none)
  ret void
}
Transformation seems to be correct! (syntactically equal)

-- 47. GVNPass

----------------------------------------
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_not_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  %b = load ptr, ptr %p, align 8
  assume_dereferenceable ptr %b, i64 10
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %b) nofree memory(none)
  ret void
}
=>
declare void @use.ptr(ptr) nofree memory(none)

define void @load_dereferenceable_not_dominating(ptr %p) {
#0:
  %a = load ptr, ptr %p, align 8
  call void @use.ptr(ptr %a) nofree memory(none)
  call void @use.ptr(ptr %a) nofree memory(none)
  ret void
}
Transformation seems to be correct!

-- 48. PassManager<llvm::Function> : Skipping NOP
-- 49. PassManager<llvm::Function> : Skipping NOP
-- 50. GVNPass

----------------------------------------
declare void @use.i64(i64) nofree memory(none)

define void @load_ptr_nonnull_to_i64(ptr %p) {
#0:
  %val = load ptr, ptr %p, align 8
  %val_nonnull = !nonnull ptr %val
  %val.int = ptrtoint ptr %val_nonnull to i64
  %val2 = load i64, ptr %p, align 8
  call void @use.i64(i64 %val.int) nofree memory(none)
  call void @use.i64(i64 %val2) nofree memory(none)
  ret void
}
Transformation seems to be correct! (syntactically equal)

-- 51. GVNPass

----------------------------------------
declare void @use.i64(i64) nofree memory(none)

define void @load_ptr_nonnull_to_i64(ptr %p) {
#0:
  %val = load ptr, ptr %p, align 8
  %val_nonnull = !nonnull ptr %val
  %val.int = ptrtoint ptr %val_nonnull to i64
  %val2 = load i64, ptr %p, align 8
  call void @use.i64(i64 %val.int) nofree memory(none)
  call void @use.i64(i64 %val2) nofree memory(none)
  ret void
}
=>
declare void @use.i64(i64) nofree memory(none)

define void @load_ptr_nonnull_to_i64(ptr %p) {
#0:
  %val = load ptr, ptr %p, align 8
  %val.int = ptrtoint ptr %val to i64
  call void @use.i64(i64 %val.int) nofree memory(none)
  call void @use.i64(i64 %val.int) nofree memory(none)
  ret void
}
Transformation doesn't verify! (unsound)
ERROR: Source and target don't have the same return domain

Example:
ptr %p = pointer(non-local, block_id=1, offset=0) / Address=#x0000000000000008

Source:
ptr %val = poison
ptr %val_nonnull = poison
i64 %val.int = poison
i64 %val2 = #x0000000000000010 (16)
Function @use.i64 returned
void = function did not return!

SOURCE MEMORY STATE
===================
NON-LOCAL BLOCKS:
Block 0 >	size: 0	align: 8	alloc type: 0	alive: false	address: 0
Block 1 >	size: 12	align: 4	alloc type: 0	alive: true	address: 8
Contents:
*: #x0000000000000010

Block 2 >	size: 0	align: 1	alloc type: 0	alive: true	address: 1
Contents:
*: #x0000000000000010


Target:
ptr %val = poison
i64 %val.int = poison
Function @use.i64 returned
Function @use.i64 returned


Pass: GVNPass
Command line: '/home/nlopes/llvm/build/bin/opt' '-load=/home/nlopes/alive2/build/tv/tv.so' '-load-pass-plugin=/home/nlopes/alive2/build/tv/tv.so' '-tv-exit-on-error' '-passes=gvn' '-S' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats'
Wrote bitcode to: "/home/nlopes/alive2/build/logs/in_d6KGCmS1_rYSe.bc"


------------------- SMT STATS -------------------
Num queries: 84
Num invalid: 0
Num skips:   0
Num trivial: 62 (42.5%)
Num timeout: 0 (0.0%)
Num errors:  0 (0.0%)
Num SAT:     60 (71.4%)
Num UNSAT:   24 (28.6%)
Alive2: Transform doesn't verify; aborting!

stderr:

RUN: at line 2: /home/nlopes/alive2/build/opt-alive.sh -passes=gvn -S < /bitbucket/nlopes/llvm/llvm/test/Transforms/GVN/metadata.ll | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/GVN/metadata.ll
+ /home/nlopes/alive2/build/opt-alive.sh -passes=gvn -S
+ /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/GVN/metadata.ll

FileCheck error: '<stdin>' is empty.
FileCheck command line:  /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/GVN/metadata.ll

 

<-- Back