[AArch64,ELF] Restrict MOVZ/MOVK to non-PIC large code model (#70178)
[llvm-project.git] / llvm / test / CodeGen / X86 / pr59980.ll
blob0823f960724e22275a140a48e24f8c62ed72560f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-apple-macosx10.15 | FileCheck %s
4 %0 = type <{ half }>
5 %1 = type <{ <16 x half> }>
7 define void @foo(ptr %0, ptr %1, ptr %2) #0 {
8 ; CHECK-LABEL: foo:
9 ; CHECK:       ## %bb.0:
10 ; CHECK-NEXT:    movl (%rdx), %eax
11 ; CHECK-NEXT:    vpinsrw $0, (%rdi), %xmm0, %xmm0
12 ; CHECK-NEXT:    vpextrw $0, %xmm0, (%rsi,%rax,2)
13 ; CHECK-NEXT:    retq
14   %4 = bitcast ptr %2 to ptr
15   %5 = load i64, ptr %4, align 8
16   %6 = getelementptr inbounds %0, ptr %0, i64 0, i32 0
17   %7 = load half, ptr %6, align 2
18   %8 = getelementptr inbounds %1, ptr %1, i64 0, i32 0
19   %9 = load <16 x half>, ptr %8, align 16
20   %10 = trunc i64 %5 to i32
21   %11 = insertelement <16 x half> %9, half %7, i32 %10
22   store <16 x half> %11, ptr %8, align 16
23   ret void
26 attributes #0 = { nounwind "target-features"="+f16c" }