Skip to content

Commit

Permalink
sh2 drc, fixes for cache handling on arm and mips cpus
Browse files Browse the repository at this point in the history
  • Loading branch information
irixxxx committed Oct 27, 2020
1 parent e7faa8e commit 69c2251
Show file tree
Hide file tree
Showing 3 changed files with 7 additions and 8 deletions.
2 changes: 1 addition & 1 deletion cpu/drc/emit_arm.c
Original file line number Diff line number Diff line change
Expand Up @@ -1247,7 +1247,7 @@ static inline void emith_pool_adjust(int tcache_offs, int move_offs)
} while (0)

#define host_instructions_updated(base, end, force) \
do { if (force) __builtin___clear_cache(base, end); } while (0)
do { if (force) emith_update_add(base, end); } while (0)

#define host_arg2reg(rd, arg) \
rd = arg
Expand Down
9 changes: 4 additions & 5 deletions cpu/drc/emit_mips.c
Original file line number Diff line number Diff line change
Expand Up @@ -1573,11 +1573,10 @@ static NOINLINE void host_instructions_updated(void *base, void *end, int force)
{
int step, tmp;
asm volatile(
" bal 0f;" // needed to allow for jr.hb
" b 3f;"

"0: rdhwr %2, $1;"
" beqz %2, 2f;"
" rdhwr %2, $1;"
" bal 0f;" // needed to allow for jr.hb:
"0: addiu $ra, $ra, 3f-0b;" // set ra to insn after jr.hb
" beqz %2, 3f;"

"1: synci 0(%0);"
" sltu %3, %0, %1;"
Expand Down
4 changes: 2 additions & 2 deletions cpu/sh2/compiler.c
Original file line number Diff line number Diff line change
Expand Up @@ -816,13 +816,13 @@ static void dr_block_link(struct block_entry *be, struct block_link *bl, int emi
emith_jump_patch(jump, bl->blx, &jump);
emith_jump_at(bl->blx, be->tcache_ptr);
host_instructions_updated(bl->blx, bl->blx + emith_jump_at_size(),
((uintptr_t)bl->blx & 0x0f) + emith_jump_at_size()-1 > 0x0f);
((uintptr_t)bl->blx & 0x1f) + emith_jump_at_size()-1 > 0x1f);
}
} else {
printf("unknown BL type %d\n", bl->type);
exit(1);
}
host_instructions_updated(jump, jump + jsz, ((uintptr_t)jump & 0x0f) + jsz-1 > 0x0f);
host_instructions_updated(jump, jump + jsz, ((uintptr_t)jump & 0x1f) + jsz-1 > 0x1f);
}

// move bl to block_entry
Expand Down

0 comments on commit 69c2251

Please sign in to comment.