loop5.ref 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. define void @main() {
  2. entry:
  3. %0 = call i32 @dx.op.loadInput.i32(i32 4, i32 1, i32 0, i8 2, i32 undef)
  4. %1 = call float @dx.op.bitcastI32toF32(i32 126, i32 0)
  5. br label %loop0
  6. loop0: ; preds = %if0.end, %entry
  7. %dx.v32.r1.0 = phi float [ %1, %entry ], [ %7, %if0.end ]
  8. %dx.v32.r2.0 = phi i32 [ 0, %entry ], [ %8, %if0.end ]
  9. %2 = call i32 @dx.op.loadInput.i32(i32 4, i32 1, i32 0, i8 0, i32 undef)
  10. %3 = icmp sge i32 %dx.v32.r2.0, %2
  11. br i1 %3, label %loop0.end, label %loop0.breakc0
  12. loop0.breakc0: ; preds = %loop0
  13. %4 = icmp eq i32 %0, 5
  14. call void @dx.op.storeOutput.f32(i32 5, i32 0, i32 0, i8 0, float %dx.v32.r1.0)
  15. br i1 %4, label %label0.callc0.retc0, label %label0.callc0.afterretc0
  16. label0.callc0.retc0: ; preds = %loop0.breakc0
  17. ret void
  18. label0.callc0.afterretc0: ; preds = %loop0.breakc0
  19. %5 = icmp eq i32 %0, 7
  20. br i1 %5, label %if0.then, label %if0.end
  21. if0.then: ; preds = %label0.callc0.afterretc0
  22. call void @dx.op.storeOutput.f32(i32 5, i32 0, i32 0, i8 0, float %dx.v32.r1.0)
  23. ret void
  24. if0.end: ; preds = %label0.callc0.afterretc0
  25. %6 = call float @dx.op.loadInput.f32(i32 4, i32 0, i32 0, i8 0, i32 undef)
  26. %7 = fadd fast float %dx.v32.r1.0, %6
  27. %8 = add i32 %dx.v32.r2.0, 1
  28. br label %loop0
  29. loop0.end: ; preds = %loop0
  30. call void @dx.op.storeOutput.f32(i32 5, i32 0, i32 0, i8 0, float %dx.v32.r1.0)
  31. ret void
  32. }
  33. ; Function Attrs: nounwind readnone
  34. declare i32 @dx.op.loadInput.i32(i32, i32, i32, i8, i32) #0
  35. ; Function Attrs: nounwind
  36. declare void @dx.op.tempRegStore.i32(i32, i32, i32) #1
  37. ; Function Attrs: nounwind readonly
  38. declare i32 @dx.op.tempRegLoad.i32(i32, i32) #2
  39. ; Function Attrs: nounwind readonly
  40. declare float @dx.op.tempRegLoad.f32(i32, i32) #2
  41. ; Function Attrs: nounwind
  42. declare void @dx.op.storeOutput.f32(i32, i32, i32, i8, float) #1
  43. ; Function Attrs: nounwind readnone
  44. declare float @dx.op.loadInput.f32(i32, i32, i32, i8, i32) #0
  45. ; Function Attrs: nounwind
  46. declare void @dx.op.tempRegStore.f32(i32, i32, float) #1
  47. ; Function Attrs: nounwind readnone
  48. declare float @dx.op.bitcastI32toF32(i32, i32) #0
  49. attributes #0 = { nounwind readnone }
  50. attributes #1 = { nounwind }
  51. attributes #2 = { nounwind readonly }
  52. !dx.version = !{!0}
  53. !dx.valver = !{!0}
  54. !dx.shaderModel = !{!1}
  55. !dx.entryPoints = !{!2}
  56. !llvm.ident = !{!11}
  57. !0 = !{i32 1, i32 0}
  58. !1 = !{!"ps", i32 6, i32 0}
  59. !2 = !{void ()* @main, !"main", !3, null, !10}
  60. !3 = !{!4, !8, null}
  61. !4 = !{!5, !7}
  62. !5 = !{i32 0, !"A", i8 9, i8 0, !6, i8 2, i32 1, i8 2, i32 0, i8 0, null}
  63. !6 = !{i32 0}
  64. !7 = !{i32 1, !"B", i8 4, i8 0, !6, i8 1, i32 1, i8 3, i32 1, i8 0, null}
  65. !8 = !{!9}
  66. !9 = !{i32 0, !"SV_Target", i8 9, i8 16, !6, i8 0, i32 1, i8 1, i32 0, i8 0, null}
  67. !10 = !{i32 0, i64 256}
  68. !11 = !{!"dxbc2dxil 1.2"}