reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    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
   28
   29
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=x86_64-- < %s | FileCheck %s

@a = external global <16 x float>, align 64

declare void @goo(<2 x i256>)

define void @foo() #0 {
; CHECK-LABEL: foo:
; CHECK:       # %bb.0:
; CHECK-NEXT:    subq $24, %rsp
; CHECK-NEXT:    movq a+{{.*}}(%rip), %r9
; CHECK-NEXT:    movq a+{{.*}}(%rip), %r8
; CHECK-NEXT:    movq a+{{.*}}(%rip), %rcx
; CHECK-NEXT:    movq a+{{.*}}(%rip), %rdx
; CHECK-NEXT:    movq a+{{.*}}(%rip), %rsi
; CHECK-NEXT:    movq {{.*}}(%rip), %rdi
; CHECK-NEXT:    vmovaps a+{{.*}}(%rip), %xmm0
; CHECK-NEXT:    vmovups %xmm0, (%rsp)
; CHECK-NEXT:    callq goo
; CHECK-NEXT:    addq $24, %rsp
; CHECK-NEXT:    retq
  %k = bitcast <16 x float>* @a to <2 x i256>*
  %load = load <2 x i256>, <2 x i256>* %k, align 64
  call void @goo(<2 x i256> %load)
  ret void
}

attributes #0 = { nounwind "target-features"="+avx512bw" }