[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[qemu-s390x] [PULL 13/54] s390x/tcg: Implement VECTOR CHECKSUM
From: |
Cornelia Huck |
Subject: |
[qemu-s390x] [PULL 13/54] s390x/tcg: Implement VECTOR CHECKSUM |
Date: |
Mon, 20 May 2019 19:02:21 +0200 |
From: David Hildenbrand <address@hidden>
Time to introduce read_vec_element_i32 and write_vec_element_i32.
Take proper care of properly adding the carry. We can perform both
additions including the carry via tcg_gen_add2_i32().
Reviewed-by: Richard Henderson <address@hidden>
Signed-off-by: David Hildenbrand <address@hidden>
---
target/s390x/insn-data.def | 2 +
target/s390x/translate_vx.inc.c | 65 +++++++++++++++++++++++++++++++++
2 files changed, 67 insertions(+)
diff --git a/target/s390x/insn-data.def b/target/s390x/insn-data.def
index 9889dc0b018f..64459465c51d 100644
--- a/target/s390x/insn-data.def
+++ b/target/s390x/insn-data.def
@@ -1072,6 +1072,8 @@
F(0xe7f2, VAVG, VRR_c, V, 0, 0, 0, 0, vavg, 0, IF_VEC)
/* VECTOR AVERAGE LOGICAL */
F(0xe7f0, VAVGL, VRR_c, V, 0, 0, 0, 0, vavgl, 0, IF_VEC)
+/* VECTOR CHECKSUM */
+ F(0xe766, VCKSM, VRR_c, V, 0, 0, 0, 0, vcksm, 0, IF_VEC)
#ifndef CONFIG_USER_ONLY
/* COMPARE AND SWAP AND PURGE */
diff --git a/target/s390x/translate_vx.inc.c b/target/s390x/translate_vx.inc.c
index 3ff068213553..b9d40ffeb7a7 100644
--- a/target/s390x/translate_vx.inc.c
+++ b/target/s390x/translate_vx.inc.c
@@ -90,6 +90,33 @@ static void read_vec_element_i64(TCGv_i64 dst, uint8_t reg,
uint8_t enr,
}
}
+static void read_vec_element_i32(TCGv_i32 dst, uint8_t reg, uint8_t enr,
+ TCGMemOp memop)
+{
+ const int offs = vec_reg_offset(reg, enr, memop & MO_SIZE);
+
+ switch (memop) {
+ case ES_8:
+ tcg_gen_ld8u_i32(dst, cpu_env, offs);
+ break;
+ case ES_16:
+ tcg_gen_ld16u_i32(dst, cpu_env, offs);
+ break;
+ case ES_8 | MO_SIGN:
+ tcg_gen_ld8s_i32(dst, cpu_env, offs);
+ break;
+ case ES_16 | MO_SIGN:
+ tcg_gen_ld16s_i32(dst, cpu_env, offs);
+ break;
+ case ES_32:
+ case ES_32 | MO_SIGN:
+ tcg_gen_ld_i32(dst, cpu_env, offs);
+ break;
+ default:
+ g_assert_not_reached();
+ }
+}
+
static void write_vec_element_i64(TCGv_i64 src, int reg, uint8_t enr,
TCGMemOp memop)
{
@@ -113,6 +140,25 @@ static void write_vec_element_i64(TCGv_i64 src, int reg,
uint8_t enr,
}
}
+static void write_vec_element_i32(TCGv_i32 src, int reg, uint8_t enr,
+ TCGMemOp memop)
+{
+ const int offs = vec_reg_offset(reg, enr, memop & MO_SIZE);
+
+ switch (memop) {
+ case ES_8:
+ tcg_gen_st8_i32(src, cpu_env, offs);
+ break;
+ case ES_16:
+ tcg_gen_st16_i32(src, cpu_env, offs);
+ break;
+ case ES_32:
+ tcg_gen_st_i32(src, cpu_env, offs);
+ break;
+ default:
+ g_assert_not_reached();
+ }
+}
static void get_vec_element_ptr_i64(TCGv_ptr ptr, uint8_t reg, TCGv_i64 enr,
uint8_t es)
@@ -1304,3 +1350,22 @@ static DisasJumpType op_vavgl(DisasContext *s, DisasOps
*o)
get_field(s->fields, v3), &g[es]);
return DISAS_NEXT;
}
+
+static DisasJumpType op_vcksm(DisasContext *s, DisasOps *o)
+{
+ TCGv_i32 tmp = tcg_temp_new_i32();
+ TCGv_i32 sum = tcg_temp_new_i32();
+ int i;
+
+ read_vec_element_i32(sum, get_field(s->fields, v3), 1, ES_32);
+ for (i = 0; i < 4; i++) {
+ read_vec_element_i32(tmp, get_field(s->fields, v2), i, ES_32);
+ tcg_gen_add2_i32(tmp, sum, sum, sum, tmp, tmp);
+ }
+ zero_vec(get_field(s->fields, v1));
+ write_vec_element_i32(sum, get_field(s->fields, v1), 1, ES_32);
+
+ tcg_temp_free_i32(tmp);
+ tcg_temp_free_i32(sum);
+ return DISAS_NEXT;
+}
--
2.20.1
- [qemu-s390x] [PULL 04/54] s390/ipl: cast to SCSIDevice directly, (continued)
- [qemu-s390x] [PULL 04/54] s390/ipl: cast to SCSIDevice directly, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 05/54] s390/css: handle CCW_FLAG_SKIP, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 03/54] pc-bios/s390: Update firmware image with "Skip bootmap signature entries" fix, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 06/54] s390x/tcg: Implement VECTOR ADD, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 07/54] s390x/tcg: Implement VECTOR ADD COMPUTE CARRY, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 09/54] s390x/tcg: Implement VECTOR ADD WITH CARRY COMPUTE CARRY, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 08/54] s390x/tcg: Implement VECTOR ADD WITH CARRY, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 10/54] s390x/tcg: Implement VECTOR AND (WITH COMPLEMENT), Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 11/54] s390x/tcg: Implement VECTOR AVERAGE, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 12/54] s390x/tcg: Implement VECTOR AVERAGE LOGICAL, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 13/54] s390x/tcg: Implement VECTOR CHECKSUM,
Cornelia Huck <=
- [qemu-s390x] [PULL 14/54] s390x/tcg: Implement VECTOR ELEMENT COMPARE *, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 15/54] s390x/tcg: Implement VECTOR COMPARE *, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 16/54] s390x/tcg: Implement VECTOR COUNT LEADING ZEROS, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 17/54] s390x/tcg: Implement VECTOR COUNT TRAILING ZEROS, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 18/54] s390x/tcg: Implement VECTOR EXCLUSIVE OR, Cornelia Huck, 2019/05/20
- [qemu-s390x] [PULL 19/54] s390x/tcg: Implement VECTOR GALOIS FIELD MULTIPLY SUM (AND ACCUMULATE), Cornelia Huck, 2019/05/20