qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH] [ppc] Convert op_move_{T1,T2}_T0 to TCG


From: Aurelien Jarno
Subject: Re: [Qemu-devel] [PATCH] [ppc] Convert op_move_{T1,T2}_T0 to TCG
Date: Tue, 2 Sep 2008 18:19:04 +0200
User-agent: Mutt/1.5.18 (2008-05-17)

On Tue, Sep 02, 2008 at 05:39:17PM +0200, Andreas Färber wrote:
> Hello,
>
> Attached patch replaces op_move_T1_T0 and op_move_T2_T0 with  
> tcg_gen_mov_tl.
>
> Signed-off-by: Andreas Faerber <address@hidden>
>
> Andreas


Applied, thanks.

>
>
> diff --git a/target-ppc/op.c b/target-ppc/op.c
> index 022d424..3ee326d 100644
> --- a/target-ppc/op.c
> +++ b/target-ppc/op.c
> @@ -137,18 +137,6 @@ void OPPROTO op_set_Rc0 (void)
>  }
>
>  /* Constants load */
> -void OPPROTO op_move_T1_T0 (void)
> -{
> -    T1 = T0;
> -    RETURN();
> -}
> -
> -void OPPROTO op_move_T2_T0 (void)
> -{
> -    T2 = T0;
> -    RETURN();
> -}
> -
>  void OPPROTO op_moven_T2_T0 (void)
>  {
>      T2 = ~T0;
> diff --git a/target-ppc/translate.c b/target-ppc/translate.c
> index 2c83056..cf6d486 100644
> --- a/target-ppc/translate.c
> +++ b/target-ppc/translate.c
> @@ -795,7 +795,7 @@ __GEN_INT_ARITH1_O_64(name##o, opc1, opc2, opc3 |  
> 0x10, type)
>  /* add    add.    addo    addo.    */
>  static always_inline void gen_op_addo (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addo();
>  }
> @@ -803,7 +803,7 @@ static always_inline void gen_op_addo (void)
>  #define gen_op_add_64 gen_op_add
>  static always_inline void gen_op_addo_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addo_64();
>  }
> @@ -812,13 +812,13 @@ GEN_INT_ARITH2_64 (add,    0x1F, 0x0A, 0x08,  
> PPC_INTEGER);
>  /* addc   addc.   addco   addco.   */
>  static always_inline void gen_op_addc (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addc();
>  }
>  static always_inline void gen_op_addco (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addc();
>      gen_op_check_addo();
> @@ -826,13 +826,13 @@ static always_inline void gen_op_addco (void)
>  #if defined(TARGET_PPC64)
>  static always_inline void gen_op_addc_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addc_64();
>  }
>  static always_inline void gen_op_addco_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add();
>      gen_op_check_addc_64();
>      gen_op_check_addo_64();
> @@ -842,14 +842,14 @@ GEN_INT_ARITH2_64 (addc,   0x1F, 0x0A, 0x00,  
> PPC_INTEGER);
>  /* adde   adde.   addeo   addeo.   */
>  static always_inline void gen_op_addeo (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_adde();
>      gen_op_check_addo();
>  }
>  #if defined(TARGET_PPC64)
>  static always_inline void gen_op_addeo_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_adde_64();
>      gen_op_check_addo_64();
>  }
> @@ -858,13 +858,13 @@ GEN_INT_ARITH2_64 (adde,   0x1F, 0x0A, 0x04,  
> PPC_INTEGER);
>  /* addme  addme.  addmeo  addmeo.  */
>  static always_inline void gen_op_addme (void)
>  {
> -    gen_op_move_T1_T0();
> +    tcg_gen_mov_tl(cpu_T[1], cpu_T[0]);
>      gen_op_add_me();
>  }
>  #if defined(TARGET_PPC64)
>  static always_inline void gen_op_addme_64 (void)
>  {
> -    gen_op_move_T1_T0();
> +    tcg_gen_mov_tl(cpu_T[1], cpu_T[0]);
>      gen_op_add_me_64();
>  }
>  #endif
> @@ -872,13 +872,13 @@ GEN_INT_ARITH1_64 (addme,  0x1F, 0x0A, 0x07,  
> PPC_INTEGER);
>  /* addze  addze.  addzeo  addzeo.  */
>  static always_inline void gen_op_addze (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add_ze();
>      gen_op_check_addc();
>  }
>  static always_inline void gen_op_addzeo (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add_ze();
>      gen_op_check_addc();
>      gen_op_check_addo();
> @@ -886,13 +886,13 @@ static always_inline void gen_op_addzeo (void)
>  #if defined(TARGET_PPC64)
>  static always_inline void gen_op_addze_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add_ze();
>      gen_op_check_addc_64();
>  }
>  static always_inline void gen_op_addzeo_64 (void)
>  {
> -    gen_op_move_T2_T0();
> +    tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>      gen_op_add_ze();
>      gen_op_check_addc_64();
>      gen_op_check_addo_64();
> @@ -999,7 +999,7 @@ GEN_HANDLER(addic, 0x0C, 0xFF, 0xFF, 0x00000000,  
> PPC_INTEGER)
>
>      gen_op_load_gpr_T0(rA(ctx->opcode));
>      if (likely(simm != 0)) {
> -        gen_op_move_T2_T0();
> +        tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>          gen_op_addi(simm);
>  #if defined(TARGET_PPC64)
>          if (ctx->sf_mode)
> @@ -1019,7 +1019,7 @@ GEN_HANDLER2(addic_, "addic.", 0x0D, 0xFF, 0xFF,  
> 0x00000000, PPC_INTEGER)
>
>      gen_op_load_gpr_T0(rA(ctx->opcode));
>      if (likely(simm != 0)) {
> -        gen_op_move_T2_T0();
> +        tcg_gen_mov_tl(cpu_T[2], cpu_T[0]);
>          gen_op_addi(simm);
>  #if defined(TARGET_PPC64)
>          if (ctx->sf_mode)
> @@ -1661,7 +1661,7 @@ GEN_HANDLER(srawi, 0x1F, 0x18, 0x19, 0x00000000,  
> PPC_INTEGER)
>      int mb, me;
>      gen_op_load_gpr_T0(rS(ctx->opcode));
>      if (SH(ctx->opcode) != 0) {
> -        gen_op_move_T1_T0();
> +        tcg_gen_mov_tl(cpu_T[1], cpu_T[0]);
>          mb = 32 - SH(ctx->opcode);
>          me = 31;
>  #if defined(TARGET_PPC64)
> @@ -1691,7 +1691,7 @@ static always_inline void gen_sradi (DisasContext 
> *ctx, int n)
>      gen_op_load_gpr_T0(rS(ctx->opcode));
>      sh = SH(ctx->opcode) + (n << 5);
>      if (sh != 0) {
> -        gen_op_move_T1_T0();
> +        tcg_gen_mov_tl(cpu_T[1], cpu_T[0]);
>          mb = 64 - SH(ctx->opcode);
>          me = 63;
>          mask = MASK(mb, me);
> @@ -4647,7 +4647,7 @@ static always_inline void gen_405_mulladd_insn  
> (DisasContext *ctx,
>      if (opc2 & 0x04) {
>          /* (n)multiply-and-accumulate (0x0C - 0x0E) */
>          gen_op_load_gpr_T2(rt);
> -        gen_op_move_T1_T0();
> +        tcg_gen_mov_tl(cpu_T[1], cpu_T[0]);
>          gen_op_405_add_T0_T2();
>      }
>      if (opc3 & 0x10) {
>


>


-- 
  .''`.  Aurelien Jarno             | GPG: 1024D/F1BCDB73
 : :' :  Debian developer           | Electrical Engineer
 `. `'   address@hidden         | address@hidden
   `-    people.debian.org/~aurel32 | www.aurel32.net




reply via email to

[Prev in Thread] Current Thread [Next in Thread]