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 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
# 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)
...
|