uint.carbon 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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 Negate(a: u64) -> u64 = "int.negate";
  7. fn TestNegate(a: u64) -> u64 { return Negate(a); }
  8. fn Add(a: u64, b: u64) -> u64 = "int.add";
  9. fn TestAdd(a: u64, b: u64) -> u64 { return Add(a, b); }
  10. fn Sub(a: u64, b: u64) -> u64 = "int.sub";
  11. fn TestSub(a: u64, b: u64) -> u64 { return Sub(a, b); }
  12. fn Mul(a: u64, b: u64) -> u64 = "int.mul";
  13. fn TestMul(a: u64, b: u64) -> u64 { return Mul(a, b); }
  14. fn Div(a: u64, b: u64) -> u64 = "int.div";
  15. fn TestDiv(a: u64, b: u64) -> u64 { return Div(a, b); }
  16. fn Mod(a: u64, b: u64) -> u64 = "int.mod";
  17. fn TestMod(a: u64, b: u64) -> u64 { return Mod(a, b); }
  18. fn Complement(a: u64) -> u64 = "int.complement";
  19. fn TestComplement(a: u64) -> u64 { return Complement(a); }
  20. fn And(a: u64, b: u64) -> u64 = "int.and";
  21. fn TestAnd(a: u64, b: u64) -> u64 { return And(a, b); }
  22. fn Or(a: u64, b: u64) -> u64 = "int.or";
  23. fn TestOr(a: u64, b: u64) -> u64 { return Or(a, b); }
  24. fn Xor(a: u64, b: u64) -> u64 = "int.xor";
  25. fn TestXor(a: u64, b: u64) -> u64 { return Xor(a, b); }
  26. fn LeftShift(a: u64, b: u64) -> u64 = "int.left_shift";
  27. fn TestLeftShift(a: u64, b: u64) -> u64 { return LeftShift(a, b); }
  28. fn RightShift(a: u64, b: u64) -> u64 = "int.right_shift";
  29. fn TestRightShift(a: u64, b: u64) -> u64 { return RightShift(a, b); }
  30. fn Eq(a: u64, b: u64) -> bool = "int.eq";
  31. fn TestEq(a: u64, b: u64) -> bool { return Eq(a, b); }
  32. fn Neq(a: u64, b: u64) -> bool = "int.neq";
  33. fn TestNeq(a: u64, b: u64) -> bool { return Neq(a, b); }
  34. fn Less(a: u64, b: u64) -> bool = "int.less";
  35. fn TestLess(a: u64, b: u64) -> bool { return Less(a, b); }
  36. fn LessEq(a: u64, b: u64) -> bool = "int.less_eq";
  37. fn TestLessEq(a: u64, b: u64) -> bool { return LessEq(a, b); }
  38. fn Greater(a: u64, b: u64) -> bool = "int.greater";
  39. fn TestGreater(a: u64, b: u64) -> bool { return Greater(a, b); }
  40. fn GreaterEq(a: u64, b: u64) -> bool = "int.greater_eq";
  41. fn TestGreaterEq(a: u64, b: u64) -> bool { return GreaterEq(a, b); }
  42. // CHECK:STDOUT: ; ModuleID = 'uint.carbon'
  43. // CHECK:STDOUT: source_filename = "uint.carbon"
  44. // CHECK:STDOUT:
  45. // CHECK:STDOUT: define i64 @TestNegate(i64 %a) {
  46. // CHECK:STDOUT: %neg = sub i64 0, %a
  47. // CHECK:STDOUT: ret i64 %neg
  48. // CHECK:STDOUT: }
  49. // CHECK:STDOUT:
  50. // CHECK:STDOUT: define i64 @TestAdd(i64 %a, i64 %b) {
  51. // CHECK:STDOUT: %add = add i64 %a, %b
  52. // CHECK:STDOUT: ret i64 %add
  53. // CHECK:STDOUT: }
  54. // CHECK:STDOUT:
  55. // CHECK:STDOUT: define i64 @TestSub(i64 %a, i64 %b) {
  56. // CHECK:STDOUT: %sub = sub i64 %a, %b
  57. // CHECK:STDOUT: ret i64 %sub
  58. // CHECK:STDOUT: }
  59. // CHECK:STDOUT:
  60. // CHECK:STDOUT: define i64 @TestMul(i64 %a, i64 %b) {
  61. // CHECK:STDOUT: %mul = mul i64 %a, %b
  62. // CHECK:STDOUT: ret i64 %mul
  63. // CHECK:STDOUT: }
  64. // CHECK:STDOUT:
  65. // CHECK:STDOUT: define i64 @TestDiv(i64 %a, i64 %b) {
  66. // CHECK:STDOUT: %div = udiv i64 %a, %b
  67. // CHECK:STDOUT: ret i64 %div
  68. // CHECK:STDOUT: }
  69. // CHECK:STDOUT:
  70. // CHECK:STDOUT: define i64 @TestMod(i64 %a, i64 %b) {
  71. // CHECK:STDOUT: %rem = urem i64 %a, %b
  72. // CHECK:STDOUT: ret i64 %rem
  73. // CHECK:STDOUT: }
  74. // CHECK:STDOUT:
  75. // CHECK:STDOUT: define i64 @TestComplement(i64 %a) {
  76. // CHECK:STDOUT: %cmpl = xor i64 -1, %a
  77. // CHECK:STDOUT: ret i64 %cmpl
  78. // CHECK:STDOUT: }
  79. // CHECK:STDOUT:
  80. // CHECK:STDOUT: define i64 @TestAnd(i64 %a, i64 %b) {
  81. // CHECK:STDOUT: %and = and i64 %a, %b
  82. // CHECK:STDOUT: ret i64 %and
  83. // CHECK:STDOUT: }
  84. // CHECK:STDOUT:
  85. // CHECK:STDOUT: define i64 @TestOr(i64 %a, i64 %b) {
  86. // CHECK:STDOUT: %or = or i64 %a, %b
  87. // CHECK:STDOUT: ret i64 %or
  88. // CHECK:STDOUT: }
  89. // CHECK:STDOUT:
  90. // CHECK:STDOUT: define i64 @TestXor(i64 %a, i64 %b) {
  91. // CHECK:STDOUT: %xor = xor i64 %a, %b
  92. // CHECK:STDOUT: ret i64 %xor
  93. // CHECK:STDOUT: }
  94. // CHECK:STDOUT:
  95. // CHECK:STDOUT: define i64 @TestLeftShift(i64 %a, i64 %b) {
  96. // CHECK:STDOUT: %shl = shl i64 %a, %b
  97. // CHECK:STDOUT: ret i64 %shl
  98. // CHECK:STDOUT: }
  99. // CHECK:STDOUT:
  100. // CHECK:STDOUT: define i64 @TestRightShift(i64 %a, i64 %b) {
  101. // CHECK:STDOUT: %shr = lshr i64 %a, %b
  102. // CHECK:STDOUT: ret i64 %shr
  103. // CHECK:STDOUT: }
  104. // CHECK:STDOUT:
  105. // CHECK:STDOUT: define i1 @TestEq(i64 %a, i64 %b) {
  106. // CHECK:STDOUT: %cmp = icmp eq i64 %a, %b
  107. // CHECK:STDOUT: ret i1 %cmp
  108. // CHECK:STDOUT: }
  109. // CHECK:STDOUT:
  110. // CHECK:STDOUT: define i1 @TestNeq(i64 %a, i64 %b) {
  111. // CHECK:STDOUT: %cmp = icmp ne i64 %a, %b
  112. // CHECK:STDOUT: ret i1 %cmp
  113. // CHECK:STDOUT: }
  114. // CHECK:STDOUT:
  115. // CHECK:STDOUT: define i1 @TestLess(i64 %a, i64 %b) {
  116. // CHECK:STDOUT: %cmp = icmp ult i64 %a, %b
  117. // CHECK:STDOUT: ret i1 %cmp
  118. // CHECK:STDOUT: }
  119. // CHECK:STDOUT:
  120. // CHECK:STDOUT: define i1 @TestLessEq(i64 %a, i64 %b) {
  121. // CHECK:STDOUT: %cmp = icmp ule i64 %a, %b
  122. // CHECK:STDOUT: ret i1 %cmp
  123. // CHECK:STDOUT: }
  124. // CHECK:STDOUT:
  125. // CHECK:STDOUT: define i1 @TestGreater(i64 %a, i64 %b) {
  126. // CHECK:STDOUT: %cmp = icmp ugt i64 %a, %b
  127. // CHECK:STDOUT: ret i1 %cmp
  128. // CHECK:STDOUT: }
  129. // CHECK:STDOUT:
  130. // CHECK:STDOUT: define i1 @TestGreaterEq(i64 %a, i64 %b) {
  131. // CHECK:STDOUT: %cmp = icmp uge i64 %a, %b
  132. // CHECK:STDOUT: ret i1 %cmp
  133. // CHECK:STDOUT: }