-
Notifications
You must be signed in to change notification settings - Fork 2.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Window focus regain causes debugger to step ahead #20004
Comments
Hm, yeah, I can see how this would happen... Re-using the debugger break feature to implement the pause feature caused this, although adding more different pause features might not be a better idea, just more states to debug. It should be possible to just check the break reason and not resume if the break wasn't caused by switching focus. EDIT: Actually we already seem to have this check.. weird:
Ah, I think there are a bunch of cases where we just leave that value around... |
This is what I suspected from the behavior, but I wasn't familiar enough with the code to find a root cause. Thanks for the pointers!
If you don't mind a bit of speculation: my mental model (that turned out wrong) expected a two-tier system, where debugger-based breaks are a different tier than pauses originating from the UI. It does not look like this behavior can be conveniently be represented with a FSM. Might want to consider a pushdown automaton (e.g.: https://gameprogrammingpatterns.com/state.html ) to represent stepping state. I think it might simplify things and prevent similar bugs in the future. I can't promise I can make such a change in an unfamiliar codebase without breaking other things, but maybe I'll experiment with it. |
Update: seems like the reason I encountered this bug despite the check was because the fix ( #19914 ) wasn't in the latest release yet. And I didn't realize the "latest git build" referred to dev builds. Sorry! |
Oh, okay. Closing then, but your report also caused me to clean up some of this :) |
Game or games this happens in
ULES-00999 - Disgaea Afternoon of Darkness
What area of the game / PPSSPP
The issue happens when using the builtin debugger. The rough steps to reproduce:
The issue is easier to see if there are multiple read/write breakpoints.
Since I'm not a 100% certain it happens every time, here's are specific steps for the European version of Disgaea: Afternoon of Darkness:
0x08980E3E
and0x08980E3F
, with the Break property enabled0x08836AF4
0x08836AF8
pc
/the current instruction indicator has moved to0x08836B0C
if the above execute breakpoint was not set, or to0x08836AF8
if it was set.The issue does not happen if emulation is explicitly paused by bringing up the PPSSPP menu. The issue also disappears without the need for pausing if "Pause when not focused" is disabled in the settings.
Before window regains focus:
data:image/s3,"s3://crabby-images/caf61/caf61a1dfea163b3bcb528e2253562085761a3b4" alt="Image"
After window regains focus:
data:image/s3,"s3://crabby-images/a6cb7/a6cb7f3dc98ad85f9c622c8fc92145fb88d37e15" alt="Image"
Since I don't remember if and what data I altered in it, the savedata I'm using is probably not suitable for upload. But if needed, I'll produce a "clean" savefile.
What should happen
If the game is stopped at a breakpoint, execution should not continue when the window regains focus, regardless of the value of "Pause when not focused".
Logs
No response
Platform
Windows
Mobile device model or graphics card (GPU)
NVIDIA Geforce GTX 960M
PPSSPP version affected
v1.8.1-g0f50225 (v1.8.1 Git release)
Last working version
No response
Graphics backend (3D API)
Direct3D 11
Checklist
The text was updated successfully, but these errors were encountered: