2009-09-09 08:09:15 +08:00
|
|
|
; RUN: llc < %s -march=ppc32
|
2009-06-16 14:58:29 +08:00
|
|
|
|
|
|
|
declare {i32, i1} @llvm.umul.with.overflow.i32(i32 %a, i32 %b)
|
2011-06-17 11:14:27 +08:00
|
|
|
define zeroext i1 @a(i32 %x) nounwind {
|
2009-06-16 14:58:29 +08:00
|
|
|
%res = call {i32, i1} @llvm.umul.with.overflow.i32(i32 %x, i32 3)
|
|
|
|
%obil = extractvalue {i32, i1} %res, 1
|
|
|
|
ret i1 %obil
|
|
|
|
}
|
|
|
|
|
|
|
|
declare {i32, i1} @llvm.smul.with.overflow.i32(i32 %a, i32 %b)
|
2011-06-17 11:14:27 +08:00
|
|
|
define zeroext i1 @b(i32 %x) nounwind {
|
2009-06-16 14:58:29 +08:00
|
|
|
%res = call {i32, i1} @llvm.smul.with.overflow.i32(i32 %x, i32 3)
|
|
|
|
%obil = extractvalue {i32, i1} %res, 1
|
|
|
|
ret i1 %obil
|
|
|
|
}
|