value_formation.carbon 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. //
  5. // AUTOUPDATE
  6. fn G(ab: ((i32, i32, i32), (i32, i32, i32)));
  7. fn F() {
  8. var a: (i32, i32, i32);
  9. var b: (i32, i32, i32);
  10. G((a, b));
  11. }
  12. // CHECK:STDOUT: ; ModuleID = 'value_formation.carbon'
  13. // CHECK:STDOUT: source_filename = "value_formation.carbon"
  14. // CHECK:STDOUT:
  15. // CHECK:STDOUT: declare void @G(ptr)
  16. // CHECK:STDOUT:
  17. // CHECK:STDOUT: define void @F() {
  18. // CHECK:STDOUT: %a = alloca { i32, i32, i32 }, align 8
  19. // CHECK:STDOUT: %b = alloca { i32, i32, i32 }, align 8
  20. // CHECK:STDOUT: %tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a, i32 0, i32 0
  21. // CHECK:STDOUT: %1 = load i32, ptr %tuple.elem, align 4
  22. // CHECK:STDOUT: %tuple.elem1 = getelementptr inbounds { i32, i32, i32 }, ptr %a, i32 0, i32 1
  23. // CHECK:STDOUT: %2 = load i32, ptr %tuple.elem1, align 4
  24. // CHECK:STDOUT: %tuple.elem2 = getelementptr inbounds { i32, i32, i32 }, ptr %a, i32 0, i32 2
  25. // CHECK:STDOUT: %3 = load i32, ptr %tuple.elem2, align 4
  26. // CHECK:STDOUT: %tuple = alloca { i32, i32, i32 }, align 8
  27. // CHECK:STDOUT: %4 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple, i32 0, i32 0
  28. // CHECK:STDOUT: store i32 %1, ptr %4, align 4
  29. // CHECK:STDOUT: %5 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple, i32 0, i32 1
  30. // CHECK:STDOUT: store i32 %2, ptr %5, align 4
  31. // CHECK:STDOUT: %6 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple, i32 0, i32 2
  32. // CHECK:STDOUT: store i32 %3, ptr %6, align 4
  33. // CHECK:STDOUT: %tuple.elem3 = getelementptr inbounds { i32, i32, i32 }, ptr %b, i32 0, i32 0
  34. // CHECK:STDOUT: %7 = load i32, ptr %tuple.elem3, align 4
  35. // CHECK:STDOUT: %tuple.elem4 = getelementptr inbounds { i32, i32, i32 }, ptr %b, i32 0, i32 1
  36. // CHECK:STDOUT: %8 = load i32, ptr %tuple.elem4, align 4
  37. // CHECK:STDOUT: %tuple.elem5 = getelementptr inbounds { i32, i32, i32 }, ptr %b, i32 0, i32 2
  38. // CHECK:STDOUT: %9 = load i32, ptr %tuple.elem5, align 4
  39. // CHECK:STDOUT: %tuple6 = alloca { i32, i32, i32 }, align 8
  40. // CHECK:STDOUT: %10 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple6, i32 0, i32 0
  41. // CHECK:STDOUT: store i32 %7, ptr %10, align 4
  42. // CHECK:STDOUT: %11 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple6, i32 0, i32 1
  43. // CHECK:STDOUT: store i32 %8, ptr %11, align 4
  44. // CHECK:STDOUT: %12 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple6, i32 0, i32 2
  45. // CHECK:STDOUT: store i32 %9, ptr %12, align 4
  46. // CHECK:STDOUT: %tuple7 = alloca { ptr, ptr }, align 8
  47. // CHECK:STDOUT: %13 = getelementptr inbounds { ptr, ptr }, ptr %tuple7, i32 0, i32 0
  48. // CHECK:STDOUT: store ptr %tuple, ptr %13, align 8
  49. // CHECK:STDOUT: %14 = getelementptr inbounds { ptr, ptr }, ptr %tuple7, i32 0, i32 1
  50. // CHECK:STDOUT: store ptr %tuple6, ptr %14, align 8
  51. // CHECK:STDOUT: call void @G(ptr %tuple7)
  52. // CHECK:STDOUT: ret void
  53. // CHECK:STDOUT: }