qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Pranith Kumar <bobby.prani@gmail.com>
To: Richard Henderson <rth@twiddle.net>
Cc: "open list:All patches CC here" <qemu-devel@nongnu.org>,
	"Alex Bennée" <alex.bennee@linaro.org>
Subject: Re: [Qemu-devel] [RFC v2 PATCH] tcg: Optimize fence instructions
Date: Wed, 10 Aug 2016 13:58:29 -0400	[thread overview]
Message-ID: <CAJhHMCB6bL3qiz1ucwLyHq0GrT4mFiDA03q5C1zdX+aj_mJkgA@mail.gmail.com> (raw)
In-Reply-To: <9212daae-d1de-7e5b-f5a3-3a60e754de6a@twiddle.net>

Hi Richard,

On Wed, Aug 10, 2016 at 6:44 AM, Richard Henderson <rth@twiddle.net> wrote:
> On 08/10/2016 04:42 AM, Pranith Kumar wrote:
>>
>> +/* Eliminate duplicate and unnecessary fence instructions */
>> +void tcg_optimize_mb(TCGContext *s)
>> +{
>> +    int oi, oi_next;
>> +    TCGArg prev_op_mb = -1;
>> +    TCGOp *prev_op = NULL;
>> +
>> +    for (oi = s->gen_op_buf[0].next; oi != 0; oi = oi_next) {
>> +        TCGOp *op = &s->gen_op_buf[oi];
>> +        TCGArg *args = &s->gen_opparam_buf[op->args];
>> +        TCGOpcode opc = op->opc;
>> +
>> +        switch (opc) {
>> +        case INDEX_op_mb:
>> +        {
>> +            TCGBar curr_mb_type = args[0] & 0xF0;
>> +            TCGBar prev_mb_type = prev_op_mb & 0xF0;
>> +
>> +            if (curr_mb_type == prev_mb_type ||
>> +                (curr_mb_type == TCG_BAR_STRL && prev_mb_type ==
>> TCG_BAR_SC)) {
>
>
> As I said before, I don't think you should be doing any of this if
> prev_op_mb == -1.  I think that's the first thing you should test within
> INDEX_op_mb.

If prev_op_mb is -1, none of the conditions evaluate to true and we
will fall through. Did you want me to check this as an optimization or
am I missing your point?

>
>> +                /* Remove the current weaker barrier op. The previous
>> +                 * barrier is stronger and sufficient.
>> +                 * mb; strl => mb; st
>> +                 */
>> +                tcg_op_remove(s, op);
>> +                op = prev_op;
>
>
> As I said before, surely you have to merge the low 4 bits as well.

Since we are removing the weaker barrier and leaving the stronger
barrier, I think just updating args[0] to have the stronger barrier
semantics should be enough.

                tcg_op_remove(s, op);
                op = prev_op;
                args[0] = prev_op_mb;
                break;

Is there something I am missing when you say merge?

>
>> +        case INDEX_op_ld8u_i32:
>> +        case INDEX_op_ld8u_i64:
>> +        case INDEX_op_ld8s_i32:
>> +        case INDEX_op_ld8s_i64:
>> +        case INDEX_op_ld16u_i32:
>> +        case INDEX_op_ld16u_i64:
>> +        case INDEX_op_ld16s_i32:
>> +        case INDEX_op_ld16s_i64:
>> +        case INDEX_op_ld_i32:
>> +        case INDEX_op_ld32u_i64:
>> +        case INDEX_op_ld32s_i64:
>> +        case INDEX_op_ld_i64:
>> +        case INDEX_op_st8_i32:
>> +        case INDEX_op_st8_i64:
>> +        case INDEX_op_st16_i32:
>> +        case INDEX_op_st16_i64:
>> +        case INDEX_op_st_i32:
>> +        case INDEX_op_st32_i64:
>> +        case INDEX_op_st_i64:
>
>
> None of these are guest memory operations.  These are host access to the ENV
> structure, primarily for cpu registers that aren't common enough to warrant
> a TCG temporary.
>
> You wanted to be checking for
>
>   INDEX_op_qemu_ld_i32
>   INDEX_op_qemu_ld_i64
>   INDEX_op_qemu_st_i32
>   INDEX_op_qemu_st_i64
>
> which are the guest memory operations.
>

Yes, I got confused. I will fix this.


>> +        case INDEX_op_call:
>> +            prev_op_mb = -1;
>> +            prev_op = NULL;
>> +            break;
>
>
> Probably you could skip the calls to "pure" helpers.  I.e. those with
> TCG_CALL_NO_RWG_SE.  But it's probably not that important and we can leave
> it for another day.
>
>
> r~



-- 
Pranith

      parent reply	other threads:[~2016-08-10 17:59 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-08-09 23:12 [Qemu-devel] [RFC v2 PATCH] tcg: Optimize fence instructions Pranith Kumar
2016-08-09 23:18 ` no-reply
     [not found] ` <9212daae-d1de-7e5b-f5a3-3a60e754de6a@twiddle.net>
2016-08-10 17:58   ` Pranith Kumar [this message]

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=CAJhHMCB6bL3qiz1ucwLyHq0GrT4mFiDA03q5C1zdX+aj_mJkgA@mail.gmail.com \
    --to=bobby.prani@gmail.com \
    --cc=alex.bennee@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=rth@twiddle.net \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).