# ------------------------------------------------------------------- # 68K (c) Copyright 1996 Nat! & KKP # ------------------------------------------------------------------- # These are some of the results/guesses that Klaus and Nat! found # out about the Jaguar with a few helpful hints by other people, # who'd prefer to remain anonymous. # # Since we are not under NDA or anything from Atari we feel free to # give this to you for educational purposes only. # # Please note, that this is not official documentation from Atari # or derived work thereof (both of us have never seen the Atari docs) # and Atari isn't connected with this in any way. # # Please use this informationphile as a starting point for your own # exploration and not as a reference. If you find anything inaccurate, # missing, needing more explanation etc. by all means please write # to us: # nat@zumdick.ruhr.de # or # kp@eegholm.dk # # If you could do us a small favor, don't use this information for # those lame flamewars on r.g.v.a or the mailing list. # # HTML soon ? # ------------------------------------------------------------------- # $Id: 68k.html,v 1.16 1997/11/16 18:14:39 nat Exp $ # -------------------------------------------------------------------
There isn't much we need to tell you about the 68K. First you already know the chip since ten years probably, and secondly there are enough reference books available in case your memory is failing you.For your convenience here is a list of useful links, where you can get all the low down dirt. I highly recommend the DTACK GROUNDED Archive which is a tribute site to one really great - though historic now - non-mainstream 68000 magazine.
Some Amiga hackers also put up a lot of useful info, which might be all you need, and is named MC680x0 Reference 1.1, by Flint/DARKNESS
Motorola, classy as always, also provides you with the complete documentation in Adobe Acrobat PDF format at their site under Motorola Microprocessors.
Let's just look at the way the processor is bound into the system and some things to watch out.
IRQs:
=-=-=
IPL Name Vector Control
---------+---------------+---------------+---------------
2 VBLANK IRQ $100 INT1 bit #0
2 GPU IRQ $100 INT1 bit #1
2 HBLANK IRQ $100 INT1 bit #2
2 Timer IRQ $100 INT1 bit #3
Note: Both timer interrupts (JPIT && PIT) are on the same INT1 bit.
and are therefore indistinguishable.
A typical way to install a LEVEL2 handler for the 68000 would be
something like this, you gotta supply "last_line" and "handler".
Note that the interrupt is auto vectored thru $100 (not $68)
V_AUTO = $100
VI = $F004E
INT1 = $F00E0
INT2 = $F00E2
IRQS_HANDLED=$909 ;; VBLANK and TIMER
move.w #$2700,sr ;; no IRQs please
move.l #handler,V_AUTO ;; install our routine
move.w #last_line,VI ;; scanline where IRQ should occur
;; should be 'odd' BTW
move.w #IRQS_HANDLE&$FF,INT1 ;; enable VBLANK + TIMER
move.w #$2100,sr ;; enable IRQs on the 68K
...
handler:
move.w d0,-(a7)
move.w INT1,d0
btst.b #0,d0
bne.b .no_blank
...
.no_blank:
btst.b #3,d0
beq.b .no_timer
...
.no_timer:
move.w #IRQS_HANDLED,INT1 ; clear latch, keep IRQ alive
move.w #0,INT2 ; let GPU run again
move.w (a7)+,d0
rte
As you can see, if you have multiple INT1 interrupts coming in,
you need to check the lower byte of INT1, to see which interrupt
happened.
Superstitions / Things to watch out for:
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
It looks like word/byte accesses to ROM space don't work. Looking
at some code in the Jaguar Server indicates that the MEMCON registers
come into play here.
I have a hunch that RWM cycles (like CLR.W (a0)) on TOM registers
aren't 100% safe.
NEUROMANCER adds:
NEVER do a clr.l (a0) into GPU/DSP memory you must do a
move.l #0,(a0) or a move.l d0,(a0).
The special thing about a CLR (on the 68000, fixed in the 68010
and onwards I believe) is, that the processor does a source read
before doing a destination write. It could be that this buggy read
is done in a slightly incompatible fashion to the other RMW
instructions like TAS <memory>, BCLR <??>,<memory>> ASL <memory>
et.c.
Otherwise you must refrain from using any RMW instruction on
GPU/DSP memory.
If the 68K does not soak up leftover cycles, but does use up valuable
bus resources its best to put it to sleep with
HALT #2000
so it will sleep until the next IRQ wakes it up again.
$Id: 68k.html,v 1.16 1997/11/16 18:14:39 nat Exp $