diff options
author | David Guillen Fandos | 2021-07-05 18:19:19 +0200 |
---|---|---|
committer | David Guillen Fandos | 2021-07-05 18:19:19 +0200 |
commit | 0ca87a4807b4d26baef3b7813e1b948b88dddf79 (patch) | |
tree | 8b714783abf6a46e3511a68ee8a0d31b602f6124 /frontend | |
parent | 3d874ec5e3d5675ae9513264d857a3c6c9d2417c (diff) | |
download | picogpsp-0ca87a4807b4d26baef3b7813e1b948b88dddf79.tar.gz picogpsp-0ca87a4807b4d26baef3b7813e1b948b88dddf79.tar.bz2 picogpsp-0ca87a4807b4d26baef3b7813e1b948b88dddf79.zip |
Fix conditional ARM instructions at the end of a translation block
This fixes issue #133
The explanation is as follows. Most blocks end on an inconditional
jump/branch, but there's two cases where this doesn't happen:
translation gates and when we hit MAX_EXITS. These are very uncommon
cases and therefore more prone to hidden bugs.
When this happens, the last instruction emits a conditional jump (via
arm_conditional_block_header macro) which is patched by a later
instruction via generate_branch_patch_conditional. Typically the last
unconditional branch will trigger the patching condition (which is
aproximately condition != last_condition), but in these two cases it
might not happen, leaving an unpatched branch. This makes x86 and ARM
dynarecs crash in interesting ways (although it might not crash
depending on $stuff and make the bug even harder to track).
Diffstat (limited to 'frontend')
0 files changed, 0 insertions, 0 deletions