All of lore.kernel.org
 help / color / mirror / Atom feed
From: Stefan Weil <weil@mail.berlios.de>
To: Blue Swirl <blauwirbel@gmail.com>
Cc: TeLeMan <geleman@gmail.com>,
	Kenneth Salerno <kennethsalerno@yahoo.com>,
	qemu-devel <qemu-devel@nongnu.org>,
	zhur@ispras.ru, Kirill Batuzov <batuzovk@ispras.ru>
Subject: Re: [Qemu-devel] [PATCH] TCG: fix copy propagation
Date: Sun, 07 Aug 2011 08:48:16 +0200	[thread overview]
Message-ID: <4E3E3530.8000501@mail.berlios.de> (raw)
In-Reply-To: <CAAu8pHssiKJ48NGcJNe8X4K_hxk9Yq4Gi1hQw1YBvAsVEnbcYw@mail.gmail.com>

Am 06.08.2011 23:26, schrieb Blue Swirl:
> Copy propagation introduced in 22613af4a6d9602001e6d0e7b6d98aa40aa018dc
> considered only global registers. However, register temps and stack
> allocated locals must be handled differently because register temps
> don't survive across brcond.
>
> Fix by propagating only within same class of temps.
>
> Signed-off-by: Blue Swirl<blauwirbel@gmail.com>
> ---
>   tcg/optimize.c |   15 +++++++++------
>   tcg/tcg.h      |    5 +++++
>   2 files changed, 14 insertions(+), 6 deletions(-)
>
> diff --git a/tcg/optimize.c b/tcg/optimize.c
> index a3bfa5e..7eb5eb1 100644
> --- a/tcg/optimize.c
> +++ b/tcg/optimize.c
> @@ -185,12 +185,15 @@ static int op_to_movi(int op)
>       }
>   }
>
> -static void tcg_opt_gen_mov(TCGArg *gen_args, TCGArg dst, TCGArg src,
> -                            int nb_temps, int nb_globals)
> +static void tcg_opt_gen_mov(TCGContext *s, TCGArg *gen_args, TCGArg dst,
> +                            TCGArg src, int nb_temps, int nb_globals)
>   {
>           reset_temp(dst, nb_temps, nb_globals);
>           assert(temps[src].state != TCG_TEMP_COPY);
> -        if (src>= nb_globals) {
> +        /* Don't try to copy if one of temps is a global or either one
> +           is local and another is register */
> +        if (src>= nb_globals&&  dst>= nb_globals&&
> +            tcg_arg_is_local(s, src) == tcg_arg_is_local(s, dst)) {
>               assert(temps[src].state != TCG_TEMP_CONST);
>               if (temps[src].state != TCG_TEMP_HAS_COPY) {
>                   temps[src].state = TCG_TEMP_HAS_COPY;
> @@ -474,7 +477,7 @@ static TCGArg *tcg_constant_folding(TCGContext *s,
> uint16_t *tcg_opc_ptr,
>                       gen_opc_buf[op_index] = INDEX_op_nop;
>                   } else {
>                       gen_opc_buf[op_index] = op_to_mov(op);
> -                    tcg_opt_gen_mov(gen_args, args[0], args[1],
> +                    tcg_opt_gen_mov(s, gen_args, args[0], args[1],
>                                       nb_temps, nb_globals);
>                       gen_args += 2;
>                       args += 3;
> @@ -500,7 +503,7 @@ static TCGArg *tcg_constant_folding(TCGContext *s,
> uint16_t *tcg_opc_ptr,
>                       gen_opc_buf[op_index] = INDEX_op_nop;
>                   } else {
>                       gen_opc_buf[op_index] = op_to_mov(op);
> -                    tcg_opt_gen_mov(gen_args, args[0], args[1], nb_temps,
> +                    tcg_opt_gen_mov(s, gen_args, args[0], args[1], nb_temps,
>                                       nb_globals);
>                       gen_args += 2;
>                       args += 3;
> @@ -523,7 +526,7 @@ static TCGArg *tcg_constant_folding(TCGContext *s,
> uint16_t *tcg_opc_ptr,
>                   break;
>               }
>               if (temps[args[1]].state != TCG_TEMP_CONST) {
> -                tcg_opt_gen_mov(gen_args, args[0], args[1],
> +                tcg_opt_gen_mov(s, gen_args, args[0], args[1],
>                                   nb_temps, nb_globals);
>                   gen_args += 2;
>                   args += 2;
> diff --git a/tcg/tcg.h b/tcg/tcg.h
> index e76f9af..e2a7095 100644
> --- a/tcg/tcg.h
> +++ b/tcg/tcg.h
> @@ -410,6 +410,11 @@ static inline TCGv_i64 tcg_temp_local_new_i64(void)
>   void tcg_temp_free_i64(TCGv_i64 arg);
>   char *tcg_get_arg_str_i64(TCGContext *s, char *buf, int buf_size,
> TCGv_i64 arg);
>
> +static inline bool tcg_arg_is_local(TCGContext *s, TCGArg arg)
> +{
> +    return s->temps[arg].temp_local;
> +}
> +
>   #if defined(CONFIG_DEBUG_TCG)
>   /* If you call tcg_clear_temp_count() at the start of a section of
>    * code which is not supposed to leak any TCG temporaries, then

This fixes qemu-system-x86_64 and qemu-system-mips64(el) on 32 bit hosts.

Tested-by: Stefan Weil <weil@mail.berlios.de>

  reply	other threads:[~2011-08-07  6:48 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-08-06 21:26 [Qemu-devel] [PATCH] TCG: fix copy propagation Blue Swirl
2011-08-07  6:48 ` Stefan Weil [this message]
2011-08-07  9:36   ` Blue Swirl
  -- strict thread matches above, loose matches on Subject: below --
2011-08-06 14:06 Blue Swirl
2011-08-06 20:13 ` Stefan Weil
2011-08-06 20:33   ` Stefan Weil
2011-08-06 21:07     ` Blue Swirl

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4E3E3530.8000501@mail.berlios.de \
    --to=weil@mail.berlios.de \
    --cc=batuzovk@ispras.ru \
    --cc=blauwirbel@gmail.com \
    --cc=geleman@gmail.com \
    --cc=kennethsalerno@yahoo.com \
    --cc=qemu-devel@nongnu.org \
    --cc=zhur@ispras.ru \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.