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 TCGv_env cpu_env;
|
||||
|
||||
static inline 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;
|
||||
}
|
||||
bool in_code_gen_buffer(const void *p);
|
||||
|
||||
#ifdef CONFIG_DEBUG_TCG
|
||||
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 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 */
|
||||
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"
|
||||
|
||||
#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)
|
||||
{
|
||||
#ifdef CONFIG_PLUGIN
|
||||
|
Loading…
Reference in New Issue
Block a user