From: Richard Henderson <richard.henderson@linaro.org>
To: qemu-devel@nongnu.org
Cc: qemu-arm@nongnu.org
Subject: Re: [PATCH 0/4] tcg/aarch64: Enable BTI within the JIT
Date: Sat, 9 Sep 2023 13:50:12 -0700 [thread overview]
Message-ID: <88a0cad9-a742-01c9-af7f-b7b0c09a20cc@linaro.org> (raw)
In-Reply-To: <20230816142516.469743-1-richard.henderson@linaro.org>
Ping. Patch 3 still missing review.
On 8/16/23 07:25, Richard Henderson wrote:
> Patch 1 is cherry-picked from
>
> [PATCH v3 02/14] tcg: Add tcg_out_tb_start backend hook
> https://lore.kernel.org/qemu-devel/20230815195741.8325-3-richard.henderson@linaro.org/T/#u
>
> here used for a different application.
>
> There are not as many landing pads as I had imagined, so the
> overhead here is really quite minimal.
>
> The architecture enables the check only when the PTE for the
> jump target is marked "guarded". Linux implements this by
> adding a PROT_BTI bit for mmap and mprotect. I have isolated
> this within a host_prot_read_exec() local function, which
> seems clean enough. So far, as far as I can tell, Linux it
> the only OS to support BTI.
>
>
> r~
>
>
> Richard Henderson (4):
> tcg: Add tcg_out_tb_start backend hook
> util/cpuinfo-aarch64: Add CPUINFO_BTI
> tcg/aarch64: Emit BTI insns at jump landing pads
> tcg: Map code_gen_buffer with PROT_BTI
>
> host/include/aarch64/host/cpuinfo.h | 1 +
> tcg/region.c | 39 ++++++++++++++++------
> tcg/tcg.c | 3 ++
> util/cpuinfo-aarch64.c | 4 +++
> tcg/aarch64/tcg-target.c.inc | 52 +++++++++++++++++++++--------
> tcg/arm/tcg-target.c.inc | 5 +++
> tcg/i386/tcg-target.c.inc | 5 +++
> tcg/loongarch64/tcg-target.c.inc | 5 +++
> tcg/mips/tcg-target.c.inc | 5 +++
> tcg/ppc/tcg-target.c.inc | 5 +++
> tcg/riscv/tcg-target.c.inc | 5 +++
> tcg/s390x/tcg-target.c.inc | 5 +++
> tcg/sparc64/tcg-target.c.inc | 5 +++
> tcg/tci/tcg-target.c.inc | 5 +++
> 14 files changed, 119 insertions(+), 25 deletions(-)
>
prev parent reply other threads:[~2023-09-09 20:50 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-16 14:25 [PATCH 0/4] tcg/aarch64: Enable BTI within the JIT Richard Henderson
2023-08-16 14:25 ` [PATCH 1/4] tcg: Add tcg_out_tb_start backend hook Richard Henderson
2023-08-16 21:38 ` Philippe Mathieu-Daudé
2023-08-16 14:25 ` [PATCH 2/4] util/cpuinfo-aarch64: Add CPUINFO_BTI Richard Henderson
2023-08-16 21:37 ` Philippe Mathieu-Daudé
2023-08-16 14:25 ` [PATCH 3/4] tcg/aarch64: Emit BTI insns at jump landing pads Richard Henderson
2023-09-12 16:23 ` Peter Maydell
2023-08-16 14:25 ` [PATCH 4/4] tcg: Map code_gen_buffer with PROT_BTI Richard Henderson
2023-08-16 22:13 ` Philippe Mathieu-Daudé
2023-09-09 20:50 ` Richard Henderson [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=88a0cad9-a742-01c9-af7f-b7b0c09a20cc@linaro.org \
--to=richard.henderson@linaro.org \
--cc=qemu-arm@nongnu.org \
--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).