xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/xmulo.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc %s -o - | FileCheck %s
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32-S128"
3*9880d681SAndroid Build Coastguard Workertarget triple = "i386-apple-macosx10.8.0"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdeclare {i64, i1} @llvm.umul.with.overflow.i64(i64, i64) nounwind readnone
6*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8*, ...)
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [10 x i8] c"%llx, %d\0A\00", align 1
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine i32 @t1() nounwind {
11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t1:
12*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $0
13*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $0
14*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $72
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker    %1 = call {i64, i1} @llvm.umul.with.overflow.i64(i64 9, i64 8)
17*9880d681SAndroid Build Coastguard Worker    %2 = extractvalue {i64, i1} %1, 0
18*9880d681SAndroid Build Coastguard Worker    %3 = extractvalue {i64, i1} %1, 1
19*9880d681SAndroid Build Coastguard Worker    %4 = zext i1 %3 to i32
20*9880d681SAndroid Build Coastguard Worker    %5 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), i64 %2, i32 %4)
21*9880d681SAndroid Build Coastguard Worker    ret i32 0
22*9880d681SAndroid Build Coastguard Worker}
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Workerdefine i32 @t2() nounwind {
25*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t2:
26*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $0
27*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $0
28*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $0
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Worker    %1 = call {i64, i1} @llvm.umul.with.overflow.i64(i64 9, i64 0)
31*9880d681SAndroid Build Coastguard Worker    %2 = extractvalue {i64, i1} %1, 0
32*9880d681SAndroid Build Coastguard Worker    %3 = extractvalue {i64, i1} %1, 1
33*9880d681SAndroid Build Coastguard Worker    %4 = zext i1 %3 to i32
34*9880d681SAndroid Build Coastguard Worker    %5 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), i64 %2, i32 %4)
35*9880d681SAndroid Build Coastguard Worker    ret i32 0
36*9880d681SAndroid Build Coastguard Worker}
37*9880d681SAndroid Build Coastguard Worker
38*9880d681SAndroid Build Coastguard Workerdefine i32 @t3() nounwind {
39*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t3:
40*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $1
41*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $-1
42*9880d681SAndroid Build Coastguard Worker; CHECK:  pushl $-9
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Worker    %1 = call {i64, i1} @llvm.umul.with.overflow.i64(i64 9, i64 -1)
45*9880d681SAndroid Build Coastguard Worker    %2 = extractvalue {i64, i1} %1, 0
46*9880d681SAndroid Build Coastguard Worker    %3 = extractvalue {i64, i1} %1, 1
47*9880d681SAndroid Build Coastguard Worker    %4 = zext i1 %3 to i32
48*9880d681SAndroid Build Coastguard Worker    %5 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), i64 %2, i32 %4)
49*9880d681SAndroid Build Coastguard Worker    ret i32 0
50*9880d681SAndroid Build Coastguard Worker}
51