FAIL;
})
-(define_expand "aarch64_ld2r<mode>"
- [(match_operand:OI 0 "register_operand" "=w")
+(define_expand "aarch64_ld<VSTRUCT:nregs>r<VALLDIF:mode>"
+ [(match_operand:VSTRUCT 0 "register_operand" "=w")
(match_operand:DI 1 "register_operand" "w")
(unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
"TARGET_SIMD"
{
rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 2);
+ set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<VALLDIF:MODE>mode))
+ * <VSTRUCT:nregs>);
- emit_insn (gen_aarch64_simd_ld2r<mode> (operands[0], mem));
- DONE;
-})
-
-(define_expand "aarch64_ld3r<mode>"
- [(match_operand:CI 0 "register_operand" "=w")
- (match_operand:DI 1 "register_operand" "w")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 3);
-
- emit_insn (gen_aarch64_simd_ld3r<mode> (operands[0], mem));
- DONE;
-})
-
-(define_expand "aarch64_ld4r<mode>"
- [(match_operand:XI 0 "register_operand" "=w")
- (match_operand:DI 1 "register_operand" "w")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 4);
-
- emit_insn (gen_aarch64_simd_ld4r<mode> (operands[0],mem));
+ emit_insn (gen_aarch64_simd_ld<VSTRUCT:nregs>r<VALLDIF:mode> (operands[0],
+ mem));
DONE;
})
DONE;
})
-(define_expand "aarch64_ld2_lane<mode>"
- [(match_operand:OI 0 "register_operand" "=w")
- (match_operand:DI 1 "register_operand" "w")
- (match_operand:OI 2 "register_operand" "0")
- (match_operand:SI 3 "immediate_operand" "i")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 2);
-
- emit_insn (gen_aarch64_vec_load_lanesoi_lane<mode> (operands[0],
- mem,
- operands[2],
- operands[3]));
- DONE;
-})
-
-(define_expand "aarch64_ld3_lane<mode>"
- [(match_operand:CI 0 "register_operand" "=w")
+(define_expand "aarch64_ld<VSTRUCT:nregs>_lane<VALLDIF:mode>"
+ [(match_operand:VSTRUCT 0 "register_operand" "=w")
(match_operand:DI 1 "register_operand" "w")
- (match_operand:CI 2 "register_operand" "0")
+ (match_operand:VSTRUCT 2 "register_operand" "0")
(match_operand:SI 3 "immediate_operand" "i")
(unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
"TARGET_SIMD"
{
rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 3);
-
- emit_insn (gen_aarch64_vec_load_lanesci_lane<mode> (operands[0],
- mem,
- operands[2],
- operands[3]));
+ set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<VALLDIF:MODE>mode))
+ * <VSTRUCT:nregs>);
+
+ aarch64_simd_lane_bounds (operands[3], 0,
+ GET_MODE_NUNITS (<VALLDIF:MODE>mode),
+ NULL);
+ emit_insn (gen_aarch64_vec_load_lanes<VSTRUCT:mode>_lane<VALLDIF:mode> (
+ operands[0], mem, operands[2], operands[3]));
DONE;
})
-(define_expand "aarch64_ld4_lane<mode>"
- [(match_operand:XI 0 "register_operand" "=w")
- (match_operand:DI 1 "register_operand" "w")
- (match_operand:XI 2 "register_operand" "0")
- (match_operand:SI 3 "immediate_operand" "i")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[1]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 4);
-
- emit_insn (gen_aarch64_vec_load_lanesxi_lane<mode> (operands[0],
- mem,
- operands[2],
- operands[3]));
- DONE;
-})
-
-
-
;; Expanders for builtins to extract vector registers from large
;; opaque integer modes.
DONE;
})
-(define_expand "aarch64_st2_lane<mode>"
- [(match_operand:DI 0 "register_operand" "r")
- (match_operand:OI 1 "register_operand" "w")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)
- (match_operand:SI 2 "immediate_operand")]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[0]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 2);
-
- emit_insn (gen_aarch64_vec_store_lanesoi_lane<mode> (mem,
- operands[1],
- operands[2]));
- DONE;
-})
-
-(define_expand "aarch64_st3_lane<mode>"
- [(match_operand:DI 0 "register_operand" "r")
- (match_operand:CI 1 "register_operand" "w")
- (unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)
- (match_operand:SI 2 "immediate_operand")]
- "TARGET_SIMD"
-{
- rtx mem = gen_rtx_MEM (BLKmode, operands[0]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 3);
-
- emit_insn (gen_aarch64_vec_store_lanesci_lane<mode> (mem,
- operands[1],
- operands[2]));
- DONE;
-})
-
-(define_expand "aarch64_st4_lane<mode>"
+(define_expand "aarch64_st<VSTRUCT:nregs>_lane<VALLDIF:mode>"
[(match_operand:DI 0 "register_operand" "r")
- (match_operand:XI 1 "register_operand" "w")
+ (match_operand:VSTRUCT 1 "register_operand" "w")
(unspec:VALLDIF [(const_int 0)] UNSPEC_VSTRUCTDUMMY)
(match_operand:SI 2 "immediate_operand")]
"TARGET_SIMD"
{
rtx mem = gen_rtx_MEM (BLKmode, operands[0]);
- set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<MODE>mode)) * 4);
+ set_mem_size (mem, GET_MODE_SIZE (GET_MODE_INNER (<VALLDIF:MODE>mode))
+ * <VSTRUCT:nregs>);
- emit_insn (gen_aarch64_vec_store_lanesxi_lane<mode> (mem,
- operands[1],
- operands[2]));
+ emit_insn (gen_aarch64_vec_store_lanes<VSTRUCT:mode>_lane<VALLDIF:mode> (
+ mem, operands[1], operands[2]));
DONE;
})