double4.ref 3.8 KB

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