xref: /llvm-project/llvm/test/CodeGen/X86/pr57576.ll (revision aa83bdd1982fbf1174d0769a7842a86779041f37)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu | FileCheck %s
3
4define { i64, i64 } @sub(i64 noundef %0, i64 noundef %1, i64 noundef %2, i64 noundef %3) {
5; CHECK-LABEL: sub:
6; CHECK:       # %bb.0:
7; CHECK-NEXT:    movq %rdi, %rax
8; CHECK-NEXT:    subq %rdx, %rax
9; CHECK-NEXT:    sbbq %rcx, %rsi
10; CHECK-NEXT:    movq %rsi, %rdx
11; CHECK-NEXT:    retq
12  %5 = zext i64 %1 to i128
13  %6 = shl nuw i128 %5, 64
14  %7 = zext i64 %0 to i128
15  %8 = zext i64 %3 to i128
16  %9 = mul i128 %8, -18446744073709551616
17  %10 = zext i64 %2 to i128
18  %11 = or i128 %6, %7
19  %12 = sub i128 %11, %10
20  %13 = add i128 %12, %9
21  %14 = trunc i128 %13 to i64
22  %15 = lshr i128 %13, 64
23  %16 = trunc i128 %15 to i64
24  %17 = insertvalue { i64, i64 } poison, i64 %14, 0
25  %18 = insertvalue { i64, i64 } %17, i64 %16, 1
26  ret { i64, i64 } %18
27}
28