aboutsummaryrefslogtreecommitdiffstats
path: root/test/Assembler/flags.ll
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2011-02-07 16:40:21 +0000
committerChris Lattner <sabre@nondot.org>2011-02-07 16:40:21 +0000
commitf067d584a81ae771d301304ea885e55e2de8ee9a (patch)
tree9e3fa2842b0884048e3cf0937db440d77d115168 /test/Assembler/flags.ll
parent163a84bbce69947aa314760e6068c704fc0df7a0 (diff)
downloadexternal_llvm-f067d584a81ae771d301304ea885e55e2de8ee9a.zip
external_llvm-f067d584a81ae771d301304ea885e55e2de8ee9a.tar.gz
external_llvm-f067d584a81ae771d301304ea885e55e2de8ee9a.tar.bz2
implement .ll and .bc support for nsw/nuw on shl and exact on lshr/ashr.
Factor some code better. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@125006 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Assembler/flags.ll')
-rw-r--r--test/Assembler/flags.ll45
1 files changed, 45 insertions, 0 deletions
diff --git a/test/Assembler/flags.ll b/test/Assembler/flags.ll
index 82b35b5..310b807 100644
--- a/test/Assembler/flags.ll
+++ b/test/Assembler/flags.ll
@@ -92,6 +92,12 @@ define i64 @mul_both_reversed(i64 %x, i64 %y) {
ret i64 %z
}
+define i64 @shl_both(i64 %x, i64 %y) {
+; CHECK: %z = shl nuw nsw i64 %x, %y
+ %z = shl nuw nsw i64 %x, %y
+ ret i64 %z
+}
+
define i64 @sdiv_exact(i64 %x, i64 %y) {
; CHECK: %z = sdiv exact i64 %x, %y
%z = sdiv exact i64 %x, %y
@@ -116,6 +122,29 @@ define i64 @udiv_plain(i64 %x, i64 %y) {
ret i64 %z
}
+define i64 @ashr_plain(i64 %x, i64 %y) {
+; CHECK: %z = ashr i64 %x, %y
+ %z = ashr i64 %x, %y
+ ret i64 %z
+}
+
+define i64 @ashr_exact(i64 %x, i64 %y) {
+; CHECK: %z = ashr exact i64 %x, %y
+ %z = ashr exact i64 %x, %y
+ ret i64 %z
+}
+
+define i64 @lshr_plain(i64 %x, i64 %y) {
+; CHECK: %z = lshr i64 %x, %y
+ %z = lshr i64 %x, %y
+ ret i64 %z
+}
+
+define i64 @lshr_exact(i64 %x, i64 %y) {
+; CHECK: %z = lshr exact i64 %x, %y
+ %z = lshr exact i64 %x, %y
+ ret i64 %z
+}
define i64* @gep_nw(i64* %p, i64 %x) {
; CHECK: %z = getelementptr inbounds i64* %p, i64 %x
@@ -154,6 +183,16 @@ define i64 @udiv_exact_ce() {
ret i64 udiv exact (i64 ptrtoint (i64* @addr to i64), i64 91)
}
+define i64 @ashr_exact_ce() {
+; CHECK: ret i64 ashr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
+ ret i64 ashr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
+}
+
+define i64 @lshr_exact_ce() {
+; CHECK: ret i64 lshr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
+ ret i64 lshr exact (i64 ptrtoint (i64* @addr to i64), i64 9)
+}
+
define i64* @gep_nw_ce() {
; CHECK: ret i64* getelementptr inbounds (i64* @addr, i64 171)
ret i64* getelementptr inbounds (i64* @addr, i64 171)
@@ -214,6 +253,12 @@ define i64 @mul_signed_ce() {
ret i64 mul nsw (i64 ptrtoint (i64* @addr to i64), i64 91)
}
+define i64 @shl_signed_ce() {
+; CHECK: ret i64 shl nsw (i64 ptrtoint (i64* @addr to i64), i64 17)
+ ret i64 shl nsw (i64 ptrtoint (i64* @addr to i64), i64 17)
+}
+
+
define i64 @add_unsigned_ce() {
; CHECK: ret i64 add nuw (i64 ptrtoint (i64* @addr to i64), i64 91)
ret i64 add nuw (i64 ptrtoint (i64* @addr to i64), i64 91)