From: Craig Topper Date: Sat, 29 Dec 2018 07:14:30 +0000 (+0000) Subject: [X86] Add test case from PR38217. NFC X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2ccabc1c0e8b79febc617a1244dc12d46ddcb2d1;p=llvm [X86] Add test case from PR38217. NFC git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@350150 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGen/X86/pr38217.ll b/test/CodeGen/X86/pr38217.ll new file mode 100644 index 00000000000..1c053ba93fc --- /dev/null +++ b/test/CodeGen/X86/pr38217.ll @@ -0,0 +1,79 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py +; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s + +@_ZL11DIGIT_TABLE = constant [201 x i8] c"00010203040506070809101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899\00", align 16 + +define void @_Z12d2s_bufferedmPc(i64, i8* nocapture) { +; CHECK-LABEL: _Z12d2s_bufferedmPc: +; CHECK: # %bb.0: +; CHECK-NEXT: cmpq $10000, %rdi # imm = 0x2710 +; CHECK-NEXT: jb .LBB0_3 +; CHECK-NEXT: # %bb.1: # %.preheader +; CHECK-NEXT: movq %rdi, %r9 +; CHECK-NEXT: xorl %r10d, %r10d +; CHECK-NEXT: movabsq $3777893186295716171, %r8 # imm = 0x346DC5D63886594B +; CHECK-NEXT: .p2align 4, 0x90 +; CHECK-NEXT: .LBB0_2: # =>This Inner Loop Header: Depth=1 +; CHECK-NEXT: movq %r9, %rax +; CHECK-NEXT: mulq %r8 +; CHECK-NEXT: shrq $11, %rdx +; CHECK-NEXT: imulq $10000, %rdx, %rax # imm = 0x2710 +; CHECK-NEXT: movq %r9, %rdi +; CHECK-NEXT: subq %rax, %rdi +; CHECK-NEXT: imulq $1374389535, %rdi, %rcx # imm = 0x51EB851F +; CHECK-NEXT: movq %rcx, %rax +; CHECK-NEXT: shrq $37, %rax +; CHECK-NEXT: imull $100, %eax, %eax +; CHECK-NEXT: subl %eax, %edi +; CHECK-NEXT: shrq $36, %rcx +; CHECK-NEXT: andl $510, %ecx # imm = 0x1FE +; CHECK-NEXT: movl %r10d, %r11d +; CHECK-NEXT: movq %rsi, %rax +; CHECK-NEXT: subq %r11, %rax +; CHECK-NEXT: movzwl _ZL11DIGIT_TABLE(%rdi,%rdi), %edi +; CHECK-NEXT: movw %di, -1(%rax) +; CHECK-NEXT: movzwl _ZL11DIGIT_TABLE(%rcx), %ecx +; CHECK-NEXT: movw %cx, -3(%rax) +; CHECK-NEXT: addl $4, %r10d +; CHECK-NEXT: cmpq $99999999, %r9 # imm = 0x5F5E0FF +; CHECK-NEXT: movq %rdx, %r9 +; CHECK-NEXT: ja .LBB0_2 +; CHECK-NEXT: .LBB0_3: +; CHECK-NEXT: retq + %3 = icmp ugt i64 %0, 9999 + br i1 %3, label %4, label %31 + +;