56 lines
2.2 KiB
YAML
56 lines
2.2 KiB
YAML
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 2
|
|
# RUN: llc -mtriple=x86_64-linux-gnu -mattr=+sse -run-pass=legalizer %s -o - | FileCheck %s --check-prefix=X86-64-SEE
|
|
|
|
# test G_STORE with vectors
|
|
|
|
---
|
|
name: test_gstore_v2s32
|
|
body: |
|
|
bb.0:
|
|
; X86-64-SEE-LABEL: name: test_gstore_v2s32
|
|
; X86-64-SEE: [[DEF:%[0-9]+]]:_(<2 x s32>) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: [[DEF1:%[0-9]+]]:_(p0) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: G_STORE [[DEF]](<2 x s32>), [[DEF1]](p0) :: (store (<2 x s32>) into `ptr undef`)
|
|
; X86-64-SEE-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY [[DEF1]](p0)
|
|
; X86-64-SEE-NEXT: RET 0, implicit [[COPY]](p0)
|
|
%0:_(<2 x s32>) = IMPLICIT_DEF
|
|
%1:_(p0) = IMPLICIT_DEF
|
|
G_STORE %0:_(<2 x s32>), %1:_(p0) :: (store (<2 x s32>) into `ptr undef`)
|
|
%2:_(p0) = COPY %1:_(p0)
|
|
RET 0, implicit %2:_(p0)
|
|
|
|
...
|
|
---
|
|
name: test_gstore_v4s8
|
|
body: |
|
|
bb.0:
|
|
; X86-64-SEE-LABEL: name: test_gstore_v4s8
|
|
; X86-64-SEE: [[DEF:%[0-9]+]]:_(<4 x s8>) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: [[DEF1:%[0-9]+]]:_(p0) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: G_STORE [[DEF]](<4 x s8>), [[DEF1]](p0) :: (store (<4 x s8>) into `ptr undef`)
|
|
; X86-64-SEE-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY [[DEF1]](p0)
|
|
; X86-64-SEE-NEXT: RET 0, implicit [[COPY]](p0)
|
|
%0:_(<4 x s8>) = IMPLICIT_DEF
|
|
%1:_(p0) = IMPLICIT_DEF
|
|
G_STORE %0:_(<4 x s8>), %1:_(p0) :: (store (<4 x s8>) into `ptr undef`)
|
|
%2:_(p0) = COPY %1:_(p0)
|
|
RET 0, implicit %2:_(p0)
|
|
|
|
...
|
|
---
|
|
name: test_gstore_v2p0
|
|
body: |
|
|
bb.0:
|
|
; X86-64-SEE-LABEL: name: test_gstore_v2p0
|
|
; X86-64-SEE: [[DEF:%[0-9]+]]:_(<2 x p0>) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: [[DEF1:%[0-9]+]]:_(p0) = IMPLICIT_DEF
|
|
; X86-64-SEE-NEXT: G_STORE [[DEF]](<2 x p0>), [[DEF1]](p0) :: (store (<2 x p0>) into `ptr undef`)
|
|
; X86-64-SEE-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY [[DEF1]](p0)
|
|
; X86-64-SEE-NEXT: RET 0, implicit [[COPY]](p0)
|
|
%0:_(<2 x p0>) = IMPLICIT_DEF
|
|
%1:_(p0) = IMPLICIT_DEF
|
|
G_STORE %0:_(<2 x p0>), %1:_(p0) :: (store (<2 x p0>) into `ptr undef`)
|
|
%2:_(p0) = COPY %1:_(p0)
|
|
RET 0, implicit %2:_(p0)
|
|
|
|
...
|