summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/lea-4.ll
blob: cef47264a58394838eaf746ce9220f90c062a0d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
; RUN: llc < %s -march=x86-64 | FileCheck %s

define zeroext i16 @t1(i32 %on_off) nounwind {
entry:
  %0 = sub i32 %on_off, 1
  %1 = mul i32 %0, 2
  %2 = trunc i32 %1 to i16
  %3 = zext i16 %2 to i32
  %4 = trunc i32 %3 to i16
; CHECK: lea
  ret i16 %4
}

define i32 @t2(i32 %on_off) nounwind {
entry:
  %0 = sub i32 %on_off, 1
  %1 = mul i32 %0, 2
  %2 = and i32 %1, 65535
; CHECK: lea
  ret i32 %2
}