tcg: Move in_code_gen_buffer and tests to region.c
Shortly, the full code_gen_buffer will only be visible to region.c, so move in_code_gen_buffer out-of-line. Move the debugging versions of tcg_splitwx_to_{rx,rw} to region.c as well, so that the compiler gets to see the implementation of in_code_gen_buffer. This leaves exactly one use of in_code_gen_buffer outside of region.c, in cpu_restore_state. Which, being on the exception path, is not performance critical. Reviewed-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Luis Pires <luis.pires@eldorado.org.br> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
a4df1b2d19
commit
47d590df34
@ -695,16 +695,7 @@ extern const void *tcg_code_gen_epilogue;
|
|||||||
extern uintptr_t tcg_splitwx_diff;
|
extern uintptr_t tcg_splitwx_diff;
|
||||||
extern TCGv_env cpu_env;
|
extern TCGv_env cpu_env;
|
||||||
|
|
||||||
static inline bool in_code_gen_buffer(const void *p)
|
bool in_code_gen_buffer(const void *p);
|
||||||
{
|
|
||||||
const TCGContext *s = &tcg_init_ctx;
|
|
||||||
/*
|
|
||||||
* Much like it is valid to have a pointer to the byte past the
|
|
||||||
* end of an array (so long as you don't dereference it), allow
|
|
||||||
* a pointer to the byte past the end of the code gen buffer.
|
|
||||||
*/
|
|
||||||
return (size_t)(p - s->code_gen_buffer) <= s->code_gen_buffer_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_TCG
|
#ifdef CONFIG_DEBUG_TCG
|
||||||
const void *tcg_splitwx_to_rx(void *rw);
|
const void *tcg_splitwx_to_rx(void *rw);
|
||||||
|
34
tcg/region.c
34
tcg/region.c
@ -68,6 +68,40 @@ static struct tcg_region_state region;
|
|||||||
static void *region_trees;
|
static void *region_trees;
|
||||||
static size_t tree_size;
|
static size_t tree_size;
|
||||||
|
|
||||||
|
bool in_code_gen_buffer(const void *p)
|
||||||
|
{
|
||||||
|
const TCGContext *s = &tcg_init_ctx;
|
||||||
|
/*
|
||||||
|
* Much like it is valid to have a pointer to the byte past the
|
||||||
|
* end of an array (so long as you don't dereference it), allow
|
||||||
|
* a pointer to the byte past the end of the code gen buffer.
|
||||||
|
*/
|
||||||
|
return (size_t)(p - s->code_gen_buffer) <= s->code_gen_buffer_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_DEBUG_TCG
|
||||||
|
const void *tcg_splitwx_to_rx(void *rw)
|
||||||
|
{
|
||||||
|
/* Pass NULL pointers unchanged. */
|
||||||
|
if (rw) {
|
||||||
|
g_assert(in_code_gen_buffer(rw));
|
||||||
|
rw += tcg_splitwx_diff;
|
||||||
|
}
|
||||||
|
return rw;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *tcg_splitwx_to_rw(const void *rx)
|
||||||
|
{
|
||||||
|
/* Pass NULL pointers unchanged. */
|
||||||
|
if (rx) {
|
||||||
|
rx -= tcg_splitwx_diff;
|
||||||
|
/* Assert that we end with a pointer in the rw region. */
|
||||||
|
g_assert(in_code_gen_buffer(rx));
|
||||||
|
}
|
||||||
|
return (void *)rx;
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_DEBUG_TCG */
|
||||||
|
|
||||||
/* compare a pointer @ptr and a tb_tc @s */
|
/* compare a pointer @ptr and a tb_tc @s */
|
||||||
static int ptr_cmp_tb_tc(const void *ptr, const struct tb_tc *s)
|
static int ptr_cmp_tb_tc(const void *ptr, const struct tb_tc *s)
|
||||||
{
|
{
|
||||||
|
23
tcg/tcg.c
23
tcg/tcg.c
@ -416,29 +416,6 @@ static const TCGTargetOpDef constraint_sets[] = {
|
|||||||
|
|
||||||
#include "tcg-target.c.inc"
|
#include "tcg-target.c.inc"
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_TCG
|
|
||||||
const void *tcg_splitwx_to_rx(void *rw)
|
|
||||||
{
|
|
||||||
/* Pass NULL pointers unchanged. */
|
|
||||||
if (rw) {
|
|
||||||
g_assert(in_code_gen_buffer(rw));
|
|
||||||
rw += tcg_splitwx_diff;
|
|
||||||
}
|
|
||||||
return rw;
|
|
||||||
}
|
|
||||||
|
|
||||||
void *tcg_splitwx_to_rw(const void *rx)
|
|
||||||
{
|
|
||||||
/* Pass NULL pointers unchanged. */
|
|
||||||
if (rx) {
|
|
||||||
rx -= tcg_splitwx_diff;
|
|
||||||
/* Assert that we end with a pointer in the rw region. */
|
|
||||||
g_assert(in_code_gen_buffer(rx));
|
|
||||||
}
|
|
||||||
return (void *)rx;
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_DEBUG_TCG */
|
|
||||||
|
|
||||||
static void alloc_tcg_plugin_context(TCGContext *s)
|
static void alloc_tcg_plugin_context(TCGContext *s)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_PLUGIN
|
#ifdef CONFIG_PLUGIN
|
||||||
|
Loading…
Reference in New Issue
Block a user