[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / CodeGen / X86 / memcpy-from-string.ll
blobaf88ffa843dfd0406655947b64fc6cb75f2e8ab5
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s | FileCheck %s --check-prefix=X86
4 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5 target triple = "x86_64-unknown-linux-gnu"
7 %0 = type { %1, i64, %2 }
8 %1 = type { i8* }
9 %2 = type { i64, [8 x i8] }
11 @0 = internal constant [10 x i8] c"asdf jkl;\00", align 1
13 ; Memcpy lowering should emit stores of immediates containing string data from
14 ; the correct offsets.
16 define void @foo(i8* %tmp2) {
17 ; X86-LABEL: foo:
18 ; X86:       # %bb.0:
19 ; X86-NEXT:    movl $3894379, 3(%rdi) # imm = 0x3B6C6B
20 ; X86-NEXT:    movl $1802117222, (%rdi) # imm = 0x6B6A2066
21 ; X86-NEXT:    retq
22   call void @llvm.memcpy.p0i8.p0i8.i64(i8* %tmp2, i8* getelementptr inbounds ([10 x i8], [10 x i8]* @0, i64 0, i64 3), i64 7, i1 false)
23   ret void
26 declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture, i8* nocapture readonly, i64, i1)