summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/add-trick64.ll
blob: 5466d9d441b164eb949ad252f884ef31381029d8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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
}