Test source: git
Source: <stdin> -- 1. ModuleToFunctionPassAdaptor -- 1. PassManager<Function> : Skipping NOP -- 2. InstCombinePass ---------------------------------------- define i16 @test1(i16 %x) { #0: %ct = ctlz i16 %x, 1 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i16 %ct, i16 16 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 3. InstCombinePass ---------------------------------------- define i16 @test1(i16 %x) { #0: %ct = ctlz i16 %x, 1 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i16 %ct, i16 16 ret i16 %cond } => define i16 @test1(i16 %x) { #0: %ct = ctlz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 ret i16 %ct_range } Transformation seems to be correct! -- 4. PassManager<Function> : Skipping NOP -- 5. PassManager<Function> : Skipping NOP -- 6. InstCombinePass ---------------------------------------- define i32 @test2(i32 %x) { #0: %ct = ctlz i32 %x, 1 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i32 %ct, i32 32 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 7. InstCombinePass ---------------------------------------- define i32 @test2(i32 %x) { #0: %ct = ctlz i32 %x, 1 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i32 %ct, i32 32 ret i32 %cond } => define i32 @test2(i32 %x) { #0: %ct = ctlz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 ret i32 %ct_range } Transformation seems to be correct! -- 8. PassManager<Function> : Skipping NOP -- 9. PassManager<Function> : Skipping NOP -- 10. InstCombinePass ---------------------------------------- define i64 @test3(i64 %x) { #0: %ct = ctlz i64 %x, 1 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i64 %ct, i64 64 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 11. InstCombinePass ---------------------------------------- define i64 @test3(i64 %x) { #0: %ct = ctlz i64 %x, 1 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i64 %ct, i64 64 ret i64 %cond } => define i64 @test3(i64 %x) { #0: %ct = ctlz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 ret i64 %ct_range } Transformation seems to be correct! -- 12. PassManager<Function> : Skipping NOP -- 13. PassManager<Function> : Skipping NOP -- 14. InstCombinePass ---------------------------------------- define i16 @test4(i16 %x) { #0: %ct = ctlz i16 %x, 1 %tobool = icmp eq i16 %x, 0 %cond = select i1 %tobool, i16 16, i16 %ct ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 15. InstCombinePass ---------------------------------------- define i16 @test4(i16 %x) { #0: %ct = ctlz i16 %x, 1 %tobool = icmp eq i16 %x, 0 %cond = select i1 %tobool, i16 16, i16 %ct ret i16 %cond } => define i16 @test4(i16 %x) { #0: %ct = ctlz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 ret i16 %ct_range } Transformation seems to be correct! -- 16. PassManager<Function> : Skipping NOP -- 17. PassManager<Function> : Skipping NOP -- 18. InstCombinePass ---------------------------------------- define i32 @test5(i32 %x) { #0: %ct = ctlz i32 %x, 1 %tobool = icmp eq i32 %x, 0 %cond = select i1 %tobool, i32 32, i32 %ct ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 19. InstCombinePass ---------------------------------------- define i32 @test5(i32 %x) { #0: %ct = ctlz i32 %x, 1 %tobool = icmp eq i32 %x, 0 %cond = select i1 %tobool, i32 32, i32 %ct ret i32 %cond } => define i32 @test5(i32 %x) { #0: %ct = ctlz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 ret i32 %ct_range } Transformation seems to be correct! -- 20. PassManager<Function> : Skipping NOP -- 21. PassManager<Function> : Skipping NOP -- 22. InstCombinePass ---------------------------------------- define i64 @test6(i64 %x) { #0: %ct = ctlz i64 %x, 1 %tobool = icmp eq i64 %x, 0 %cond = select i1 %tobool, i64 64, i64 %ct ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 23. InstCombinePass ---------------------------------------- define i64 @test6(i64 %x) { #0: %ct = ctlz i64 %x, 1 %tobool = icmp eq i64 %x, 0 %cond = select i1 %tobool, i64 64, i64 %ct ret i64 %cond } => define i64 @test6(i64 %x) { #0: %ct = ctlz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 ret i64 %ct_range } Transformation seems to be correct! -- 24. PassManager<Function> : Skipping NOP -- 25. PassManager<Function> : Skipping NOP -- 26. InstCombinePass ---------------------------------------- define i16 @test1b(i16 %x) { #0: %ct = cttz i16 %x, 1 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i16 %ct, i16 16 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 27. InstCombinePass ---------------------------------------- define i16 @test1b(i16 %x) { #0: %ct = cttz i16 %x, 1 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i16 %ct, i16 16 ret i16 %cond } => define i16 @test1b(i16 %x) { #0: %ct = cttz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 ret i16 %ct_range } Transformation seems to be correct! -- 28. PassManager<Function> : Skipping NOP -- 29. PassManager<Function> : Skipping NOP -- 30. InstCombinePass ---------------------------------------- define i32 @test2b(i32 %x) { #0: %ct = cttz i32 %x, 1 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i32 %ct, i32 32 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 31. InstCombinePass ---------------------------------------- define i32 @test2b(i32 %x) { #0: %ct = cttz i32 %x, 1 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i32 %ct, i32 32 ret i32 %cond } => define i32 @test2b(i32 %x) { #0: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 ret i32 %ct_range } Transformation seems to be correct! -- 32. PassManager<Function> : Skipping NOP -- 33. PassManager<Function> : Skipping NOP -- 34. InstCombinePass ---------------------------------------- define i64 @test3b(i64 %x) { #0: %ct = cttz i64 %x, 1 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i64 %ct, i64 64 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 35. InstCombinePass ---------------------------------------- define i64 @test3b(i64 %x) { #0: %ct = cttz i64 %x, 1 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i64 %ct, i64 64 ret i64 %cond } => define i64 @test3b(i64 %x) { #0: %ct = cttz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 ret i64 %ct_range } Transformation seems to be correct! -- 36. PassManager<Function> : Skipping NOP -- 37. PassManager<Function> : Skipping NOP -- 38. InstCombinePass ---------------------------------------- define i16 @test4b(i16 %x) { #0: %ct = cttz i16 %x, 1 %tobool = icmp eq i16 %x, 0 %cond = select i1 %tobool, i16 16, i16 %ct ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 39. InstCombinePass ---------------------------------------- define i16 @test4b(i16 %x) { #0: %ct = cttz i16 %x, 1 %tobool = icmp eq i16 %x, 0 %cond = select i1 %tobool, i16 16, i16 %ct ret i16 %cond } => define i16 @test4b(i16 %x) { #0: %ct = cttz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 ret i16 %ct_range } Transformation seems to be correct! -- 40. PassManager<Function> : Skipping NOP -- 41. PassManager<Function> : Skipping NOP -- 42. InstCombinePass ---------------------------------------- define i32 @test5b(i32 %x) { entry: %ct = cttz i32 %x, 1 %tobool = icmp eq i32 %x, 0 %cond = select i1 %tobool, i32 32, i32 %ct ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 43. InstCombinePass ---------------------------------------- define i32 @test5b(i32 %x) { entry: %ct = cttz i32 %x, 1 %tobool = icmp eq i32 %x, 0 %cond = select i1 %tobool, i32 32, i32 %ct ret i32 %cond } => define i32 @test5b(i32 %x) { entry: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 ret i32 %ct_range } Transformation seems to be correct! -- 44. PassManager<Function> : Skipping NOP -- 45. PassManager<Function> : Skipping NOP -- 46. InstCombinePass ---------------------------------------- define i64 @test6b(i64 %x) { #0: %ct = cttz i64 %x, 1 %tobool = icmp eq i64 %x, 0 %cond = select i1 %tobool, i64 64, i64 %ct ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 47. InstCombinePass ---------------------------------------- define i64 @test6b(i64 %x) { #0: %ct = cttz i64 %x, 1 %tobool = icmp eq i64 %x, 0 %cond = select i1 %tobool, i64 64, i64 %ct ret i64 %cond } => define i64 @test6b(i64 %x) { #0: %ct = cttz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 ret i64 %ct_range } Transformation seems to be correct! -- 48. PassManager<Function> : Skipping NOP -- 49. PassManager<Function> : Skipping NOP -- 50. InstCombinePass ---------------------------------------- define i32 @test1c(i16 %x) { #0: %ct = cttz i16 %x, 1 %cast2 = zext i16 %ct to i32 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i32 %cast2, i32 16 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 51. InstCombinePass ---------------------------------------- define i32 @test1c(i16 %x) { #0: %ct = cttz i16 %x, 1 %cast2 = zext i16 %ct to i32 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i32 %cast2, i32 16 ret i32 %cond } => define i32 @test1c(i16 %x) { #0: %ct = cttz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 %cast2 = zext nneg i16 %ct_range to i32 ret i32 %cast2 } Transformation seems to be correct! -- 52. PassManager<Function> : Skipping NOP -- 53. PassManager<Function> : Skipping NOP -- 54. InstCombinePass ---------------------------------------- define i64 @test2c(i16 %x) { #0: %ct = cttz i16 %x, 1 %conv = zext i16 %ct to i64 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 16 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 55. InstCombinePass ---------------------------------------- define i64 @test2c(i16 %x) { #0: %ct = cttz i16 %x, 1 %conv = zext i16 %ct to i64 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 16 ret i64 %cond } => define i64 @test2c(i16 %x) { #0: %ct = cttz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 %conv = zext nneg i16 %ct_range to i64 ret i64 %conv } Transformation seems to be correct! -- 56. PassManager<Function> : Skipping NOP -- 57. PassManager<Function> : Skipping NOP -- 58. InstCombinePass ---------------------------------------- define i64 @test3c(i32 %x) { #0: %ct = cttz i32 %x, 1 %conv = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 32 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 59. InstCombinePass ---------------------------------------- define i64 @test3c(i32 %x) { #0: %ct = cttz i32 %x, 1 %conv = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 32 ret i64 %cond } => define i64 @test3c(i32 %x) { #0: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %conv = zext nneg i32 %ct_range to i64 ret i64 %conv } Transformation seems to be correct! -- 60. PassManager<Function> : Skipping NOP -- 61. PassManager<Function> : Skipping NOP -- 62. InstCombinePass ---------------------------------------- define i32 @test4c(i16 %x) { #0: %ct = ctlz i16 %x, 1 %cast = zext i16 %ct to i32 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 16 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 63. InstCombinePass ---------------------------------------- define i32 @test4c(i16 %x) { #0: %ct = ctlz i16 %x, 1 %cast = zext i16 %ct to i32 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 16 ret i32 %cond } => define i32 @test4c(i16 %x) { #0: %ct = ctlz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 %cast = zext nneg i16 %ct_range to i32 ret i32 %cast } Transformation seems to be correct! -- 64. PassManager<Function> : Skipping NOP -- 65. PassManager<Function> : Skipping NOP -- 66. InstCombinePass ---------------------------------------- define i64 @test5c(i16 %x) { #0: %ct = ctlz i16 %x, 1 %cast = zext i16 %ct to i64 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i64 %cast, i64 16 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 67. InstCombinePass ---------------------------------------- define i64 @test5c(i16 %x) { #0: %ct = ctlz i16 %x, 1 %cast = zext i16 %ct to i64 %tobool = icmp ne i16 %x, 0 %cond = select i1 %tobool, i64 %cast, i64 16 ret i64 %cond } => define i64 @test5c(i16 %x) { #0: %ct = ctlz i16 %x, 0 %ct_range = !range i16 %ct, i16 0, i16 17 %cast = zext nneg i16 %ct_range to i64 ret i64 %cast } Transformation seems to be correct! -- 68. PassManager<Function> : Skipping NOP -- 69. PassManager<Function> : Skipping NOP -- 70. InstCombinePass ---------------------------------------- define i64 @test6c(i32 %x) { #0: %ct = ctlz i32 %x, 1 %cast = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %cast, i64 32 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 71. InstCombinePass ---------------------------------------- define i64 @test6c(i32 %x) { #0: %ct = ctlz i32 %x, 1 %cast = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %cast, i64 32 ret i64 %cond } => define i64 @test6c(i32 %x) { #0: %ct = ctlz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %cast = zext nneg i32 %ct_range to i64 ret i64 %cast } Transformation seems to be correct! -- 72. PassManager<Function> : Skipping NOP -- 73. PassManager<Function> : Skipping NOP -- 74. InstCombinePass ---------------------------------------- define i16 @test1d(i64 %x) { #0: %ct = cttz i64 %x, 1 %conv = trunc i64 %ct to i16 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i16 %conv, i16 64 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 75. InstCombinePass ---------------------------------------- define i16 @test1d(i64 %x) { #0: %ct = cttz i64 %x, 1 %conv = trunc i64 %ct to i16 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i16 %conv, i16 64 ret i16 %cond } => define i16 @test1d(i64 %x) { #0: %ct = cttz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %conv = trunc i64 %ct_range to i16 ret i16 %conv } Transformation seems to be correct! -- 76. PassManager<Function> : Skipping NOP -- 77. PassManager<Function> : Skipping NOP -- 78. InstCombinePass ---------------------------------------- define i32 @test2d(i64 %x) { #0: %ct = cttz i64 %x, 1 %cast = trunc i64 %ct to i32 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 64 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 79. InstCombinePass ---------------------------------------- define i32 @test2d(i64 %x) { #0: %ct = cttz i64 %x, 1 %cast = trunc i64 %ct to i32 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 64 ret i32 %cond } => define i32 @test2d(i64 %x) { #0: %ct = cttz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 ret i32 %cast } Transformation seems to be correct! -- 80. PassManager<Function> : Skipping NOP -- 81. PassManager<Function> : Skipping NOP -- 82. InstCombinePass ---------------------------------------- define i16 @test3d(i32 %x) { #0: %ct = cttz i32 %x, 1 %cast = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 32 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 83. InstCombinePass ---------------------------------------- define i16 @test3d(i32 %x) { #0: %ct = cttz i32 %x, 1 %cast = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 32 ret i16 %cond } => define i16 @test3d(i32 %x) { #0: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %cast = trunc i32 %ct_range to i16 ret i16 %cast } Transformation seems to be correct! -- 84. PassManager<Function> : Skipping NOP -- 85. PassManager<Function> : Skipping NOP -- 86. InstCombinePass ---------------------------------------- define i16 @test4d(i64 %x) { #0: %ct = ctlz i64 %x, 1 %cast = trunc i64 %ct to i16 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 64 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 87. InstCombinePass ---------------------------------------- define i16 @test4d(i64 %x) { #0: %ct = ctlz i64 %x, 1 %cast = trunc i64 %ct to i16 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 64 ret i16 %cond } => define i16 @test4d(i64 %x) { #0: %ct = ctlz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i16 ret i16 %cast } Transformation seems to be correct! -- 88. PassManager<Function> : Skipping NOP -- 89. PassManager<Function> : Skipping NOP -- 90. InstCombinePass ---------------------------------------- define i32 @test5d(i64 %x) { #0: %ct = ctlz i64 %x, 1 %cast = trunc i64 %ct to i32 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 64 ret i32 %cond } Transformation seems to be correct! (syntactically equal) -- 91. InstCombinePass ---------------------------------------- define i32 @test5d(i64 %x) { #0: %ct = ctlz i64 %x, 1 %cast = trunc i64 %ct to i32 %tobool = icmp ne i64 %x, 0 %cond = select i1 %tobool, i32 %cast, i32 64 ret i32 %cond } => define i32 @test5d(i64 %x) { #0: %ct = ctlz i64 %x, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 ret i32 %cast } Transformation seems to be correct! -- 92. PassManager<Function> : Skipping NOP -- 93. PassManager<Function> : Skipping NOP -- 94. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! (syntactically equal) -- 95. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } => define i32 @not_op_ctlz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = ctlz i64 %n, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 ret i32 %cast } Transformation seems to be correct! -- 96. PassManager<Function> : Skipping NOP -- 97. PassManager<Function> : Skipping NOP -- 98. InstCombinePass ---------------------------------------- define i32 @not_op_cttz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! (syntactically equal) -- 99. InstCombinePass ---------------------------------------- define i32 @not_op_cttz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } => define i32 @not_op_cttz(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 0 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 ret i32 %cast } Transformation seems to be correct! -- 100. PassManager<Function> : Skipping NOP -- 101. PassManager<Function> : Skipping NOP -- 102. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz_wrong_xor_op1(i64 %x) { #0: %n = xor i64 %x, -2 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! (syntactically equal) -- 103. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz_wrong_xor_op1(i64 %x) { #0: %n = xor i64 %x, -2 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } => define i32 @not_op_ctlz_wrong_xor_op1(i64 %x) { #0: %n = xor i64 %x, -2 %ct = ctlz i64 %n, 1 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! -- 104. PassManager<Function> : Skipping NOP -- 105. PassManager<Function> : Skipping NOP -- 106. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz_wrong_xor_op0(i64 %x, i64 %y) { #0: %n = xor i64 %y, -1 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! (syntactically equal) -- 107. InstCombinePass ---------------------------------------- define i32 @not_op_ctlz_wrong_xor_op0(i64 %x, i64 %y) { #0: %n = xor i64 %y, -1 %ct = ctlz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } => define i32 @not_op_ctlz_wrong_xor_op0(i64 %x, i64 %y) { #0: %n = xor i64 %y, -1 %ct = ctlz i64 %n, 1 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 %tobool = icmp eq i64 %x, -1 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! -- 108. PassManager<Function> : Skipping NOP -- 109. PassManager<Function> : Skipping NOP -- 110. InstCombinePass ---------------------------------------- define i32 @not_op_cttz_wrong_cmp(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, 0 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! (syntactically equal) -- 111. InstCombinePass ---------------------------------------- define i32 @not_op_cttz_wrong_cmp(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 1 %cast = trunc i64 %ct to i32 %tobool = icmp eq i64 %x, 0 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } => define i32 @not_op_cttz_wrong_cmp(i64 %x) { #0: %n = xor i64 %x, -1 %ct = cttz i64 %n, 1 %ct_range = !range i64 %ct, i64 0, i64 65 %cast = trunc i64 %ct_range to i32 %tobool = icmp eq i64 %x, 0 %r = select i1 %tobool, i32 64, i32 %cast ret i32 %r } Transformation seems to be correct! -- 112. PassManager<Function> : Skipping NOP -- 113. PassManager<Function> : Skipping NOP -- 114. InstCombinePass ---------------------------------------- define i16 @test6d(i32 %x) { #0: %ct = ctlz i32 %x, 1 %cast = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 32 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 115. InstCombinePass ---------------------------------------- define i16 @test6d(i32 %x) { #0: %ct = ctlz i32 %x, 1 %cast = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %cast, i16 32 ret i16 %cond } => define i16 @test6d(i32 %x) { #0: %ct = ctlz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %cast = trunc i32 %ct_range to i16 ret i16 %cast } Transformation seems to be correct! -- 116. PassManager<Function> : Skipping NOP -- 117. PassManager<Function> : Skipping NOP -- 118. InstCombinePass ---------------------------------------- define i64 @select_bug1(i32 %x) { #0: %ct = cttz i32 %x, 0 %conv = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 32 ret i64 %cond } Transformation seems to be correct! (syntactically equal) -- 119. InstCombinePass ---------------------------------------- define i64 @select_bug1(i32 %x) { #0: %ct = cttz i32 %x, 0 %conv = zext i32 %ct to i64 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i64 %conv, i64 32 ret i64 %cond } => define i64 @select_bug1(i32 %x) { #0: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %conv = zext nneg i32 %ct_range to i64 ret i64 %conv } Transformation seems to be correct! -- 120. PassManager<Function> : Skipping NOP -- 121. PassManager<Function> : Skipping NOP -- 122. InstCombinePass ---------------------------------------- define i16 @select_bug2(i32 %x) { #0: %ct = cttz i32 %x, 0 %conv = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %conv, i16 32 ret i16 %cond } Transformation seems to be correct! (syntactically equal) -- 123. InstCombinePass ---------------------------------------- define i16 @select_bug2(i32 %x) { #0: %ct = cttz i32 %x, 0 %conv = trunc i32 %ct to i16 %tobool = icmp ne i32 %x, 0 %cond = select i1 %tobool, i16 %conv, i16 32 ret i16 %cond } => define i16 @select_bug2(i32 %x) { #0: %ct = cttz i32 %x, 0 %ct_range = !range i32 %ct, i32 0, i32 33 %conv = trunc i32 %ct_range to i16 ret i16 %conv } Transformation seems to be correct! -- 124. PassManager<Function> : Skipping NOP -- 125. PassManager<Function> : Skipping NOP -- 126. InstCombinePass ---------------------------------------- define i128 @test7(i128 %x) { #0: %ct = ctlz i128 %x, 1 %tobool = icmp ne i128 %x, 0 %cond = select i1 %tobool, i128 %ct, i128 128 ret i128 %cond } Transformation seems to be correct! (syntactically equal) -- 127. InstCombinePass ---------------------------------------- define i128 @test7(i128 %x) { #0: %ct = ctlz i128 %x, 1 %tobool = icmp ne i128 %x, 0 %cond = select i1 %tobool, i128 %ct, i128 128 ret i128 %cond } => define i128 @test7(i128 %x) { #0: %ct = ctlz i128 %x, 0 %ct_range = !range i128 %ct, i128 0, i128 129 ret i128 %ct_range } Transformation seems to be correct! -- 128. PassManager<Function> : Skipping NOP -- 129. PassManager<Function> : Skipping NOP -- 130. InstCombinePass ---------------------------------------- define i128 @test8(i128 %x) { #0: %ct = cttz i128 %x, 1 %tobool = icmp ne i128 %x, 0 %cond = select i1 %tobool, i128 %ct, i128 128 ret i128 %cond } Transformation seems to be correct! (syntactically equal) -- 131. InstCombinePass ---------------------------------------- define i128 @test8(i128 %x) { #0: %ct = cttz i128 %x, 1 %tobool = icmp ne i128 %x, 0 %cond = select i1 %tobool, i128 %ct, i128 128 ret i128 %cond } => define i128 @test8(i128 %x) { #0: %ct = cttz i128 %x, 0 %ct_range = !range i128 %ct, i128 0, i128 129 ret i128 %ct_range } Transformation seems to be correct! -- 132. PassManager<Function> : Skipping NOP -- 133. PassManager<Function> : Skipping NOP -- 134. InstCombinePass ---------------------------------------- define i32 @test_ctlz_not_bw(i32 %x) { #0: %ct = ctlz i32 %x, 0 %cmp = icmp ne i32 %x, 0 %res = select i1 %cmp, i32 %ct, i32 123 ret i32 %res } Transformation seems to be correct! (syntactically equal) -- 135. InstCombinePass ---------------------------------------- define i32 @test_ctlz_not_bw(i32 %x) { #0: %ct = ctlz i32 %x, 0 %cmp = icmp ne i32 %x, 0 %res = select i1 %cmp, i32 %ct, i32 123 ret i32 %res } => define i32 @test_ctlz_not_bw(i32 %x) { #0: %ct = ctlz i32 %x, 1 %ct_range = !range i32 %ct, i32 0, i32 33 %cmp.not = icmp eq i32 %x, 0 %res = select i1 %cmp.not, i32 123, i32 %ct_range ret i32 %res } Transformation doesn't verify! (unsound) ERROR: Target is more poisonous than source Example: i32 %x = undef Source: i32 %ct = #x00000020 (32) [based on undef value] i1 %cmp = #x0 (0) [based on undef value] i32 %res = #x0000007b (123) Target: i32 %ct = poison i32 %ct_range = poison i1 %cmp.not = #x0 (0) i32 %res = poison Source value: #x0000007b (123) Target value: poison Pass: InstCombinePass 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=instcombine' '-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_Oov12Ee3_pGrE.bc" ------------------- SMT STATS ------------------- Num queries: 173 Num invalid: 0 Num skips: 0 Num trivial: 107 (38.2%) Num timeout: 0 (0.0%) Num errors: 0 (0.0%) Num SAT: 72 (41.6%) Num UNSAT: 101 (58.4%) Alive2: Transform doesn't verify; aborting!
RUN: at line 2: /home/nlopes/alive2/build/opt-alive.sh -passes=instcombine -S < /bitbucket/nlopes/llvm/llvm/test/Transforms/InstCombine/select-cmp-cttz-ctlz.ll | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstCombine/select-cmp-cttz-ctlz.ll + /home/nlopes/alive2/build/opt-alive.sh -passes=instcombine -S + /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstCombine/select-cmp-cttz-ctlz.ll FileCheck error: '<stdin>' is empty. FileCheck command line: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/InstCombine/select-cmp-cttz-ctlz.ll
NOTE: This test would pass if undef didn't exist!