blob: 9cf630a55dd6508f6bf4b1248911caa98e39ae68 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 | FileCheck %s
define i64 @test(i128 %in) {
; CHECK-LABEL: test:
; CHECK: # %bb.0:
; CHECK-NEXT: larl %r1, .LCPI0_0
; CHECK-NEXT: vl %v0, 0(%r2), 3
; CHECK-NEXT: vl %v1, 0(%r1), 3
; CHECK-NEXT: vaccq %v0, %v0, %v1
; CHECK-NEXT: vlgvg %r1, %v0, 1
; CHECK-NEXT: la %r2, 1(%r1)
; CHECK-NEXT: br %r14
%1 = tail call { i128, i1 } @llvm.uadd.with.overflow.i128(i128 %in, i128 1)
%2 = extractvalue { i128, i1 } %1, 1
%3 = zext i1 %2 to i64
%4 = add i64 %3, 1
ret i64 %4
}
declare { i128, i1 } @llvm.uadd.with.overflow.i128(i128, i128) #0
attributes #0 = { nocallback nofree nosync nounwind speculatable willreturn memory(none) }