From: Aurelien Jarno <aurelien@aurel32.net>
To: qemu-devel@nongnu.org
Cc: Aurelien Jarno <aurelien@aurel32.net>
Subject: [Qemu-devel] [PATCH v2 0/9] Improve TCG optimizer
Date: Fri, 7 Sep 2012 15:16:23 +0200 [thread overview]
Message-ID: <1347023792-24045-1-git-send-email-aurelien@aurel32.net> (raw)
This patch series improves the TCG optimizer, based on patterns found
while executing various guest. The brcond ad setcond constant folding
are useful especially useful when they are used to avoid some argument
values (e.g. division by 0), and thus can be optimized when this argument
is a constant.
This bring around 0.5% improvement on openssl like benchmarks.
Modifications between V1 and V2 following feedback I got:
- In the first patch, account for the liveness analysis time and
optimizing pass time separately
- Fixed swith/break in patch 7 to correctly throw an error
- Added patch 9 to make the code more readable
Other patches are unmodified.
Aurelien Jarno (9):
tcg: improve profiler
tcg/optimize: split expression simplification
tcg/optimize: simplify or/xor r, a, 0 cases
tcg/optimize: simplify and r, a, 0 cases
tcg/optimize: simplify shift/rot r, 0, a => movi r, 0 cases
tcg/optimize: swap brcond/setcond arguments when possible
tcg/optimize: add constant folding for setcond
tcg/optimize: add constant folding for brcond
tcg/optimize: fix if/else/break coding style
tcg/optimize.c | 179 +++++++++++++++++++++++++++++++++++++++++++++++++++-----
tcg/tcg.c | 12 +++-
tcg/tcg.h | 1 +
3 files changed, 175 insertions(+), 17 deletions(-)
--
1.7.10.4
next reply other threads:[~2012-09-07 13:16 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-09-07 13:16 Aurelien Jarno [this message]
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 1/9] tcg: improve profiler Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 2/9] tcg/optimize: split expression simplification Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 3/9] tcg/optimize: simplify or/xor r, a, 0 cases Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 4/9] tcg/optimize: simplify and " Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 5/9] tcg/optimize: simplify shift/rot r, 0, a => movi r, " Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 6/9] tcg/optimize: swap brcond/setcond arguments when possible Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 7/9] tcg/optimize: add constant folding for setcond Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 8/9] tcg/optimize: add constant folding for brcond Aurelien Jarno
2012-09-07 13:16 ` [Qemu-devel] [PATCH v2 9/9] tcg/optimize: fix if/else/break coding style Aurelien Jarno
2012-09-08 8:18 ` [Qemu-devel] [PATCH v2 0/9] Improve TCG optimizer Blue Swirl
2012-09-08 9:01 ` Aurelien Jarno
2012-09-08 9:06 ` Blue Swirl
2012-09-08 9:12 ` Aurelien Jarno
2012-09-08 9:29 ` Blue Swirl
2012-09-08 9:35 ` Aurelien Jarno
2012-09-10 13:55 ` Richard Henderson
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=1347023792-24045-1-git-send-email-aurelien@aurel32.net \
--to=aurelien@aurel32.net \
--cc=qemu-devel@nongnu.org \
/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).