tcg: Add comments for all optional instructions not implemented.
Signed-off-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
18c8f7a35d
commit
3682825669
@ -63,6 +63,20 @@ enum {
|
|||||||
#define TCG_TARGET_STACK_ALIGN 8
|
#define TCG_TARGET_STACK_ALIGN 8
|
||||||
#define TCG_TARGET_CALL_STACK_OFFSET 0
|
#define TCG_TARGET_CALL_STACK_OFFSET 0
|
||||||
|
|
||||||
|
/* 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_not_i32
|
||||||
|
// #define TCG_TARGET_HAS_neg_i32
|
||||||
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
#define TCG_TARGET_HAS_GUEST_BASE
|
#define TCG_TARGET_HAS_GUEST_BASE
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -45,15 +45,17 @@ enum {
|
|||||||
#define TCG_TARGET_CALL_STACK_OFFSET 0
|
#define TCG_TARGET_CALL_STACK_OFFSET 0
|
||||||
|
|
||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
|
#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_bswap16_i32
|
||||||
#define TCG_TARGET_HAS_bswap32_i32
|
#define TCG_TARGET_HAS_bswap32_i32
|
||||||
#define TCG_TARGET_HAS_neg_i32
|
#define TCG_TARGET_HAS_neg_i32
|
||||||
#define TCG_TARGET_HAS_not_i32
|
#define TCG_TARGET_HAS_not_i32
|
||||||
#define TCG_TARGET_HAS_ext8s_i32
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
#define TCG_TARGET_HAS_ext16s_i32
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
#define TCG_TARGET_HAS_rot_i32
|
|
||||||
#define TCG_TARGET_HAS_ext8u_i32
|
|
||||||
#define TCG_TARGET_HAS_ext16u_i32
|
|
||||||
|
|
||||||
#define TCG_TARGET_HAS_GUEST_BASE
|
#define TCG_TARGET_HAS_GUEST_BASE
|
||||||
|
|
||||||
|
@ -80,11 +80,13 @@ enum {
|
|||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
#define TCG_TARGET_HAS_div_i32
|
#define TCG_TARGET_HAS_div_i32
|
||||||
#define TCG_TARGET_HAS_not_i32
|
#define TCG_TARGET_HAS_not_i32
|
||||||
|
#undef TCG_TARGET_HAS_rot_i32
|
||||||
#undef TCG_TARGET_HAS_ext8s_i32
|
#undef TCG_TARGET_HAS_ext8s_i32
|
||||||
#undef TCG_TARGET_HAS_ext16s_i32
|
#undef TCG_TARGET_HAS_ext16s_i32
|
||||||
#undef TCG_TARGET_HAS_bswap32_i32
|
#undef TCG_TARGET_HAS_bswap32_i32
|
||||||
#undef TCG_TARGET_HAS_bswap16_i32
|
#undef TCG_TARGET_HAS_bswap16_i32
|
||||||
#undef TCG_TARGET_HAS_rot_i32
|
#undef TCG_TARGET_HAS_andc_i32
|
||||||
|
#undef TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
/* optional instructions automatically implemented */
|
/* optional instructions automatically implemented */
|
||||||
#undef TCG_TARGET_HAS_neg_i32 /* sub rd, zero, rt */
|
#undef TCG_TARGET_HAS_neg_i32 /* sub rd, zero, rt */
|
||||||
|
@ -77,10 +77,18 @@ enum {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
#define TCG_TARGET_HAS_neg_i32
|
|
||||||
#define TCG_TARGET_HAS_div_i32
|
#define TCG_TARGET_HAS_div_i32
|
||||||
|
// #define TCG_TARGET_HAS_rot_i32
|
||||||
#define TCG_TARGET_HAS_ext8s_i32
|
#define TCG_TARGET_HAS_ext8s_i32
|
||||||
#define TCG_TARGET_HAS_ext16s_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_not_i32
|
||||||
|
#define TCG_TARGET_HAS_neg_i32
|
||||||
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
#define TCG_AREG0 TCG_REG_R27
|
#define TCG_AREG0 TCG_REG_R27
|
||||||
#define TCG_AREG1 TCG_REG_R24
|
#define TCG_AREG1 TCG_REG_R24
|
||||||
|
@ -68,15 +68,34 @@ enum {
|
|||||||
#define TCG_TARGET_CALL_STACK_OFFSET 48
|
#define TCG_TARGET_CALL_STACK_OFFSET 48
|
||||||
|
|
||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
#define TCG_TARGET_HAS_neg_i32
|
|
||||||
#define TCG_TARGET_HAS_div_i32
|
#define TCG_TARGET_HAS_div_i32
|
||||||
#define TCG_TARGET_HAS_neg_i64
|
// #define TCG_TARGET_HAS_rot_i32
|
||||||
#define TCG_TARGET_HAS_div_i64
|
|
||||||
#define TCG_TARGET_HAS_ext8s_i32
|
#define TCG_TARGET_HAS_ext8s_i32
|
||||||
#define TCG_TARGET_HAS_ext16s_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_not_i32
|
||||||
|
#define TCG_TARGET_HAS_neg_i32
|
||||||
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
|
#define TCG_TARGET_HAS_div_i64
|
||||||
|
// #define TCG_TARGET_HAS_rot_i64
|
||||||
#define TCG_TARGET_HAS_ext8s_i64
|
#define TCG_TARGET_HAS_ext8s_i64
|
||||||
#define TCG_TARGET_HAS_ext16s_i64
|
#define TCG_TARGET_HAS_ext16s_i64
|
||||||
#define TCG_TARGET_HAS_ext32s_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_not_i64
|
||||||
|
#define TCG_TARGET_HAS_neg_i64
|
||||||
|
// #define TCG_TARGET_HAS_andc_i64
|
||||||
|
// #define TCG_TARGET_HAS_orc_i64
|
||||||
|
|
||||||
#define TCG_AREG0 TCG_REG_R27
|
#define TCG_AREG0 TCG_REG_R27
|
||||||
#define TCG_AREG1 TCG_REG_R24
|
#define TCG_AREG1 TCG_REG_R24
|
||||||
|
@ -46,6 +46,36 @@ enum {
|
|||||||
};
|
};
|
||||||
#define TCG_TARGET_NB_REGS 16
|
#define TCG_TARGET_NB_REGS 16
|
||||||
|
|
||||||
|
/* 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_not_i32
|
||||||
|
// #define TCG_TARGET_HAS_neg_i32
|
||||||
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
|
// #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_not_i64
|
||||||
|
// #define TCG_TARGET_HAS_neg_i64
|
||||||
|
// #define TCG_TARGET_HAS_andc_i64
|
||||||
|
// #define TCG_TARGET_HAS_orc_i64
|
||||||
|
|
||||||
/* used for function call generation */
|
/* used for function call generation */
|
||||||
#define TCG_REG_CALL_STACK TCG_REG_R15
|
#define TCG_REG_CALL_STACK TCG_REG_R15
|
||||||
#define TCG_TARGET_STACK_ALIGN 8
|
#define TCG_TARGET_STACK_ALIGN 8
|
||||||
|
@ -89,26 +89,36 @@ enum {
|
|||||||
|
|
||||||
/* optional instructions */
|
/* optional instructions */
|
||||||
#define TCG_TARGET_HAS_div_i32
|
#define TCG_TARGET_HAS_div_i32
|
||||||
#define TCG_TARGET_HAS_div_i64
|
// #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_neg_i32
|
||||||
#define TCG_TARGET_HAS_not_i32
|
#define TCG_TARGET_HAS_not_i32
|
||||||
#define TCG_TARGET_HAS_andc_i32
|
#define TCG_TARGET_HAS_andc_i32
|
||||||
#define TCG_TARGET_HAS_orc_i32
|
#define TCG_TARGET_HAS_orc_i32
|
||||||
|
|
||||||
#if TCG_TARGET_REG_BITS == 64
|
#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_ext32s_i64
|
||||||
|
// #define TCG_TARGET_HAS_ext8u_i64
|
||||||
|
// #define TCG_TARGET_HAS_ext16u_i64
|
||||||
#define TCG_TARGET_HAS_ext32u_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_neg_i64
|
||||||
#define TCG_TARGET_HAS_not_i64
|
#define TCG_TARGET_HAS_not_i64
|
||||||
#define TCG_TARGET_HAS_andc_i64
|
#define TCG_TARGET_HAS_andc_i64
|
||||||
#define TCG_TARGET_HAS_orc_i64
|
#define TCG_TARGET_HAS_orc_i64
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//#define TCG_TARGET_HAS_bswap32_i32
|
|
||||||
//#define TCG_TARGET_HAS_bswap64_i64
|
|
||||||
|
|
||||||
|
|
||||||
/* Note: must be synced with dyngen-exec.h and Makefile.target */
|
/* Note: must be synced with dyngen-exec.h and Makefile.target */
|
||||||
#ifdef CONFIG_SOLARIS
|
#ifdef CONFIG_SOLARIS
|
||||||
#define TCG_AREG0 TCG_REG_G2
|
#define TCG_AREG0 TCG_REG_G2
|
||||||
|
@ -75,10 +75,14 @@ enum {
|
|||||||
#define TCG_TARGET_HAS_ext8u_i64
|
#define TCG_TARGET_HAS_ext8u_i64
|
||||||
#define TCG_TARGET_HAS_ext16u_i64
|
#define TCG_TARGET_HAS_ext16u_i64
|
||||||
#define TCG_TARGET_HAS_ext32u_i64
|
#define TCG_TARGET_HAS_ext32u_i64
|
||||||
|
|
||||||
#define TCG_TARGET_HAS_rot_i32
|
#define TCG_TARGET_HAS_rot_i32
|
||||||
#define TCG_TARGET_HAS_rot_i64
|
#define TCG_TARGET_HAS_rot_i64
|
||||||
|
|
||||||
|
// #define TCG_TARGET_HAS_andc_i32
|
||||||
|
// #define TCG_TARGET_HAS_andc_i64
|
||||||
|
// #define TCG_TARGET_HAS_orc_i32
|
||||||
|
// #define TCG_TARGET_HAS_orc_i64
|
||||||
|
|
||||||
#define TCG_TARGET_HAS_GUEST_BASE
|
#define TCG_TARGET_HAS_GUEST_BASE
|
||||||
|
|
||||||
/* Note: must be synced with dyngen-exec.h */
|
/* Note: must be synced with dyngen-exec.h */
|
||||||
|
Loading…
Reference in New Issue
Block a user