diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/CodeGen/X86/add-trick32.ll | 11 | ||||
-rw-r--r-- | test/CodeGen/X86/add-trick64.ll | 15 | ||||
-rw-r--r-- | test/TableGen/2006-09-18-LargeInt.td | 2 |
3 files changed, 27 insertions, 1 deletions
diff --git a/test/CodeGen/X86/add-trick32.ll b/test/CodeGen/X86/add-trick32.ll new file mode 100644 index 0000000000..42909b4b58 --- /dev/null +++ b/test/CodeGen/X86/add-trick32.ll @@ -0,0 +1,11 @@ +; RUN: llvm-as < %s | llc -march=x86 > %t +; RUN: not grep add %t +; RUN: grep subl %t | count 1 + +; The immediate can be encoded in a smaller way if the +; instruction is a sub instead of an add. + +define i32 @foo(i32 inreg %a) nounwind { + %b = add i32 %a, 128 + ret i32 %b +} diff --git a/test/CodeGen/X86/add-trick64.ll b/test/CodeGen/X86/add-trick64.ll new file mode 100644 index 0000000000..5466d9d441 --- /dev/null +++ b/test/CodeGen/X86/add-trick64.ll @@ -0,0 +1,15 @@ +; RUN: llvm-as < %s | llc -march=x86-64 > %t +; RUN: not grep add %t +; RUN: grep subq %t | count 2 + +; The immediate can be encoded in a smaller way if the +; instruction is a sub instead of an add. + +define i64 @foo(i64 inreg %a) nounwind { + %b = add i64 %a, 2147483648 + ret i64 %b +} +define i64 @bar(i64 inreg %a) nounwind { + %b = add i64 %a, 128 + ret i64 %b +} diff --git a/test/TableGen/2006-09-18-LargeInt.td b/test/TableGen/2006-09-18-LargeInt.td index 0e441c5b47..afd813fab6 100644 --- a/test/TableGen/2006-09-18-LargeInt.td +++ b/test/TableGen/2006-09-18-LargeInt.td @@ -1,4 +1,4 @@ -// RUN: tblgen %s | grep -- -65536 +// RUN: tblgen %s | grep -- 4294901760 def X { int Y = 0xFFFF0000; |