[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 3/8] target/arm: optimize rev16() using extract op
From: |
Philippe Mathieu-Daudé |
Subject: |
[Qemu-devel] [PATCH 3/8] target/arm: optimize rev16() using extract op |
Date: |
Wed, 10 May 2017 17:05:30 -0300 |
Applied using Coccinelle script.
Signed-off-by: Philippe Mathieu-Daudé <address@hidden>
---
target/arm/translate-a64.c | 6 ++----
1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
index 24de30d92c..7ea130107e 100644
--- a/target/arm/translate-a64.c
+++ b/target/arm/translate-a64.c
@@ -4038,14 +4038,12 @@ static void handle_rev16(DisasContext *s, unsigned int
sf,
tcg_gen_andi_i64(tcg_tmp, tcg_rn, 0xffff);
tcg_gen_bswap16_i64(tcg_rd, tcg_tmp);
- tcg_gen_shri_i64(tcg_tmp, tcg_rn, 16);
- tcg_gen_andi_i64(tcg_tmp, tcg_tmp, 0xffff);
+ tcg_gen_extract_i64(tcg_tmp, tcg_rn, 16, 0xffff);
tcg_gen_bswap16_i64(tcg_tmp, tcg_tmp);
tcg_gen_deposit_i64(tcg_rd, tcg_rd, tcg_tmp, 16, 16);
if (sf) {
- tcg_gen_shri_i64(tcg_tmp, tcg_rn, 32);
- tcg_gen_andi_i64(tcg_tmp, tcg_tmp, 0xffff);
+ tcg_gen_extract_i64(tcg_tmp, tcg_rn, 32, 0xffff);
tcg_gen_bswap16_i64(tcg_tmp, tcg_tmp);
tcg_gen_deposit_i64(tcg_rd, tcg_rd, tcg_tmp, 32, 16);
--
2.11.0
- [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), (continued)
- [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), Philippe Mathieu-Daudé, 2017/05/10
- Re: [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), Philippe Mathieu-Daudé, 2017/05/10
- Re: [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), Markus Armbruster, 2017/05/11
- Re: [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), Philippe Mathieu-Daudé, 2017/05/11
- Re: [Qemu-devel] [RFC PATCH v2] coccinelle: add a script to optimize tcg op using tcg_gen_extract(), Philippe Mathieu-Daudé, 2017/05/11
[Qemu-devel] [PATCH 2/8] target/arm: optimize smul_dual() and neon_trn_u8() using extract op, Philippe Mathieu-Daudé, 2017/05/10
[Qemu-devel] [PATCH 3/8] target/arm: optimize rev16() using extract op,
Philippe Mathieu-Daudé <=
[Qemu-devel] [PATCH 4/8] target/cris: optimize gen_swapb() using extract op, Philippe Mathieu-Daudé, 2017/05/10
[Qemu-devel] [PATCH 5/8] target/m68k: optimize bcd_flags() using extract op, Philippe Mathieu-Daudé, 2017/05/10
[Qemu-devel] [PATCH 6/8] target/mips: optimize bshfl() using extract op, Philippe Mathieu-Daudé, 2017/05/10
[Qemu-devel] [PATCH 7/8] target/ppc: optimize various functions using extract op, Philippe Mathieu-Daudé, 2017/05/10