mirror of https://github.com/xemu-project/xemu.git
tcg: Split helper-proto.h
Create helper-proto-common.h without the target specific portion. Use that in tcg-op-common.h. Include helper-proto.h in target/arm and target/hexagon before helper-info.c.inc; all other targets are already correct in this regard. Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
e4eff8e4ed
commit
c213ee2dfc
|
@ -29,7 +29,7 @@
|
||||||
#include "tcg/tcg.h"
|
#include "tcg/tcg.h"
|
||||||
#include "qemu/error-report.h"
|
#include "qemu/error-report.h"
|
||||||
#include "exec/log.h"
|
#include "exec/log.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto-common.h"
|
||||||
#include "qemu/atomic.h"
|
#include "qemu/atomic.h"
|
||||||
#include "qemu/atomic128.h"
|
#include "qemu/atomic128.h"
|
||||||
#include "exec/translate-all.h"
|
#include "exec/translate-all.h"
|
||||||
|
@ -41,7 +41,6 @@
|
||||||
#endif
|
#endif
|
||||||
#include "tcg/tcg-ldst.h"
|
#include "tcg/tcg-ldst.h"
|
||||||
#include "tcg/oversized-guest.h"
|
#include "tcg/oversized-guest.h"
|
||||||
#include "exec/helper-proto.h"
|
|
||||||
|
|
||||||
/* DEBUG defines, enable DEBUG_TLB_LOG to log to the CPU_LOG_MMU target */
|
/* DEBUG defines, enable DEBUG_TLB_LOG to log to the CPU_LOG_MMU target */
|
||||||
/* #define DEBUG_TLB */
|
/* #define DEBUG_TLB */
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "exec/plugin-gen.h"
|
#include "exec/plugin-gen.h"
|
||||||
#include "exec/translator.h"
|
#include "exec/translator.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto-common.h"
|
||||||
|
|
||||||
#define HELPER_H "accel/tcg/plugin-helpers.h"
|
#define HELPER_H "accel/tcg/plugin-helpers.h"
|
||||||
#include "exec/helper-info.c.inc"
|
#include "exec/helper-info.c.inc"
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qemu/host-utils.h"
|
#include "qemu/host-utils.h"
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto-common.h"
|
||||||
#include "tcg/tcg-gvec-desc.h"
|
#include "tcg/tcg-gvec-desc.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qemu/host-utils.h"
|
#include "qemu/host-utils.h"
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto-common.h"
|
||||||
#include "exec/cpu_ldst.h"
|
#include "exec/cpu_ldst.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "disas/disas.h"
|
#include "disas/disas.h"
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Helper file for declaring TCG helper functions.
|
||||||
|
* This one expands prototypes for the helper functions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef HELPER_PROTO_COMMON_H
|
||||||
|
#define HELPER_PROTO_COMMON_H
|
||||||
|
|
||||||
|
#define HELPER_H "accel/tcg/tcg-runtime.h"
|
||||||
|
#include "exec/helper-proto.h.inc"
|
||||||
|
#undef HELPER_H
|
||||||
|
|
||||||
|
#define HELPER_H "accel/tcg/plugin-helpers.h"
|
||||||
|
#include "exec/helper-proto.h.inc"
|
||||||
|
#undef HELPER_H
|
||||||
|
|
||||||
|
#endif /* HELPER_PROTO_COMMON_H */
|
|
@ -1,71 +1,16 @@
|
||||||
/* Helper file for declaring TCG helper functions.
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
This one expands prototypes for the helper functions. */
|
/*
|
||||||
|
* Helper file for declaring TCG helper functions.
|
||||||
|
* This one expands prototypes for the helper functions.
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef HELPER_PROTO_H
|
#ifndef HELPER_PROTO_H
|
||||||
#define HELPER_PROTO_H
|
#define HELPER_PROTO_H
|
||||||
|
|
||||||
#include "exec/helper-head.h"
|
#include "exec/helper-proto-common.h"
|
||||||
|
|
||||||
/*
|
#define HELPER_H "helper.h"
|
||||||
* Work around an issue with --enable-lto, in which GCC's ipa-split pass
|
#include "exec/helper-proto.h.inc"
|
||||||
* decides to split out the noreturn code paths that raise an exception,
|
#undef HELPER_H
|
||||||
* taking the __builtin_return_address() along into the new function,
|
|
||||||
* where it no longer computes a value that returns to TCG generated code.
|
|
||||||
* Despite the name, the noinline attribute affects splitter, so this
|
|
||||||
* prevents the optimization in question. Given that helpers should not
|
|
||||||
* otherwise be called directly, this should have any other visible effect.
|
|
||||||
*
|
|
||||||
* See https://gitlab.com/qemu-project/qemu/-/issues/1454
|
|
||||||
*/
|
|
||||||
#define DEF_HELPER_ATTR __attribute__((noinline))
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_0(name, flags, ret) \
|
|
||||||
dh_ctype(ret) HELPER(name) (void) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_1(name, flags, ret, t1) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_2(name, flags, ret, t1, t2) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_3(name, flags, ret, t1, t2, t3) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), \
|
|
||||||
dh_ctype(t3)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_4(name, flags, ret, t1, t2, t3, t4) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
|
||||||
dh_ctype(t4)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_5(name, flags, ret, t1, t2, t3, t4, t5) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
|
||||||
dh_ctype(t4), dh_ctype(t5)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_6(name, flags, ret, t1, t2, t3, t4, t5, t6) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
|
||||||
dh_ctype(t4), dh_ctype(t5), \
|
|
||||||
dh_ctype(t6)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define DEF_HELPER_FLAGS_7(name, flags, ret, t1, t2, t3, t4, t5, t6, t7) \
|
|
||||||
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
|
||||||
dh_ctype(t4), dh_ctype(t5), dh_ctype(t6), \
|
|
||||||
dh_ctype(t7)) DEF_HELPER_ATTR;
|
|
||||||
|
|
||||||
#define IN_HELPER_PROTO
|
|
||||||
|
|
||||||
#include "helper.h"
|
|
||||||
#include "accel/tcg/tcg-runtime.h"
|
|
||||||
#include "accel/tcg/plugin-helpers.h"
|
|
||||||
|
|
||||||
#undef IN_HELPER_PROTO
|
|
||||||
|
|
||||||
#undef DEF_HELPER_FLAGS_0
|
|
||||||
#undef DEF_HELPER_FLAGS_1
|
|
||||||
#undef DEF_HELPER_FLAGS_2
|
|
||||||
#undef DEF_HELPER_FLAGS_3
|
|
||||||
#undef DEF_HELPER_FLAGS_4
|
|
||||||
#undef DEF_HELPER_FLAGS_5
|
|
||||||
#undef DEF_HELPER_FLAGS_6
|
|
||||||
#undef DEF_HELPER_FLAGS_7
|
|
||||||
#undef DEF_HELPER_ATTR
|
|
||||||
|
|
||||||
#endif /* HELPER_PROTO_H */
|
#endif /* HELPER_PROTO_H */
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Helper file for declaring TCG helper functions.
|
||||||
|
* This one expands prototypes for the helper functions.
|
||||||
|
* Define HELPER_H for the header file to be expanded.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "exec/helper-head.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Work around an issue with --enable-lto, in which GCC's ipa-split pass
|
||||||
|
* decides to split out the noreturn code paths that raise an exception,
|
||||||
|
* taking the __builtin_return_address() along into the new function,
|
||||||
|
* where it no longer computes a value that returns to TCG generated code.
|
||||||
|
* Despite the name, the noinline attribute affects splitter, so this
|
||||||
|
* prevents the optimization in question. Given that helpers should not
|
||||||
|
* otherwise be called directly, this should not have any other visible effect.
|
||||||
|
*
|
||||||
|
* See https://gitlab.com/qemu-project/qemu/-/issues/1454
|
||||||
|
*/
|
||||||
|
#define DEF_HELPER_ATTR __attribute__((noinline))
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_0(name, flags, ret) \
|
||||||
|
dh_ctype(ret) HELPER(name) (void) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_1(name, flags, ret, t1) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_2(name, flags, ret, t1, t2) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_3(name, flags, ret, t1, t2, t3) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), \
|
||||||
|
dh_ctype(t3)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_4(name, flags, ret, t1, t2, t3, t4) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
||||||
|
dh_ctype(t4)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_5(name, flags, ret, t1, t2, t3, t4, t5) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
||||||
|
dh_ctype(t4), dh_ctype(t5)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_6(name, flags, ret, t1, t2, t3, t4, t5, t6) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
||||||
|
dh_ctype(t4), dh_ctype(t5), \
|
||||||
|
dh_ctype(t6)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define DEF_HELPER_FLAGS_7(name, flags, ret, t1, t2, t3, t4, t5, t6, t7) \
|
||||||
|
dh_ctype(ret) HELPER(name) (dh_ctype(t1), dh_ctype(t2), dh_ctype(t3), \
|
||||||
|
dh_ctype(t4), dh_ctype(t5), dh_ctype(t6), \
|
||||||
|
dh_ctype(t7)) DEF_HELPER_ATTR;
|
||||||
|
|
||||||
|
#define IN_HELPER_PROTO
|
||||||
|
|
||||||
|
#include HELPER_H
|
||||||
|
|
||||||
|
#undef IN_HELPER_PROTO
|
||||||
|
|
||||||
|
#undef DEF_HELPER_FLAGS_0
|
||||||
|
#undef DEF_HELPER_FLAGS_1
|
||||||
|
#undef DEF_HELPER_FLAGS_2
|
||||||
|
#undef DEF_HELPER_FLAGS_3
|
||||||
|
#undef DEF_HELPER_FLAGS_4
|
||||||
|
#undef DEF_HELPER_FLAGS_5
|
||||||
|
#undef DEF_HELPER_FLAGS_6
|
||||||
|
#undef DEF_HELPER_FLAGS_7
|
||||||
|
#undef DEF_HELPER_ATTR
|
|
@ -9,7 +9,7 @@
|
||||||
#define TCG_TCG_OP_COMMON_H
|
#define TCG_TCG_OP_COMMON_H
|
||||||
|
|
||||||
#include "tcg/tcg.h"
|
#include "tcg/tcg.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto-common.h"
|
||||||
#include "exec/helper-gen-common.h"
|
#include "exec/helper-gen-common.h"
|
||||||
|
|
||||||
/* Basic output routines. Not for general consumption. */
|
/* Basic output routines. Not for general consumption. */
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include "translate.h"
|
#include "translate.h"
|
||||||
#include "translate-a32.h"
|
#include "translate-a32.h"
|
||||||
#include "exec/gen-icount.h"
|
#include "exec/gen-icount.h"
|
||||||
|
#include "exec/helper-proto.h"
|
||||||
|
|
||||||
#define HELPER_H "helper.h"
|
#define HELPER_H "helper.h"
|
||||||
#include "exec/helper-info.c.inc"
|
#include "exec/helper-info.c.inc"
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "tcg/tcg-op.h"
|
#include "tcg/tcg-op.h"
|
||||||
#include "tcg/tcg-op-gvec.h"
|
#include "tcg/tcg-op-gvec.h"
|
||||||
#include "exec/helper-gen.h"
|
#include "exec/helper-gen.h"
|
||||||
|
#include "exec/helper-proto.h"
|
||||||
#include "exec/cpu_ldst.h"
|
#include "exec/cpu_ldst.h"
|
||||||
#include "exec/log.h"
|
#include "exec/log.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
Loading…
Reference in New Issue