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)
|
|
|
|
define i1 @a(i32 %x) zeroext nounwind {
|
|
|
|
%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)
|
|
|
|
define i1 @b(i32 %x) zeroext nounwind {
|
|
|
|
%res = call {i32, i1} @llvm.smul.with.overflow.i32(i32 %x, i32 3)
|
|
|
|
%obil = extractvalue {i32, i1} %res, 1
|
|
|
|
ret i1 %obil
|
|
|
|
}
|