From d3b1d74624b1652716af0b9aa986463e542251a0 Mon Sep 17 00:00:00 2001 From: Chen Zheng Date: Mon, 8 Apr 2019 05:49:15 +0000 Subject: [PATCH] [InstCombine] add testcases for sdiv exact flag fixing - NFC. llvm-svn: 357884 --- llvm/test/Transforms/InstCombine/div.ll | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/llvm/test/Transforms/InstCombine/div.ll b/llvm/test/Transforms/InstCombine/div.ll index 2bfa549..91747a5 100644 --- a/llvm/test/Transforms/InstCombine/div.ll +++ b/llvm/test/Transforms/InstCombine/div.ll @@ -760,3 +760,22 @@ define <2 x i8> @udiv_common_factor_not_nuw_vec(<2 x i8> %x, <2 x i8> %y, <2 x i ret <2 x i8> %c } +define i32 @test_exact(i32 %x) { +; CHECK-LABEL: @test_exact( +; CHECK-NEXT: [[DIV:%.*]] = sdiv i32 [[X:%.*]], -3 +; CHECK-NEXT: ret i32 [[DIV]] +; + %div = sdiv exact i32 %x, 3 + %neg = sub nsw i32 0, %div + ret i32 %neg +} + +define <2 x i64> @test_exact_vec(<2 x i64> %x) { +; CHECK-LABEL: @test_exact_vec( +; CHECK-NEXT: [[DIV:%.*]] = sdiv <2 x i64> [[X:%.*]], +; CHECK-NEXT: ret <2 x i64> [[DIV]] +; + %div = sdiv exact <2 x i64> %x, + %neg = sub nsw <2 x i64> zeroinitializer, %div + ret <2 x i64> %neg +} -- 2.7.4