summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/20090313-signext.ll
blob: 688cb07ac8e4f82c2b6d6da882b224fd2c30bec0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=x86_64-- -relocation-model=pic | FileCheck %s

@x = common global i16 0

define signext i16 @f() nounwind {
; CHECK-LABEL: f:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    pushq %rax
; CHECK-NEXT:    callq h@PLT
; CHECK-NEXT:    movswl %ax, %edi
; CHECK-NEXT:    callq g@PLT
; CHECK-NEXT:    movq x@{{.*}}(%rip), %rax
; CHECK-NEXT:    movzwl (%rax), %eax
; CHECK-NEXT:    popq %rcx
; CHECK-NEXT:    retq
entry:
	%0 = tail call signext i16 @h() nounwind
	%1 = sext i16 %0 to i32
	tail call void @g(i32 %1) nounwind
	%2 = load i16, i16* @x, align 2
	ret i16 %2
}

declare signext i16 @h()

declare void @g(i32)
OpenPOWER on IntegriCloud