I don’t have much hair, and with the aid of the Atari Jaguar RISC CPUs I am bound to have less with fun bugs like these. I keep hitting this one, forgetting about it for a few mind numbing minutes/hours/days and then remember it and spend more minutes/hours/days resolving it. So I thought I would scribble it here…
I am not 100% certain if this is entirely the RISC CPU bug or MADMAC being a bit pants at alignment, but it is possible to generate ‘fun’ alignment issues in your code by simply adding or removing a nop (or other similar 16bit only instruction). The instruction doesn’t need to be called even! that’s how much fun this is!
From what I can tell it seems that jump instructions are particularly fussy about where they are jumping to, so it is possible that by adding/removing a 16bit instruction you will move a jump destination into one of these ‘un-desired’ addresses and hey presto your RISC code suddenly stops working, or does something weird. Even though you haven’t changed anything that should cause such behaviour.
So if you are playing with Jaguar RISC code and using jumps and sometimes it randomly seems to stop working but then work again, this could be the cause. How do you find which jump is being affected? trial and error is my best method, or add a nop just after the code you modified (doesn’t need to be the executed code block), one at a time until your code magically starts working again :/
One day I’ll fully track this down and come up with some fix/work around.. probably :DÂ Until then, keep hacking!
IT would be most helpful if you posted the code you are talking about.
Perhaps then I might be able to figure out why you may be having this issue.
Thanks but I am pretty sure I know the issue, hence why I posted the article about it. It’s not a particular piece of code that is an issue, as explained in the article.