mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
tcg: Always define all of the TCGOpcode enum members.
By always defining these symbols, we can eliminate a lot of ifdefs. To allow this to be checked reliably, the semantics of the TCG_TARGET_HAS_* macros must be changed from def/undef to true/false. This allows even more ifdefs to be removed, converting them into C if statements. Signed-off-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
8399ad59e7
commit
25c4d9cc84
14 changed files with 832 additions and 1003 deletions
|
@ -92,41 +92,43 @@ enum {
|
|||
#endif
|
||||
|
||||
/* optional instructions */
|
||||
#define TCG_TARGET_HAS_div_i32
|
||||
// #define TCG_TARGET_HAS_rot_i32
|
||||
// #define TCG_TARGET_HAS_ext8s_i32
|
||||
// #define TCG_TARGET_HAS_ext16s_i32
|
||||
// #define TCG_TARGET_HAS_ext8u_i32
|
||||
// #define TCG_TARGET_HAS_ext16u_i32
|
||||
// #define TCG_TARGET_HAS_bswap16_i32
|
||||
// #define TCG_TARGET_HAS_bswap32_i32
|
||||
#define TCG_TARGET_HAS_neg_i32
|
||||
#define TCG_TARGET_HAS_not_i32
|
||||
#define TCG_TARGET_HAS_andc_i32
|
||||
#define TCG_TARGET_HAS_orc_i32
|
||||
// #define TCG_TARGET_HAS_eqv_i32
|
||||
// #define TCG_TARGET_HAS_nand_i32
|
||||
// #define TCG_TARGET_HAS_nor_i32
|
||||
#define TCG_TARGET_HAS_div_i32 1
|
||||
#define TCG_TARGET_HAS_rot_i32 0
|
||||
#define TCG_TARGET_HAS_ext8s_i32 0
|
||||
#define TCG_TARGET_HAS_ext16s_i32 0
|
||||
#define TCG_TARGET_HAS_ext8u_i32 0
|
||||
#define TCG_TARGET_HAS_ext16u_i32 0
|
||||
#define TCG_TARGET_HAS_bswap16_i32 0
|
||||
#define TCG_TARGET_HAS_bswap32_i32 0
|
||||
#define TCG_TARGET_HAS_neg_i32 1
|
||||
#define TCG_TARGET_HAS_not_i32 1
|
||||
#define TCG_TARGET_HAS_andc_i32 1
|
||||
#define TCG_TARGET_HAS_orc_i32 1
|
||||
#define TCG_TARGET_HAS_eqv_i32 0
|
||||
#define TCG_TARGET_HAS_nand_i32 0
|
||||
#define TCG_TARGET_HAS_nor_i32 0
|
||||
#define TCG_TARGET_HAS_deposit_i32 0
|
||||
|
||||
#if TCG_TARGET_REG_BITS == 64
|
||||
#define TCG_TARGET_HAS_div_i64
|
||||
// #define TCG_TARGET_HAS_rot_i64
|
||||
// #define TCG_TARGET_HAS_ext8s_i64
|
||||
// #define TCG_TARGET_HAS_ext16s_i64
|
||||
#define TCG_TARGET_HAS_ext32s_i64
|
||||
// #define TCG_TARGET_HAS_ext8u_i64
|
||||
// #define TCG_TARGET_HAS_ext16u_i64
|
||||
#define TCG_TARGET_HAS_ext32u_i64
|
||||
// #define TCG_TARGET_HAS_bswap16_i64
|
||||
// #define TCG_TARGET_HAS_bswap32_i64
|
||||
// #define TCG_TARGET_HAS_bswap64_i64
|
||||
#define TCG_TARGET_HAS_neg_i64
|
||||
#define TCG_TARGET_HAS_not_i64
|
||||
#define TCG_TARGET_HAS_andc_i64
|
||||
#define TCG_TARGET_HAS_orc_i64
|
||||
// #define TCG_TARGET_HAS_eqv_i64
|
||||
// #define TCG_TARGET_HAS_nand_i64
|
||||
// #define TCG_TARGET_HAS_nor_i64
|
||||
#define TCG_TARGET_HAS_div_i64 1
|
||||
#define TCG_TARGET_HAS_rot_i64 0
|
||||
#define TCG_TARGET_HAS_ext8s_i64 0
|
||||
#define TCG_TARGET_HAS_ext16s_i64 0
|
||||
#define TCG_TARGET_HAS_ext32s_i64 1
|
||||
#define TCG_TARGET_HAS_ext8u_i64 0
|
||||
#define TCG_TARGET_HAS_ext16u_i64 0
|
||||
#define TCG_TARGET_HAS_ext32u_i64 1
|
||||
#define TCG_TARGET_HAS_bswap16_i64 0
|
||||
#define TCG_TARGET_HAS_bswap32_i64 0
|
||||
#define TCG_TARGET_HAS_bswap64_i64 0
|
||||
#define TCG_TARGET_HAS_neg_i64 1
|
||||
#define TCG_TARGET_HAS_not_i64 1
|
||||
#define TCG_TARGET_HAS_andc_i64 1
|
||||
#define TCG_TARGET_HAS_orc_i64 1
|
||||
#define TCG_TARGET_HAS_eqv_i64 0
|
||||
#define TCG_TARGET_HAS_nand_i64 0
|
||||
#define TCG_TARGET_HAS_nor_i64 0
|
||||
#define TCG_TARGET_HAS_deposit_i64 0
|
||||
#endif
|
||||
|
||||
/* Note: must be synced with dyngen-exec.h */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue