X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=cpu%2Fsh2%2Fcompiler.h;h=61d8d2dafbfd5da66e6b2b68be30ced9c2c897ed;hb=6a5b1b362ecf78ce2925068a5d938d319ff583a3;hp=1d127a14040c13382ddc5eb5238617b83dc205e1;hpb=679af8a3f466a2a4a20f58e4181a231fb73e9836;p=picodrive.git diff --git a/cpu/sh2/compiler.h b/cpu/sh2/compiler.h index 1d127a1..61d8d2d 100644 --- a/cpu/sh2/compiler.h +++ b/cpu/sh2/compiler.h @@ -1,2 +1,27 @@ +int sh2_drc_init(SH2 *sh2); +void sh2_drc_finish(SH2 *sh2); +void sh2_drc_wcheck_ram(unsigned int a, int val, int cpuid); +void sh2_drc_wcheck_da(unsigned int a, int val, int cpuid); -int sh2_drc_init(SH2 *sh2); +#ifdef DRC_SH2 +void sh2_drc_mem_setup(SH2 *sh2); +void sh2_drc_flush_all(void); +void sh2_drc_frame(void); +#else +#define sh2_drc_mem_setup(x) +#define sh2_drc_flush_all() +#define sh2_drc_frame() +#endif + +#define BLOCK_INSN_LIMIT 128 + +/* op_flags */ +#define OF_DELAY_OP (1 << 0) +#define OF_BTARGET (1 << 1) +#define OF_T_SET (1 << 2) // T is known to be set +#define OF_T_CLEAR (1 << 3) // ... clear +#define OF_B_IN_DS (1 << 4) + +void scan_block(unsigned int base_pc, int is_slave, + unsigned char *op_flags, unsigned int *end_pc, + unsigned int *end_literals);