diff options
author | Hao Liu <Hao.Liu@arm.com> | 2013-11-05 03:39:32 +0000 |
---|---|---|
committer | Hao Liu <Hao.Liu@arm.com> | 2013-11-05 03:39:32 +0000 |
commit | 591c2f738a3e12026ff5504a486d54fc21fb3049 (patch) | |
tree | 6909db3910a1e52022a3166d0b2d7648269f5bc3 /lib/Target/AArch64/AArch64ISelLowering.h | |
parent | 8263dcdf23bc534405745959c97cbfd562362458 (diff) | |
download | llvm-591c2f738a3e12026ff5504a486d54fc21fb3049.tar.gz llvm-591c2f738a3e12026ff5504a486d54fc21fb3049.tar.bz2 llvm-591c2f738a3e12026ff5504a486d54fc21fb3049.tar.xz |
Implement AArch64 post-index vector load/store multiple N-element structure class SIMD(lselem-post).
Including following 14 instructions:
4 ld1 insts: post-index load multiple 1-element structure to sequential 1/2/3/4 registers.
ld2/ld3/ld4: post-index load multiple N-element structure to sequential N registers (N=2,3,4).
4 st1 insts: post-index store multiple 1-element structure from sequential 1/2/3/4 registers.
st2/st3/st4: post-index store multiple N-element structure from sequential N registers (N = 2,3,4).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194043 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/AArch64/AArch64ISelLowering.h')
-rw-r--r-- | lib/Target/AArch64/AArch64ISelLowering.h | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/lib/Target/AArch64/AArch64ISelLowering.h b/lib/Target/AArch64/AArch64ISelLowering.h index 9836d40155..7effbfd66c 100644 --- a/lib/Target/AArch64/AArch64ISelLowering.h +++ b/lib/Target/AArch64/AArch64ISelLowering.h @@ -142,7 +142,19 @@ namespace AArch64ISD { NEON_VDUP, // Vector dup by lane - NEON_VDUPLANE + NEON_VDUPLANE, + + // NEON loads with post-increment base updates: + NEON_LD1_UPD = ISD::FIRST_TARGET_MEMORY_OPCODE, + NEON_LD2_UPD, + NEON_LD3_UPD, + NEON_LD4_UPD, + + // NEON stores with post-increment base updates: + NEON_ST1_UPD, + NEON_ST2_UPD, + NEON_ST3_UPD, + NEON_ST4_UPD }; } |