double3.ref 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. %dx.types.splitdouble = type { i32, i32 }
  2. define void @main() {
  3. entry:
  4. %0 = call i32 @dx.op.loadInput.i32(i32 4, i32 0, i32 0, i8 0, i32 undef)
  5. %1 = call i32 @dx.op.loadInput.i32(i32 4, i32 0, i32 0, i8 1, i32 undef)
  6. %2 = call i32 @dx.op.loadInput.i32(i32 4, i32 1, i32 0, i8 0, i32 undef)
  7. %3 = call i32 @dx.op.loadInput.i32(i32 4, i32 1, i32 0, i8 1, i32 undef)
  8. %4 = call double @dx.op.makeDouble.f64(i32 101, i32 %2, i32 %3)
  9. %5 = call double @dx.op.makeDouble.f64(i32 101, i32 %0, i32 %1)
  10. %6 = fcmp fast oeq double %4, %5
  11. %7 = sext i1 %6 to i32
  12. %8 = call i32 @dx.op.loadInput.i32(i32 4, i32 2, i32 0, i8 0, i32 undef)
  13. %9 = call i32 @dx.op.loadInput.i32(i32 4, i32 2, i32 0, i8 1, i32 undef)
  14. %10 = call double @dx.op.makeDouble.f64(i32 101, i32 %0, i32 %1)
  15. %11 = call double @dx.op.makeDouble.f64(i32 101, i32 %8, i32 %9)
  16. %12 = fcmp fast une double %10, %11
  17. %13 = sext i1 %12 to i32
  18. %14 = and i32 %13, %7
  19. %15 = call double @dx.op.makeDouble.f64(i32 101, i32 %2, i32 %3)
  20. %16 = call double @dx.op.makeDouble.f64(i32 101, i32 %8, i32 %9)
  21. %17 = fcmp fast olt double %15, %16
  22. %18 = sext i1 %17 to i32
  23. %19 = call double @dx.op.makeDouble.f64(i32 101, i32 %2, i32 %3)
  24. %20 = call double @dx.op.makeDouble.f64(i32 101, i32 %8, i32 %9)
  25. %21 = fmul fast double %19, %20
  26. %22 = call double @dx.op.makeDouble.f64(i32 101, i32 %0, i32 %1)
  27. %23 = fadd fast double %21, %22
  28. %24 = call double @dx.op.makeDouble.f64(i32 101, i32 %0, i32 %1)
  29. %25 = fcmp fast olt double %24, %23
  30. %26 = sext i1 %25 to i32
  31. %27 = and i32 %18, %14
  32. %28 = and i32 %26, %27
  33. call void @dx.op.storeOutput.i32(i32 5, i32 0, i32 0, i8 0, i32 %28)
  34. ret void
  35. }
  36. ; Function Attrs: nounwind readnone
  37. declare i32 @dx.op.loadInput.i32(i32, i32, i32, i8, i32) #0
  38. ; Function Attrs: nounwind
  39. declare void @dx.op.tempRegStore.i32(i32, i32, i32) #1
  40. ; Function Attrs: nounwind readonly
  41. declare i32 @dx.op.tempRegLoad.i32(i32, i32) #2
  42. ; Function Attrs: nounwind readnone
  43. declare double @dx.op.makeDouble.f64(i32, i32, i32) #0
  44. ; Function Attrs: nounwind readnone
  45. declare %dx.types.splitdouble @dx.op.splitDouble.f64(i32, double) #0
  46. ; Function Attrs: nounwind
  47. declare void @dx.op.storeOutput.i32(i32, i32, i32, i8, i32) #1
  48. attributes #0 = { nounwind readnone }
  49. attributes #1 = { nounwind }
  50. attributes #2 = { nounwind readonly }
  51. !dx.version = !{!0}
  52. !dx.valver = !{!0}
  53. !dx.shaderModel = !{!1}
  54. !dx.entryPoints = !{!2}
  55. !llvm.ident = !{!12}
  56. !0 = !{i32 1, i32 0}
  57. !1 = !{!"ps", i32 6, i32 0}
  58. !2 = !{void ()* @main, !"main", !3, null, !11}
  59. !3 = !{!4, !9, null}
  60. !4 = !{!5, !7, !8}
  61. !5 = !{i32 0, !"AAA", i8 5, i8 0, !6, i8 1, i32 1, i8 2, i32 0, i8 0, null}
  62. !6 = !{i32 0}
  63. !7 = !{i32 1, !"BBB", i8 5, i8 0, !6, i8 1, i32 1, i8 2, i32 0, i8 2, null}
  64. !8 = !{i32 2, !"CCC", i8 5, i8 0, !6, i8 1, i32 1, i8 2, i32 1, i8 0, null}
  65. !9 = !{!10}
  66. !10 = !{i32 0, !"SV_Target", i8 5, i8 16, !6, i8 0, i32 1, i8 1, i32 0, i8 0, null}
  67. !11 = !{i32 0, i64 260}
  68. !12 = !{!"dxbc2dxil 1.2"}