X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=cpu%2Fsh2%2Fcompiler.h;h=ef1944b439ac1acbf958e56c51c2b2569b9f16eb;hb=20a10d3ed94e12bfc0f415e186f0da5bc4efac49;hp=1d127a14040c13382ddc5eb5238617b83dc205e1;hpb=679af8a3f466a2a4a20f58e4181a231fb73e9836;p=picodrive.git diff --git a/cpu/sh2/compiler.h b/cpu/sh2/compiler.h index 1d127a1..ef1944b 100644 --- a/cpu/sh2/compiler.h +++ b/cpu/sh2/compiler.h @@ -1,2 +1,26 @@ +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 + +void scan_block(unsigned int base_pc, int is_slave, + unsigned char *op_flags, unsigned int *end_pc, + unsigned int *end_literals);