-
Notifications
You must be signed in to change notification settings - Fork 57
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
IRQ occurring during DMA is not emulated correctly #380
Comments
This is incorrect, I just had a bug in my code. The IRQ pipeline being stalled while DMA is active seems to be the correct implementation in all cases. |
Thanks for the info. This is interesting, albeit I'm unsure what the exact mechanism behind this would be. My understanding of DMA stalling is that if DMA is active and the CPU attempts to access memory then that bus cycle is extended via CLKEN but CPU internal operations (i.e. internal cycles) can happen in parallel to DMA (AGBEEG tests this). Albeit there also appears to be a one clock cycle penalty on CPU->DMA and DMA->CPU bus control transitions during which, as far as I know, internal cycles of the CPU can't execute. So maybe that influences the IRQ pipeline? |
I did some quick testing and it seems that internal cycles (at least multiplication cycles) take place on all cycles the DMA is active, including transition periods. See this test which Nanoboy Advance currently fails: https://github.com/alyosha-tas/gba-tests/blob/master/Interactions/Internal_Cycle_DMA_Mul.gba I don't have the slightest idea how hardware internals work, so I cant offer anything there. |
Late response but yes, it seems that you are right. I managed to fix this test by allowing the CPU to execute two additional internal cycles during a DMA period. |
https://github.com/alyosha-tas/gba-tests/blob/master/Interactions/Internal_Cycle_DMA_IRQ.gba
This test indicates that the IRQ pipeline is also stalled while DMA is running (I think) (at least in some cases.)
The test runs a DMA with HBL timing that starts on the read cycle of an LDR. A timer IRQ then occurs in the middle of DMA execution.
The IRQ code then checks what value is pushed to the link reg.
Current result in Nanoboy Advance is that IRQ occurs immediately after DMA. (Giving result of 6.)
Current result in GBAHawk is that one additional instruction occurs. (Giving result of 8.)
But on hardware, result is 10.
Pretty surprising this has gone unnoticed until now.
The text was updated successfully, but these errors were encountered: