indexableinput2.ref 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. define void @main() {
  2. entry:
  3. %0 = call i32 @dx.op.sampleIndex.i32(i32 90)
  4. %1 = sub i32 %0, 0
  5. %2 = call float @dx.op.loadInput.f32(i32 4, i32 0, i32 %1, i8 0, i32 undef)
  6. %3 = call float @dx.op.loadInput.f32(i32 4, i32 0, i32 2, i8 1, i32 undef)
  7. %4 = fadd fast float %2, %3
  8. %5 = call i32 @dx.op.loadInput.i32(i32 4, i32 3, i32 0, i8 0, i32 undef)
  9. %6 = add i32 %5, 3
  10. %7 = sub i32 %6, 3
  11. %8 = call float @dx.op.loadInput.f32(i32 4, i32 2, i32 %7, i8 0, i32 undef)
  12. %9 = fadd fast float %4, %8
  13. call void @dx.op.storeOutput.f32(i32 5, i32 0, i32 0, i8 0, float %9)
  14. ret void
  15. }
  16. ; Function Attrs: nounwind readnone
  17. declare i32 @dx.op.sampleIndex.i32(i32) #0
  18. ; Function Attrs: nounwind
  19. declare void @dx.op.tempRegStore.i32(i32, i32, i32) #1
  20. ; Function Attrs: nounwind readonly
  21. declare i32 @dx.op.tempRegLoad.i32(i32, i32) #2
  22. ; Function Attrs: nounwind readnone
  23. declare float @dx.op.loadInput.f32(i32, i32, i32, i8, i32) #0
  24. ; Function Attrs: nounwind
  25. declare void @dx.op.tempRegStore.f32(i32, i32, float) #1
  26. ; Function Attrs: nounwind readnone
  27. declare i32 @dx.op.loadInput.i32(i32, i32, i32, i8, i32) #0
  28. ; Function Attrs: nounwind readonly
  29. declare float @dx.op.tempRegLoad.f32(i32, i32) #2
  30. ; Function Attrs: nounwind
  31. declare void @dx.op.storeOutput.f32(i32, i32, i32, i8, float) #1
  32. ; Function Attrs: nounwind readnone
  33. declare float @dx.op.bitcastI32toF32(i32, i32) #0
  34. ; Function Attrs: nounwind readnone
  35. declare i32 @dx.op.bitcastF32toI32(i32, float) #0
  36. attributes #0 = { nounwind readnone }
  37. attributes #1 = { nounwind }
  38. attributes #2 = { nounwind readonly }
  39. !dx.version = !{!0}
  40. !dx.valver = !{!0}
  41. !dx.shaderModel = !{!1}
  42. !dx.entryPoints = !{!2}
  43. !llvm.ident = !{!16}
  44. !0 = !{i32 1, i32 0}
  45. !1 = !{!"ps", i32 6, i32 0}
  46. !2 = !{void ()* @main, !"main", !3, null, !15}
  47. !3 = !{!4, !13, null}
  48. !4 = !{!5, !7, !9, !11, !12}
  49. !5 = !{i32 0, !"A", i8 9, i8 0, !6, i8 2, i32 3, i8 2, i32 0, i8 0, null}
  50. !6 = !{i32 0, i32 1, i32 2}
  51. !7 = !{i32 1, !"B", i8 9, i8 0, !8, i8 0, i32 1, i8 2, i32 0, i8 2, null}
  52. !8 = !{i32 0}
  53. !9 = !{i32 2, !"C", i8 9, i8 0, !10, i8 2, i32 6, i8 2, i32 3, i8 0, null}
  54. !10 = !{i32 0, i32 1, i32 2, i32 3, i32 4, i32 5}
  55. !11 = !{i32 3, !"D", i8 4, i8 0, !8, i8 1, i32 1, i8 1, i32 9, i8 0, null}
  56. !12 = !{i32 4, !"SV_SampleIndex", i8 5, i8 12, !8, i8 1, i32 1, i8 1, i32 -1, i8 -1, null}
  57. !13 = !{!14}
  58. !14 = !{i32 0, !"SV_Target", i8 9, i8 16, !8, i8 0, i32 1, i8 1, i32 0, i8 0, null}
  59. !15 = !{i32 0, i64 256}
  60. !16 = !{!"dxbc2dxil 1.2"}