| |
ready.
Registered: Feb 2003 Posts: 441 |
reading flags
Hello,
I am packing some parts together to be loaded using DreamLoad and I want to dedicate n clock cylces per frame for loading. To do this, at a certain of the demo code point I start a signle shot CIA timer to generate a NMI after some delay (during which the loader loads). I jump to the loader code, which later on is interrupted by the previously set NMI. I change a bit the stack and stack pointer for jumping back and forth between demo and loader and it seems to work....
....but after some frames it crashes. I suspect that the problem is that when the code enters the loader the flags are changed and I should save not only A, X, Y, SP but flags also.
Is there a way to read/write the flags all in one, like TSX and TXS for the stack pointer? |
|
| |
assiduous Account closed
Registered: Jun 2007 Posts: 343 |
read: php pla
write: lda#val pha plp |
| |
Slammer
Registered: Feb 2004 Posts: 416 |
The flags are set during rti. Perhaps you modify the flags or returnadress on the stack? |
| |
ready.
Registered: Feb 2003 Posts: 441 |
yes I modify the addresses on the stack, but not (yet) the flags. Thanks I forgot about plp anbd php! Will give it a try.
Thanks |
| |
ready.
Registered: Feb 2003 Posts: 441 |
thanx to you all. My loader routine works great now and I can choose how much raster time it can have per each screen frame. Hope to finish this demo soon:)
Linking in progress.... |
| |
HCL
Registered: Feb 2003 Posts: 728 |
Sounds cool!! The loader at least, don't know about the demo yet :). |
| |
ready.
Registered: Feb 2003 Posts: 441 |
I don't want to say anything about the demo, yet.
But I am having this problem of linking the parts together, most of which were done not by me. I had only runnable individual compressed files of each part. So, I had to modify the code from VICE monitor, adding the needed code to support the loader.
So I thought I could jump to the loader at some point inside the demo, while the effect is running and have a single shot NMI to force the program to leave the loader code and go back to the demo effect code.
The problem is that standard DreamLoad is meant to be run in background as the main program and be interrupted by an irq. I needed instead to run the demo effect in "background" (not really since all effects use IRQs) and dedicate a pre-set amount of rastertime to DreamLoad, not too much otherwise the effect slows down/crashes, not too little otherwise loading takes too long.
Any suggestion about how I could do this differently? |
| |
HCL
Registered: Feb 2003 Posts: 728 |
I always do it the other way around, run the demo effects inside the irq:s and do the loading outside. This way loading gets all the time not used by irq (or nmi). But then, you seem to not be in charge of all the code, so perhaps that's not an option. Depends on alot of things.. |
| |
WVL
Registered: Mar 2002 Posts: 903 |
HCL's way is the normal way to do it, but I use a little bit different way again..
In the real background, I do the loading. The effects run in my IRQ's.
But sometimes I have to do stuff that I cannot do inside an IRQ, like decompressing some datas (or copying a shitload of $d800 colors! :). What I do then, is to make an 'inbetween' background by firing a 'background IRQ' in which decompressing takes place. The normal effect-IRQ's can then still interrupt the 'background' IRQ.
So the system kinda looks like this:
loop:
background stuff here
load some stuffs..
goto loop or wait here until part ends
irq:
this gets fired depending on the raster
if (needforbackgroundirq)
goto backgroundirq
else
rti
(note : basically I dont end the normal effect IRQ, but I keep it running to do the more important background stuffs! I only make it so that the next effect IRQ can still interrupt it)
backgroundirq
save a,x,y,p
cli ;make sure effect irqs can still interrupt
do background stuff that's more important than the real background stuff
load a,x,y,p
rti ;go back to background loop
|
| |
JackAsser
Registered: Jun 2002 Posts: 2014 |
For Mekanics I used a simple theading method when I got bored to rewrite the code to be IRQ-reentrant. Instead the part is a simple linear loop but instead of polling $d012 for framesync I implemented a yield() call which gave up the CPU for another thread until next frame. The "other" thread was the loader.
So with this mechanism you get co-operative threading between two threads and the IRQ is the scheduler.
But normally we do it like HCL said. |
| |
Oswald
Registered: Apr 2002 Posts: 5095 |
wvl, I dont see where do you do the "effect" :) there's background stuff I and background stuff II. it looks the same as HCL's method, but with different name for stuff :)
(edit: btw why did the horizontal scrollbar appear in chrome for this page?) |
| |
WVL
Registered: Mar 2002 Posts: 903 |
Oswald : effect happens in the IRQ ofcourse :)
And you get the horizontal scrollbar because of my too-long sentence between code tags (which I can't edit anymore..).. |
| |
Pantaloon
Registered: Aug 2003 Posts: 124 |
i do it as the rest of you guys, one main interrupt that drives the effect, the code executing outside the irq i normally do loading in, and if i need it i issue more irq's from the main irq and doing a cli to get higher priority then the normal loop.
sometimes you want loading to be of higher priority then effect updates so you just switch place between the two. |
| |
Oswald
Registered: Apr 2002 Posts: 5095 |
Panta, and how do you make sure that the loader returns from time to time before finishing a whole file? |
| |
ready.
Registered: Feb 2003 Posts: 441 |
Oswald, your last question was exactly my original problem. I hope my previous posts clearify this. |