[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 1/8] tcg/tcg-op: Document bswap16_i32() byte pattern
From: |
Philippe Mathieu-Daudé |
Subject: |
[PATCH v2 1/8] tcg/tcg-op: Document bswap16_i32() byte pattern |
Date: |
Wed, 23 Aug 2023 16:55:35 +0200 |
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
---
tcg/tcg-op.c | 32 ++++++++++++++++++++++++--------
1 file changed, 24 insertions(+), 8 deletions(-)
diff --git a/tcg/tcg-op.c b/tcg/tcg-op.c
index 7aadb37756..c1b9a3e34c 100644
--- a/tcg/tcg-op.c
+++ b/tcg/tcg-op.c
@@ -1021,6 +1021,15 @@ void tcg_gen_ext16u_i32(TCGv_i32 ret, TCGv_i32 arg)
}
}
+/*
+ * bswap16_i32: 16-bit byte swap on the low bits of a 32-bit value.
+ *
+ * flags
+ * Byte pattern: bswap16_i32(..ab) -> .aba (TCG_BSWAP_IZ)
+ * bswap16_i32(xxab) -> ..ba (TCG_BSWAP_OZ)
+ * bswap16_i32(xxab) -> ssba (TCG_BSWAP_OS)
+ * bswap16_i32(xxab) -> xaba
+ */
void tcg_gen_bswap16_i32(TCGv_i32 ret, TCGv_i32 arg, int flags)
{
/* Only one extension flag may be present. */
@@ -1032,22 +1041,29 @@ void tcg_gen_bswap16_i32(TCGv_i32 ret, TCGv_i32 arg,
int flags)
TCGv_i32 t0 = tcg_temp_ebb_new_i32();
TCGv_i32 t1 = tcg_temp_ebb_new_i32();
- tcg_gen_shri_i32(t0, arg, 8);
+ /* arg = xxab (IZ=0) */
+ /* = ..ab (IZ=1) */
+ tcg_gen_shri_i32(t0, arg, 8); /* t0 = .xxa (IZ=0) */
+ /* = ...a (IZ=1) */
if (!(flags & TCG_BSWAP_IZ)) {
- tcg_gen_ext8u_i32(t0, t0);
+ tcg_gen_ext8u_i32(t0, t0); /* t0 = ...a (IZ=0) */
}
if (flags & TCG_BSWAP_OS) {
- tcg_gen_shli_i32(t1, arg, 24);
- tcg_gen_sari_i32(t1, t1, 16);
+ tcg_gen_shli_i32(t1, arg, 24); /* t1 = b... (OS=1) */
+ tcg_gen_sari_i32(t1, t1, 16); /* t1 = ssb. (OS=1) */
} else if (flags & TCG_BSWAP_OZ) {
- tcg_gen_ext8u_i32(t1, arg);
- tcg_gen_shli_i32(t1, t1, 8);
+ tcg_gen_ext8u_i32(t1, arg); /* t1 = ...b (OZ=1) */
+ tcg_gen_shli_i32(t1, t1, 8); /* t1 = ..b. (OZ=1) */
} else {
- tcg_gen_shli_i32(t1, arg, 8);
+ tcg_gen_shli_i32(t1, arg, 8); /* t1 = xab. (IZ=0) */
+ /* = .ab. (IZ=1) */
}
- tcg_gen_or_i32(ret, t0, t1);
+ tcg_gen_or_i32(ret, t0, t1); /* ret = ..ba (OZ=1) */
+ /* = ssba (OS=1) */
+ /* = .aba (IZ=1) */
+ /* = xaba (no flag) */
tcg_temp_free_i32(t0);
tcg_temp_free_i32(t1);
}
--
2.41.0
- [PATCH v2 0/8] tcg: Document *swap* helper implementations, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 1/8] tcg/tcg-op: Document bswap16_i32() byte pattern,
Philippe Mathieu-Daudé <=
- [PATCH v2 4/8] tcg/tcg-op: Document bswap32_i64() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 5/8] tcg/tcg-op: Document bswap64_i64() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 7/8] tcg/tcg-op: Document wswap_i64() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 2/8] tcg/tcg-op: Document bswap16_i64() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 3/8] tcg/tcg-op: Document bswap32_i32() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 6/8] tcg/tcg-op: Document hswap_i32/64() byte pattern, Philippe Mathieu-Daudé, 2023/08/23
- [PATCH v2 8/8] target/cris: Fix a typo in gen_swapr(), Philippe Mathieu-Daudé, 2023/08/23
- Re: [PATCH v2 0/8] tcg: Document *swap* helper implementations, Richard Henderson, 2023/08/23