Test source: git
Source: /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll -- 1. ModuleToFunctionPassAdaptor -- 1. PassManager<llvm::Function> : Skipping NOP -- 2. SandboxVectorizerPass ---------------------------------------- define void @store_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 3. SandboxVectorizerPass ---------------------------------------- define void @store_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 ret void } => define void @store_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %VecL = load <2 x float>, ptr %ptr0, align 4 store <2 x float> %VecL, ptr %ptr0, align 4 ret void } Transformation seems to be correct! -- 4. PassManager<llvm::Function> : Skipping NOP -- 5. PassManager<llvm::Function> : Skipping NOP -- 6. SandboxVectorizerPass ---------------------------------------- define void @store_fpext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ptrd0 = gep ptr %ptr, 8 x i32 0 %ptrd1 = gep ptr %ptr, 8 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 %fpext0 = fpext float %ld0 to double %fpext1 = fpext float %ld1 to double store double %fpext0, ptr %ptrd0, align 8 store double %fpext1, ptr %ptrd1, align 8 ret void } Transformation seems to be correct! (syntactically equal) -- 7. SandboxVectorizerPass ---------------------------------------- define void @store_fpext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ptrd0 = gep ptr %ptr, 8 x i32 0 %ptrd1 = gep ptr %ptr, 8 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 %fpext0 = fpext float %ld0 to double %fpext1 = fpext float %ld1 to double store double %fpext0, ptr %ptrd0, align 8 store double %fpext1, ptr %ptrd1, align 8 ret void } => define void @store_fpext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptrd0 = gep ptr %ptr, 8 x i32 0 %VecL = load <2 x float>, ptr %ptr0, align 4 %VCast = fpext <2 x float> %VecL to <2 x double> store <2 x double> %VCast, ptr %ptrd0, align 8 ret void } Transformation doesn't verify! (not unsound) ERROR: Timeout -- 8. PassManager<llvm::Function> : Skipping NOP -- 9. PassManager<llvm::Function> : Skipping NOP -- 10. SandboxVectorizerPass ---------------------------------------- define void @store_fcmp_zext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ptrb0 = gep ptr %ptr, 4 x i32 0 %ptrb1 = gep ptr %ptr, 4 x i32 1 %ldB0 = load float, ptr %ptr0, align 4 %ldB1 = load float, ptr %ptr1, align 4 %ldA0 = load float, ptr %ptr0, align 4 %ldA1 = load float, ptr %ptr1, align 4 %fcmp0 = fcmp ogt float %ldA0, %ldB0 %fcmp1 = fcmp ogt float %ldA1, %ldB1 %zext0 = zext i1 %fcmp0 to i32 %zext1 = zext i1 %fcmp1 to i32 store i32 %zext0, ptr %ptrb0, align 4 store i32 %zext1, ptr %ptrb1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 11. SandboxVectorizerPass ---------------------------------------- define void @store_fcmp_zext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ptrb0 = gep ptr %ptr, 4 x i32 0 %ptrb1 = gep ptr %ptr, 4 x i32 1 %ldB0 = load float, ptr %ptr0, align 4 %ldB1 = load float, ptr %ptr1, align 4 %ldA0 = load float, ptr %ptr0, align 4 %ldA1 = load float, ptr %ptr1, align 4 %fcmp0 = fcmp ogt float %ldA0, %ldB0 %fcmp1 = fcmp ogt float %ldA1, %ldB1 %zext0 = zext i1 %fcmp0 to i32 %zext1 = zext i1 %fcmp1 to i32 store i32 %zext0, ptr %ptrb0, align 4 store i32 %zext1, ptr %ptrb1, align 4 ret void } => define void @store_fcmp_zext_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptrb0 = gep ptr %ptr, 4 x i32 0 %VecL1 = load <2 x float>, ptr %ptr0, align 4 %VecL = load <2 x float>, ptr %ptr0, align 4 %VCmp = fcmp ogt <2 x float> %VecL, %VecL1 %VCast = zext <2 x i1> %VCmp to <2 x i32> store <2 x i32> %VCast, ptr %ptrb0, align 4 ret void } Transformation seems to be correct! -- 12. PassManager<llvm::Function> : Skipping NOP -- 13. PassManager<llvm::Function> : Skipping NOP -- 14. SandboxVectorizerPass ---------------------------------------- define void @store_fadd_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ldA0 = load float, ptr %ptr0, align 4 %ldA1 = load float, ptr %ptr1, align 4 %ldB0 = load float, ptr %ptr0, align 4 %ldB1 = load float, ptr %ptr1, align 4 %fadd0 = fadd float %ldA0, %ldB0 %fadd1 = fadd float %ldA1, %ldB1 store float %fadd0, ptr %ptr0, align 4 store float %fadd1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 15. SandboxVectorizerPass ---------------------------------------- define void @store_fadd_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ldA0 = load float, ptr %ptr0, align 4 %ldA1 = load float, ptr %ptr1, align 4 %ldB0 = load float, ptr %ptr0, align 4 %ldB1 = load float, ptr %ptr1, align 4 %fadd0 = fadd float %ldA0, %ldB0 %fadd1 = fadd float %ldA1, %ldB1 store float %fadd0, ptr %ptr0, align 4 store float %fadd1, ptr %ptr1, align 4 ret void } => define void @store_fadd_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %VecL = load <2 x float>, ptr %ptr0, align 4 %VecL1 = load <2 x float>, ptr %ptr0, align 4 %Vec = fadd <2 x float> %VecL, %VecL1 store <2 x float> %Vec, ptr %ptr0, align 4 ret void } Transformation doesn't verify! (not unsound) ERROR: Timeout -- 16. PassManager<llvm::Function> : Skipping NOP -- 17. PassManager<llvm::Function> : Skipping NOP -- 18. SandboxVectorizerPass ---------------------------------------- define void @store_fneg_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 %fneg0 = fneg float %ld0 %fneg1 = fneg float %ld1 store float %fneg0, ptr %ptr0, align 4 store float %fneg1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 19. SandboxVectorizerPass ---------------------------------------- define void @store_fneg_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 %fneg0 = fneg float %ld0 %fneg1 = fneg float %ld1 store float %fneg0, ptr %ptr0, align 4 store float %fneg1, ptr %ptr1, align 4 ret void } => define void @store_fneg_load(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %VecL = load <2 x float>, ptr %ptr0, align 4 %Vec = fneg <2 x float> %VecL store <2 x float> %Vec, ptr %ptr0, align 4 ret void } Transformation seems to be correct! -- 20. PassManager<llvm::Function> : Skipping NOP -- 21. PassManager<llvm::Function> : Skipping NOP -- 22. SandboxVectorizerPass ---------------------------------------- define float @scalars_with_external_uses_not_dead(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 %user = fneg float %ld1 ret float %ld0 } Transformation seems to be correct! (syntactically equal) -- 23. SandboxVectorizerPass ---------------------------------------- define float @scalars_with_external_uses_not_dead(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 ret float %ld0 } => define float @scalars_with_external_uses_not_dead(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 %VecL = load <2 x float>, ptr %ptr0, align 4 store <2 x float> %VecL, ptr %ptr0, align 4 ret float %ld0 } Transformation seems to be correct! -- 24. PassManager<llvm::Function> : Skipping NOP -- 25. PassManager<llvm::Function> : Skipping NOP -- 26. SandboxVectorizerPass ---------------------------------------- define void @pack_scalars(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr2, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 27. SandboxVectorizerPass ---------------------------------------- define void @pack_scalars(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr2, align 4 store float %ld0, ptr %ptr0, align 4 store float %ld1, ptr %ptr1, align 4 ret void } => define void @pack_scalars(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr2, align 4 %Pack = insertelement <2 x float> poison, float %ld0, i32 0 %Pack1 = insertelement <2 x float> %Pack, float %ld1, i32 1 store <2 x float> %Pack1, ptr %ptr0, align 4 ret void } Transformation seems to be correct! -- 28. PassManager<llvm::Function> : Skipping NOP -- 29. PassManager<llvm::Function> : Skipping NOP -- 30. SandboxVectorizerPass ---------------------------------------- declare void @foo() define void @cant_vectorize_seeds(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld1, ptr %ptr1, align 4 call void @foo() store float %ld1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 31. SandboxVectorizerPass ---------------------------------------- declare void @foo() define void @cant_vectorize_seeds(ptr %ptr) { #0: %ptr0 = gep ptr %ptr, 4 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 1 %ld0 = load float, ptr %ptr0, align 4 %ld1 = load float, ptr %ptr1, align 4 store float %ld1, ptr %ptr1, align 4 call void @foo() store float %ld1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 32. PassManager<llvm::Function> : Skipping NOP -- 33. PassManager<llvm::Function> : Skipping NOP -- 34. SandboxVectorizerPass ---------------------------------------- define void @pack_vectors(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 8 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 2 %ld0 = load <2 x float>, ptr %ptr0, align 8 %ld1 = load float, ptr %ptr2, align 4 store <2 x float> %ld0, ptr %ptr0, align 8 store float %ld1, ptr %ptr1, align 4 ret void } Transformation seems to be correct! (syntactically equal) -- 35. SandboxVectorizerPass ---------------------------------------- define void @pack_vectors(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 8 x i32 0 %ptr1 = gep ptr %ptr, 4 x i32 2 %ld0 = load <2 x float>, ptr %ptr0, align 8 %ld1 = load float, ptr %ptr2, align 4 store <2 x float> %ld0, ptr %ptr0, align 8 store float %ld1, ptr %ptr1, align 4 ret void } => define void @pack_vectors(ptr %ptr, ptr %ptr2) { #0: %ptr0 = gep ptr %ptr, 8 x i32 0 %ld0 = load <2 x float>, ptr %ptr0, align 8 %ld1 = load float, ptr %ptr2, align 4 %VPack = extractelement <2 x float> %ld0, i32 0 %VPack1 = insertelement <3 x float> poison, float %VPack, i32 0 %VPack2 = extractelement <2 x float> %ld0, i32 1 %VPack3 = insertelement <3 x float> %VPack1, float %VPack2, i32 1 %Pack = insertelement <3 x float> %VPack3, float %ld1, i32 2 store <3 x float> %Pack, ptr %ptr0, align 8 ret void } Transformation doesn't verify! (unsound) ERROR: Source is more defined than target Example: ptr %ptr = pointer(non-local, block_id=1, offset=0) / Address=#x08 ptr %ptr2 = pointer(non-local, block_id=1, offset=0) / Address=#x08 Source: ptr %ptr0 = pointer(non-local, block_id=1, offset=0) / Address=#x08 ptr %ptr1 = pointer(non-local, block_id=1, offset=8) / Address=#x10 <2 x float> %ld0 = < poison, poison > float %ld1 = poison SOURCE MEMORY STATE =================== NON-LOCAL BLOCKS: Block 0 > size: 0 align: 4 alloc type: 0 alive: false address: 0 Block 1 > size: 12 align: 1 alloc type: 0 alive: true address: 8 Block 2 > size: 0 align: 2 alloc type: 0 alive: true address: 8 Target: ptr %ptr0 = pointer(non-local, block_id=1, offset=0) / Address=#x08 <2 x float> %ld0 = < poison, poison > float %ld1 = poison float %VPack = poison <3 x float> %VPack1 = < poison, poison, poison > float %VPack2 = poison <3 x float> %VPack3 = < poison, poison, poison > <3 x float> %Pack = < poison, poison, poison > void = UB triggered! Pass: SandboxVectorizerPass 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=sandbox-vectorizer' '-sbvec-passes=bottom-up-vec<>' '/bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll' '-S' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats' Wrote bitcode to: "/home/nlopes/alive2/build/logs/bottomup_basic_tT1u8rlc_Ojdr.bc" ------------------- SMT STATS ------------------- Num queries: 72 Num invalid: 0 Num skips: 0 Num trivial: 31 (30.1%) Num timeout: 2 (2.8%) Num errors: 0 (0.0%) Num SAT: 45 (62.5%) Num UNSAT: 25 (34.7%) Alive2: Transform doesn't verify; aborting!
RUN: at line 2: /home/nlopes/alive2/build/opt-alive.sh -passes=sandbox-vectorizer -sbvec-passes="bottom-up-vec<>" /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll -S | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll + /home/nlopes/alive2/build/opt-alive.sh -passes=sandbox-vectorizer '-sbvec-passes=bottom-up-vec<>' /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll -S + /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll FileCheck error: '<stdin>' is empty. FileCheck command line: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SandboxVectorizer/bottomup_basic.ll