aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/X86/i8-umulo.ll
blob: ba846f3e9be309dee57da0e23b2fcc205ab841aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
; RUN: llc -mcpu=generic -march=x86 < %s | FileCheck %s
; PR19858

declare {i8, i1} @llvm.umul.with.overflow.i8(i8 %a, i8 %b)
define i8 @testumulo(i32 %argc) {
; CHECK: imulw
; CHECK: testb %{{.+}}, %{{.+}}
; CHECK: je [[NOOVERFLOWLABEL:.+]]
; CHECK: {{.*}}[[NOOVERFLOWLABEL]]:
; CHECK-NEXT: movb
; CHECK-NEXT: retl
top:
  %RHS = trunc i32 %argc to i8
  %umul = call { i8, i1 } @llvm.umul.with.overflow.i8(i8 25, i8 %RHS)
  %ex = extractvalue { i8, i1 } %umul, 1
  br i1 %ex, label %overflow, label %nooverlow

overflow:
  ret i8 %RHS

nooverlow:
  %umul.value = extractvalue { i8, i1 } %umul, 0
  ret i8 %umul.value
}