Test source: git
Source: <stdin>
-- 1. ModuleToFunctionPassAdaptor
ERROR: Unsupported instruction: %toptr = inttoptr i32 %a to ptr addrspace(1)
ERROR: Unsupported instruction: %toptr = inttoptr i32 -1 to ptr addrspace(1)
ERROR: Unsupported instruction: %toptr = inttoptr i64 -1 to ptr addrspace(1)
ERROR: Unsupported instruction: %toptr = inttoptr i16 -1 to ptr addrspace(1)
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) null,
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) @g.as
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %sub = sub i32 ptrtoaddr (ptr addrspace(1) getelementptr (i8, ptr addrspace(1)
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %cmp = icmp ne i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), 0
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoint ptr addrspace(1) @g.as1 to i64
ERROR: Unsupported instruction: %cmp = icmp ne i64 ptrtoint (ptr addrspace(1) @g.as1 to i64), 0
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g2.as1 to i32
ERROR: Unsupported instruction: %cmp = icmp ne i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), ptrtoaddr (ptr
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoint ptr addrspace(1) @g.as1 to i64
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoint ptr addrspace(1) @g2.as1 to i64
ERROR: Unsupported instruction: %cmp = icmp ne i64 ptrtoint (ptr addrspace(1) @g.as1 to i64), ptrtoint (ptr ad
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) getelementptr inbounds (i8, ptr ad
ERROR: Unsupported instruction: %cmp = icmp ult i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), ptrtoaddr (ptr
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoint ptr addrspace(1) @g.as1 to i64
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoint ptr addrspace(1) getelementptr inbounds (i8, ptr add
ERROR: Unsupported instruction: %cmp = icmp ult i64 ptrtoint (ptr addrspace(1) @g.as1 to i64), ptrtoint (ptr a
-- 1. PassManager<Function> : Skipping NOP
-- 2. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_arg(i64 %a) {
#0:
%toptr = inttoptr i64 %a to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 3. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_arg(i64 %a) {
#0:
%toptr = inttoptr i64 %a to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
=>
define i64 @ptrtoaddr_inttoptr_arg(i64 %a) {
#0:
ret i64 %a
}
Transformation seems to be correct!
-- 4. PassManager<Function> : Skipping NOP
-- 5. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toptr = inttoptr i32 %a to ptr addrspace(1)
-- 6. InstSimplifyPass
ERROR: Unsupported instruction: %toptr = inttoptr i32 %a to ptr addrspace(1)
-- 7. InstSimplifyPass
-- 8. PassManager<Function> : Skipping NOP
-- 9. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toptr = inttoptr i32 -1 to ptr addrspace(1)
-- 10. InstSimplifyPass
ERROR: Unsupported instruction: %toptr = inttoptr i32 -1 to ptr addrspace(1)
-- 11. InstSimplifyPass
-- 12. PassManager<Function> : Skipping NOP
-- 13. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toptr = inttoptr i64 -1 to ptr addrspace(1)
-- 14. InstSimplifyPass
ERROR: Unsupported instruction: %toptr = inttoptr i64 -1 to ptr addrspace(1)
-- 15. InstSimplifyPass
-- 16. PassManager<Function> : Skipping NOP
-- 17. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toptr = inttoptr i16 -1 to ptr addrspace(1)
-- 18. InstSimplifyPass
ERROR: Unsupported instruction: %toptr = inttoptr i16 -1 to ptr addrspace(1)
-- 19. InstSimplifyPass
-- 20. PassManager<Function> : Skipping NOP
-- 21. PassManager<Function> : Skipping NOP
-- 22. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas1() {
#0:
%toptr = gep ptr null, 1 x i64 1
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 23. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas1() {
#0:
%toptr = gep ptr null, 1 x i64 1
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
=>
define i64 @ptrtoaddr_inttoptr_noas1() {
#0:
ret i64 1
}
Transformation seems to be correct!
-- 24. PassManager<Function> : Skipping NOP
-- 25. PassManager<Function> : Skipping NOP
-- 26. InstSimplifyPass
----------------------------------------
define i64 @ptr2addr2_inttoptr_noas2() {
#0:
%toptr = inttoptr i64 123 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 27. InstSimplifyPass
----------------------------------------
define i64 @ptr2addr2_inttoptr_noas2() {
#0:
%toptr = inttoptr i64 123 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
=>
define i64 @ptr2addr2_inttoptr_noas2() {
#0:
ret i64 123
}
Transformation seems to be correct!
-- 28. PassManager<Function> : Skipping NOP
-- 29. PassManager<Function> : Skipping NOP
-- 30. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas_diff_size1() {
#0:
%toptr = inttoptr i32 4294967295 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 31. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas_diff_size1() {
#0:
%toptr = inttoptr i32 4294967295 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
=>
define i64 @ptrtoaddr_inttoptr_noas_diff_size1() {
#0:
ret i64 4294967295
}
Transformation seems to be correct!
-- 32. PassManager<Function> : Skipping NOP
-- 33. PassManager<Function> : Skipping NOP
-- 34. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas_diff_size2() {
#0:
%toptr = inttoptr i128 340282366920938463463374607431768211455 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 35. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_inttoptr_noas_diff_size2() {
#0:
%toptr = inttoptr i128 340282366920938463463374607431768211455 to ptr
%toaddr = ptrtoaddr ptr %toptr to i64
ret i64 %toaddr
}
=>
define i64 @ptrtoaddr_inttoptr_noas_diff_size2() {
#0:
ret i64 -1
}
Transformation seems to be correct!
-- 36. PassManager<Function> : Skipping NOP
-- 37. PassManager<Function> : Skipping NOP
-- 38. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_gep_null() {
#0:
%__constexpr_0 = gep ptr null, 1 x i64 42
%toaddr = ptrtoaddr ptr %__constexpr_0 to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 39. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_gep_null() {
#0:
%__constexpr_0 = gep ptr null, 1 x i64 42
%toaddr = ptrtoaddr ptr %__constexpr_0 to i64
ret i64 %toaddr
}
=>
define i64 @ptrtoaddr_gep_null() {
#0:
ret i64 42
}
Transformation seems to be correct!
-- 40. PassManager<Function> : Skipping NOP
-- 41. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) null,
-- 42. InstSimplifyPass
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) null,
-- 43. InstSimplifyPass
-- 44. PassManager<Function> : Skipping NOP
-- 45. PassManager<Function> : Skipping NOP
-- 46. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_gep_sub() {
#0:
%__constexpr_2 = ptrtoaddr ptr @g2 to i64
%__constexpr_1 = sub i64 0, %__constexpr_2
%__constexpr_0 = gep ptr @g, 1 x i64 %__constexpr_1
%toaddr = ptrtoaddr ptr %__constexpr_0 to i64
ret i64 %toaddr
}
Transformation seems to be correct! (syntactically equal)
-- 47. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_gep_sub() {
#0:
%__constexpr_2 = ptrtoaddr ptr @g2 to i64
%__constexpr_1 = sub i64 0, %__constexpr_2
%__constexpr_0 = gep ptr @g, 1 x i64 %__constexpr_1
%toaddr = ptrtoaddr ptr %__constexpr_0 to i64
ret i64 %toaddr
}
=>
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_gep_sub() {
#0:
%__constexpr_1 = ptrtoaddr ptr @g to i64
%__constexpr_2 = ptrtoaddr ptr @g2 to i64
%__constexpr_0 = sub i64 %__constexpr_1, %__constexpr_2
ret i64 %__constexpr_0
}
Transformation seems to be correct!
-- 48. PassManager<Function> : Skipping NOP
-- 49. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) @g.as
-- 50. InstSimplifyPass
ERROR: Unsupported instruction: %toaddr = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1) @g.as
-- 51. InstSimplifyPass
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %__constexpr_2 = ptrtoaddr ptr addrspace(1) @g2.as1 to i32
ERROR: Unsupported instruction: %__constexpr_0 = sub i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), ptrtoaddr
ERROR: Unsupported instruction: ret i32 sub (i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), i32 ptrtoaddr (pt
-- 52. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %__constexpr_2 = ptrtoaddr ptr addrspace(1) @g2.as1 to i32
ERROR: Unsupported instruction: %__constexpr_0 = sub i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), ptrtoaddr
ERROR: Unsupported instruction: ret i32 sub (i32 ptrtoaddr (ptr addrspace(1) @g.as1 to i32), i32 ptrtoaddr (pt
-- 53. PassManager<Function> : Skipping NOP
-- 54. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
define ptr @inttoptr_of_ptrtoaddr() {
#0:
%__constexpr_0 = ptrtoaddr ptr @g to i64
%toptr = inttoptr i64 %__constexpr_0 to ptr
ret ptr %toptr
}
Transformation seems to be correct! (syntactically equal)
-- 55. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
define ptr @inttoptr_of_ptrtoaddr() {
#0:
%__constexpr_0 = ptrtoaddr ptr @g to i64
%toptr = inttoptr i64 %__constexpr_0 to ptr
ret ptr %toptr
}
=>
@g = global 1 bytes, align 1
define ptr @inttoptr_of_ptrtoaddr() {
#0:
%__constexpr_1 = ptrtoaddr ptr @g to i64
%__constexpr_0 = inttoptr i64 %__constexpr_1 to ptr
ret ptr %__constexpr_0
}
Transformation seems to be correct!
-- 56. PassManager<Function> : Skipping NOP
-- 57. PassManager<Function> : Skipping NOP
-- 58. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_unrelated() {
#0:
%__constexpr_0 = ptrtoaddr ptr @g to i64
%__constexpr_1 = ptrtoaddr ptr @g2 to i64
%sub = sub i64 %__constexpr_0, %__constexpr_1
ret i64 %sub
}
Transformation seems to be correct! (syntactically equal)
-- 59. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_unrelated() {
#0:
%__constexpr_0 = ptrtoaddr ptr @g to i64
%__constexpr_1 = ptrtoaddr ptr @g2 to i64
%sub = sub i64 %__constexpr_0, %__constexpr_1
ret i64 %sub
}
=>
@g = global 1 bytes, align 1
@g2 = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_unrelated() {
#0:
%__constexpr_1 = ptrtoaddr ptr @g to i64
%__constexpr_2 = ptrtoaddr ptr @g2 to i64
%__constexpr_0 = sub i64 %__constexpr_1, %__constexpr_2
ret i64 %__constexpr_0
}
Transformation seems to be correct!
-- 60. PassManager<Function> : Skipping NOP
-- 61. PassManager<Function> : Skipping NOP
-- 62. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_offset() {
#0:
%__constexpr_1 = gep ptr @g, 1 x i64 42
%__constexpr_0 = ptrtoaddr ptr %__constexpr_1 to i64
%__constexpr_2 = ptrtoaddr ptr @g to i64
%sub = sub i64 %__constexpr_0, %__constexpr_2
ret i64 %sub
}
Transformation seems to be correct! (syntactically equal)
-- 63. InstSimplifyPass
----------------------------------------
@g = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_offset() {
#0:
%__constexpr_1 = gep ptr @g, 1 x i64 42
%__constexpr_0 = ptrtoaddr ptr %__constexpr_1 to i64
%__constexpr_2 = ptrtoaddr ptr @g to i64
%sub = sub i64 %__constexpr_0, %__constexpr_2
ret i64 %sub
}
=>
@g = global 1 bytes, align 1
define i64 @ptrtoaddr_sub_consts_offset() {
#0:
ret i64 42
}
Transformation seems to be correct!
-- 64. PassManager<Function> : Skipping NOP
-- 65. PassManager<Function> : Skipping NOP
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %sub = sub i32 ptrtoaddr (ptr addrspace(1) getelementptr (i8, ptr addrspace(1)
-- 66. InstSimplifyPass
ERROR: Unsupported instruction: %__constexpr_0 = ptrtoaddr ptr addrspace(1) getelementptr (i8, ptr addrspace(1
ERROR: Unsupported instruction: %__constexpr_1 = ptrtoaddr ptr addrspace(1) @g.as1 to i32
ERROR: Unsupported instruction: %sub = sub i32 ptrtoaddr (ptr addrspace(1) getelementptr (i8, ptr addrspace(1)
-- 67. InstSimplifyPass
-- 68. PassManager<Function> : Skipping NOP
-- 69. PassManager<Function> : Skipping NOP
-- 70. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_sub_known_offset(ptr %p) {
#0:
%p2 = gep inbounds ptr %p, 1 x i64 42
%p.addr = ptrtoaddr ptr %p to i64
%p2.addr = ptrtoaddr ptr %p2 to i64
%sub = sub i64 %p2.addr, %p.addr
ret i64 %sub
}
Transformation seems to be correct! (syntactically equal)
-- 71. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_sub_known_offset(ptr %p) {
#0:
%p2 = gep inbounds ptr %p, 1 x i64 42
%p.addr = ptrtoaddr ptr %p to i64
%p2.addr = ptrtoaddr ptr %p2 to i64
%sub = sub i64 %p2.addr, %p.addr
ret i64 %sub
}
=>
define i64 @ptrtoaddr_sub_known_offset(ptr %p) {
#0:
ret i64 42
}
Transformation seems to be correct!
-- 72. PassManager<Function> : Skipping NOP
-- 73. PassManager<Function> : Skipping NOP
-- 74. InstSimplifyPass
-- 75. InstSimplifyPass
-- 76. PassManager<Function> : Skipping NOP
-- 77. PassManager<Function> : Skipping NOP
-- 78. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_of_ptradd_of_sub(i64 %x, ptr %p) {
#0:
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %x, %p.addr
%ptradd = gep ptr %p, 1 x i64 %sub
%ptradd.addr = ptrtoaddr ptr %ptradd to i64
ret i64 %ptradd.addr
}
Transformation seems to be correct! (syntactically equal)
-- 79. InstSimplifyPass
----------------------------------------
define i64 @ptrtoaddr_of_ptradd_of_sub(i64 %x, ptr %p) {
#0:
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %x, %p.addr
%ptradd = gep ptr %p, 1 x i64 %sub
%ptradd.addr = ptrtoaddr ptr %ptradd to i64
ret i64 %ptradd.addr
}
=>
define i64 @ptrtoaddr_of_ptradd_of_sub(i64 %x, ptr %p) {
#0:
ret i64 %x
}
Transformation doesn't verify! (not unsound)
ERROR: Timeout
Pass: InstSimplifyPass
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=instsimplify' '-S' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats'
-- 80. PassManager<Function> : Skipping NOP
-- 81. PassManager<Function> : Skipping NOP
-- 82. InstSimplifyPass
-- 83. InstSimplifyPass
-- 84. PassManager<Function> : Skipping NOP
-- 85. PassManager<Function> : Skipping NOP
-- 86. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr_unrelated_pointers(ptr %p, ptr %p2, i64 %x) {
#0:
%p2.addr = ptrtoaddr ptr %p2 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %p2.addr, %p.addr
%gep2 = gep ptr %p, 1 x i64 %sub
ret ptr %gep2
}
Transformation seems to be correct! (syntactically equal)
-- 87. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr_unrelated_pointers(ptr %p, ptr %p2, i64 %x) {
#0:
%p2.addr = ptrtoaddr ptr %p2 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %p2.addr, %p.addr
%gep2 = gep ptr %p, 1 x i64 %sub
ret ptr %gep2
}
Transformation seems to be correct! (syntactically equal)
-- 88. PassManager<Function> : Skipping NOP
-- 89. PassManager<Function> : Skipping NOP
-- 90. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
%gep1.addr = ptrtoaddr ptr %gep1 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %gep1.addr, %p.addr
%gep2 = gep ptr %p, 1 x i64 %sub
ret ptr %gep2
}
Transformation seems to be correct! (syntactically equal)
-- 91. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
%gep1.addr = ptrtoaddr ptr %gep1 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %gep1.addr, %p.addr
%gep2 = gep ptr %p, 1 x i64 %sub
ret ptr %gep2
}
=>
define ptr @gep_of_sub_ptrtoaddr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
ret ptr %gep1
}
Transformation doesn't verify! (not unsound)
ERROR: Timeout
Pass: InstSimplifyPass
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=instsimplify' '-S' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats'
-- 92. PassManager<Function> : Skipping NOP
-- 93. PassManager<Function> : Skipping NOP
-- 94. InstSimplifyPass
-- 95. InstSimplifyPass
-- 96. PassManager<Function> : Skipping NOP
-- 97. PassManager<Function> : Skipping NOP
-- 98. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr_ashr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
%gep1.addr = ptrtoaddr ptr %gep1 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %gep1.addr, %p.addr
%ashr = ashr i64 %sub, 1
%gep2 = gep ptr %p, 2 x i64 %ashr
ret ptr %gep2
}
Transformation seems to be correct! (syntactically equal)
-- 99. InstSimplifyPass
----------------------------------------
define ptr @gep_of_sub_ptrtoaddr_ashr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
%gep1.addr = ptrtoaddr ptr %gep1 to i64
%p.addr = ptrtoaddr ptr %p to i64
%sub = sub i64 %gep1.addr, %p.addr
%ashr = ashr i64 %sub, 1
%gep2 = gep ptr %p, 2 x i64 %ashr
ret ptr %gep2
}
=>
define ptr @gep_of_sub_ptrtoaddr_ashr(ptr %p, i64 %x) {
#0:
%gep1 = gep ptr %p, 1 x i64 %x
ret ptr %gep1
}
Transformation doesn't verify! (unsound)
ERROR: Value mismatch
Example:
ptr %p = null
i64 %x = #x0000000000000003 (3)
Source:
ptr %gep1 = pointer(non-local, block_id=0, offset=3) / Address=#x0000000000000003
i64 %gep1.addr = #x0000000000000003 (3)
i64 %p.addr = #x0000000000000000 (0)
i64 %sub = #x0000000000000003 (3)
i64 %ashr = #x0000000000000001 (1)
ptr %gep2 = pointer(non-local, block_id=0, offset=2) / Address=#x0000000000000002
SOURCE MEMORY STATE
===================
NON-LOCAL BLOCKS:
Block 0 > size: 0 align: 1 alloc type: 0 alive: false address: #x0000000000000000
Block 1 > size: 0 align: 1 alloc type: 0 alive: true address: #x0000000000000001
Target:
ptr %gep1 = pointer(non-local, block_id=0, offset=3) / Address=#x0000000000000003
TARGET MEMORY STATE
===================
NON-LOCAL BLOCKS:
Block 0 > size: 0 align: 1 alloc type: 0 alive: false address: #x0000000000000000
Block 1 > size: 0 align: 1 alloc type: 0 alive: true address: #x0000000000000001
Source value: pointer(non-local, block_id=0, offset=2) / Address=#x0000000000000002
Target value: pointer(non-local, block_id=0, offset=3) / Address=#x0000000000000003
Pass: InstSimplifyPass
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=instsimplify' '-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_hP6yg8N9_hAEH.bc"
------------------- SMT STATS -------------------
Num queries: 54
Num invalid: 0
Num skips: 0
Num trivial: 81 (60.0%)
Num timeout: 2 (3.7%)
Num errors: 0 (0.0%)
Num SAT: 42 (77.8%)
Num UNSAT: 10 (18.5%)
Alive2: Transform doesn't verify; aborting!
Transforms/InstSimplify/ptrtoaddr.ll' FAILED ******************** Exit Code: 2 Command Output (stdout): -- # RUN: at line 2 /home/nlopes/alive2/build/opt-alive.sh < /bitbucket/nlopes/llvm/llvm/test/Transforms/InstSimplify/ptrtoaddr.ll -passes=instsimplify -S | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstSimplify/ptrtoaddr.ll # executed command: /home/nlopes/alive2/build/opt-alive.sh -passes=instsimplify -S # .---command stderr------------ # `----------------------------- # error: command failed with exit status: 1 # executed command: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstSimplify/ptrtoaddr.ll # .---command stderr------------ # | FileCheck error: '<stdin>' is empty. # | FileCheck command line: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstSimplify/ptrtoaddr.ll # `----------------------------- # error: command failed with exit status: 2 --