diff mbox series

[22/38] target/cris: Use tcg_gen_abs_tl

Message ID 20190420073442.7488-23-richard.henderson@linaro.org
State Superseded
Headers show
Series tcg vector improvements | expand

Commit Message

Richard Henderson April 20, 2019, 7:34 a.m. UTC
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

---
 target/cris/translate.c | 9 +--------
 1 file changed, 1 insertion(+), 8 deletions(-)

-- 
2.17.1

Comments

Philippe Mathieu-Daudé April 23, 2019, 10:09 a.m. UTC | #1
On 4/20/19 9:34 AM, Richard Henderson wrote:
> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

> ---

>  target/cris/translate.c | 9 +--------

>  1 file changed, 1 insertion(+), 8 deletions(-)

> 

> diff --git a/target/cris/translate.c b/target/cris/translate.c

> index 11b2c11174..0374718f66 100644

> --- a/target/cris/translate.c

> +++ b/target/cris/translate.c

> @@ -1685,18 +1685,11 @@ static int dec_cmp_r(CPUCRISState *env, DisasContext *dc)

>  

>  static int dec_abs_r(CPUCRISState *env, DisasContext *dc)

>  {

> -    TCGv t0;

> -

>      LOG_DIS("abs $r%u, $r%u\n",

>              dc->op1, dc->op2);

>      cris_cc_mask(dc, CC_MASK_NZ);

>  

> -    t0 = tcg_temp_new();

> -    tcg_gen_sari_tl(t0, cpu_R[dc->op1], 31);

> -    tcg_gen_xor_tl(cpu_R[dc->op2], cpu_R[dc->op1], t0);

> -    tcg_gen_sub_tl(cpu_R[dc->op2], cpu_R[dc->op2], t0);

> -    tcg_temp_free(t0);

> -

> +    tcg_gen_abs_tl(cpu_R[dc->op2], cpu_R[dc->op1]);

>      cris_alu(dc, CC_OP_MOVE,

>              cpu_R[dc->op2], cpu_R[dc->op2], cpu_R[dc->op2], 4);

>      return 2;

> 


Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
diff mbox series

Patch

diff --git a/target/cris/translate.c b/target/cris/translate.c
index 11b2c11174..0374718f66 100644
--- a/target/cris/translate.c
+++ b/target/cris/translate.c
@@ -1685,18 +1685,11 @@  static int dec_cmp_r(CPUCRISState *env, DisasContext *dc)
 
 static int dec_abs_r(CPUCRISState *env, DisasContext *dc)
 {
-    TCGv t0;
-
     LOG_DIS("abs $r%u, $r%u\n",
             dc->op1, dc->op2);
     cris_cc_mask(dc, CC_MASK_NZ);
 
-    t0 = tcg_temp_new();
-    tcg_gen_sari_tl(t0, cpu_R[dc->op1], 31);
-    tcg_gen_xor_tl(cpu_R[dc->op2], cpu_R[dc->op1], t0);
-    tcg_gen_sub_tl(cpu_R[dc->op2], cpu_R[dc->op2], t0);
-    tcg_temp_free(t0);
-
+    tcg_gen_abs_tl(cpu_R[dc->op2], cpu_R[dc->op1]);
     cris_alu(dc, CC_OP_MOVE,
             cpu_R[dc->op2], cpu_R[dc->op2], cpu_R[dc->op2], 4);
     return 2;