tuple.carbon 5.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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 F() -> i32 {
  7. var a: (i32, i32, i32) = (1, 2, 3);
  8. var b: (i32, i32) = (4, 5);
  9. let c: ((i32, i32, i32), (i32, i32)) = (a, b);
  10. return c[1][1];
  11. }
  12. // CHECK:STDOUT: ; ModuleID = 'tuple.carbon'
  13. // CHECK:STDOUT: source_filename = "tuple.carbon"
  14. // CHECK:STDOUT:
  15. // CHECK:STDOUT: @tuple.1.loc8_37 = internal constant { i32, i32, i32 } { i32 1, i32 2, i32 3 }
  16. // CHECK:STDOUT: @tuple.2.loc9_29 = internal constant { i32, i32 } { i32 4, i32 5 }
  17. // CHECK:STDOUT:
  18. // CHECK:STDOUT: define i32 @F() {
  19. // CHECK:STDOUT: entry:
  20. // CHECK:STDOUT: %a.var = alloca { i32, i32, i32 }, align 8
  21. // CHECK:STDOUT: %.loc8_36.2.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 0
  22. // CHECK:STDOUT: %.loc8_36.4.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 1
  23. // CHECK:STDOUT: %.loc8_36.6.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 2
  24. // CHECK:STDOUT: call void @llvm.memcpy.p0.p0.i64(ptr align 4 %a.var, ptr align 4 @tuple.1.loc8_37, i64 12, i1 false)
  25. // CHECK:STDOUT: %b.var = alloca { i32, i32 }, align 8
  26. // CHECK:STDOUT: %.loc9_28.2.tuple.elem = getelementptr inbounds { i32, i32 }, ptr %b.var, i32 0, i32 0
  27. // CHECK:STDOUT: %.loc9_28.4.tuple.elem = getelementptr inbounds { i32, i32 }, ptr %b.var, i32 0, i32 1
  28. // CHECK:STDOUT: call void @llvm.memcpy.p0.p0.i64(ptr align 4 %b.var, ptr align 4 @tuple.2.loc9_29, i64 8, i1 false)
  29. // CHECK:STDOUT: %.loc10_43.1.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 0
  30. // CHECK:STDOUT: %.loc10_43.2 = load i32, ptr %.loc10_43.1.tuple.elem, align 4
  31. // CHECK:STDOUT: %.loc10_43.3.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 1
  32. // CHECK:STDOUT: %.loc10_43.4 = load i32, ptr %.loc10_43.3.tuple.elem, align 4
  33. // CHECK:STDOUT: %.loc10_43.5.tuple.elem = getelementptr inbounds { i32, i32, i32 }, ptr %a.var, i32 0, i32 2
  34. // CHECK:STDOUT: %.loc10_43.6 = load i32, ptr %.loc10_43.5.tuple.elem, align 4
  35. // CHECK:STDOUT: %tuple.loc10_43 = alloca { i32, i32, i32 }, align 8
  36. // CHECK:STDOUT: %tuple.loc10_431 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple.loc10_43, i32 0, i32 0
  37. // CHECK:STDOUT: store i32 %.loc10_43.2, ptr %tuple.loc10_431, align 4
  38. // CHECK:STDOUT: %tuple.loc10_432 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple.loc10_43, i32 0, i32 1
  39. // CHECK:STDOUT: store i32 %.loc10_43.4, ptr %tuple.loc10_432, align 4
  40. // CHECK:STDOUT: %tuple.loc10_433 = getelementptr inbounds { i32, i32, i32 }, ptr %tuple.loc10_43, i32 0, i32 2
  41. // CHECK:STDOUT: store i32 %.loc10_43.6, ptr %tuple.loc10_433, align 4
  42. // CHECK:STDOUT: %.loc10_46.1.tuple.elem = getelementptr inbounds { i32, i32 }, ptr %b.var, i32 0, i32 0
  43. // CHECK:STDOUT: %.loc10_46.2 = load i32, ptr %.loc10_46.1.tuple.elem, align 4
  44. // CHECK:STDOUT: %.loc10_46.3.tuple.elem = getelementptr inbounds { i32, i32 }, ptr %b.var, i32 0, i32 1
  45. // CHECK:STDOUT: %.loc10_46.4 = load i32, ptr %.loc10_46.3.tuple.elem, align 4
  46. // CHECK:STDOUT: %tuple.loc10_46 = alloca { i32, i32 }, align 8
  47. // CHECK:STDOUT: %tuple.loc10_464 = getelementptr inbounds { i32, i32 }, ptr %tuple.loc10_46, i32 0, i32 0
  48. // CHECK:STDOUT: store i32 %.loc10_46.2, ptr %tuple.loc10_464, align 4
  49. // CHECK:STDOUT: %tuple.loc10_465 = getelementptr inbounds { i32, i32 }, ptr %tuple.loc10_46, i32 0, i32 1
  50. // CHECK:STDOUT: store i32 %.loc10_46.4, ptr %tuple.loc10_465, align 4
  51. // CHECK:STDOUT: %tuple.loc10_47 = alloca { ptr, ptr }, align 8
  52. // CHECK:STDOUT: %tuple.loc10_476 = getelementptr inbounds { ptr, ptr }, ptr %tuple.loc10_47, i32 0, i32 0
  53. // CHECK:STDOUT: store ptr %tuple.loc10_43, ptr %tuple.loc10_476, align 8
  54. // CHECK:STDOUT: %tuple.loc10_477 = getelementptr inbounds { ptr, ptr }, ptr %tuple.loc10_47, i32 0, i32 1
  55. // CHECK:STDOUT: store ptr %tuple.loc10_46, ptr %tuple.loc10_477, align 8
  56. // CHECK:STDOUT: %.loc11_13.tuple.index = getelementptr inbounds { ptr, ptr }, ptr %tuple.loc10_47, i32 0, i32 1
  57. // CHECK:STDOUT: %.loc11_13.tuple.index.load = load ptr, ptr %.loc11_13.tuple.index, align 8
  58. // CHECK:STDOUT: %.loc11_16.tuple.index = getelementptr inbounds { i32, i32 }, ptr %.loc11_13.tuple.index.load, i32 0, i32 1
  59. // CHECK:STDOUT: %.loc11_16.tuple.index.load = load i32, ptr %.loc11_16.tuple.index, align 4
  60. // CHECK:STDOUT: ret i32 %.loc11_16.tuple.index.load
  61. // CHECK:STDOUT: }
  62. // CHECK:STDOUT:
  63. // CHECK:STDOUT: ; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: readwrite)
  64. // CHECK:STDOUT: declare void @llvm.memcpy.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64, i1 immarg) #0
  65. // CHECK:STDOUT:
  66. // CHECK:STDOUT: ; uselistorder directives
  67. // CHECK:STDOUT: uselistorder ptr @llvm.memcpy.p0.p0.i64, { 1, 0 }
  68. // CHECK:STDOUT:
  69. // CHECK:STDOUT: attributes #0 = { nocallback nofree nounwind willreturn memory(argmem: readwrite) }