OpenCores
URL https://opencores.org/ocsvn/eco32/eco32/trunk

Subversion Repositories eco32

[/] [eco32/] [trunk/] [hwtests/] [xcptest/] [start.s] - Rev 48

Go to most recent revision | Compare with Previous | Blame | View Log

;
; start.s -- startup and support routines
;
 
	.set	dmapaddr,0xC0000000	; base of directly mapped addresses
	.set	stacktop,0xC0400000	; monitor stack is at top of memory
 
	.set	PSW,0			; reg # of PSW
	.set	TLB_INDEX,1		; reg # of TLB Index
	.set	TLB_ENTRY_HI,2		; reg # of TLB EntryHi
	.set	TLB_ENTRY_LO,3		; reg # of TLB EntryLo
	.set	TLB_ENTRIES,32		; number of TLB entries
 
;***************************************************************
 
	.import	_ecode
	.import	_edata
	.import	_ebss
 
	.import	serinit
	.import	ser0in
	.import	ser0out
 
	.import	main
	.import	userMissTaken
 
	.export	_bcode
	.export	_bdata
	.export	_bbss
 
	.export	cin
	.export	cout
 
	.export	xtest1
	.export	xtest1x
	.export	xtest2
	.export	xtest2x
	.export	xtest3
	.export	xtest3x
	.export	xtest4
	.export	xtest4x
	.export	xtest5
	.export	xtest5x
	.export	xtest6
	.export	xtest6x
	.export	xtest7
	.export	xtest7x
	.export	xtest8
	.export	xtest8x
	.export	xtest9
	.export	xtest9x
	.export	xtest10
	.export	xtest10x
	.export	xtest11
	.export	xtest11x
	.export	xtest12
	.export	xtest12x
	.export	xtest13
	.export	xtest13x
	.export	xtest14
	.export	xtest14x
	.export	xtest15
	.export	xtest15x
	.export	xtest16
	.export	xtest16x
	.export	xtest17
	.export	xtest17x
	.export	xtest18
	.export	xtest18x
	.export	xtest19
	.export	xtest19x
	.export	xtest20
	.export	xtest20x
	.export	xtest21
	.export	xtest21x
	.export	xtest22
	.export	xtest22x
	.export	xtest23
	.export	xtest23x
	.export	xtest24
	.export	xtest24x
	.export	xtest25
	.export	xtest25x
	.export	xtest26
	.export	xtest26x
	.export	xtest27
	.export	xtest27x
	.export	xtest28
	.export	xtest28x
	.export	xtest29
	.export	xtest29x
	.export	xtest30
	.export	xtest30x
	.export	xtest31
	.export	xtest31x
	.export	xtest32
	.export	xtest32x
	.export	xtest33
	.export	xtest33x
	.export	xtest34
	.export	xtest34x
	.export	xtest35
	.export	xtest35x
	.export	xtest36
	.export	xtest36x
	.export	xtest37
	.export	xtest37x
 
	.export	getTLB_HI
	.export	getTLB_LO
	.export	setTLB
 
;***************************************************************
 
	.code
_bcode:
 
	.data
_bdata:
 
	.bss
_bbss:
 
;***************************************************************
 
	.code
	.align	4
 
reset:
	j	start
 
interrupt:
	j	isr
 
userMiss:
	j	umsr
 
;***************************************************************
 
	.code
	.align	4
 
cin:
	j	ser0in
 
cout:
	j	ser0out
 
;***************************************************************
 
	.code
	.align	4
 
start:
	; force CPU into a defined state
	mvts	$0,PSW			; disable interrupts and user mode
 
	; initialize TLB
	mvts	$0,TLB_ENTRY_LO		; invalidate all TLB entries
	add	$8,$0,dmapaddr		; by impossible virtual page number
	add	$9,$0,$0
	add	$10,$0,TLB_ENTRIES
tlbloop:
	mvts	$8,TLB_ENTRY_HI
	mvts	$9,TLB_INDEX
	tbwi
	add	$8,$8,0x1000		; all entries must be different
	add	$9,$9,1
	bne	$9,$10,tlbloop
 
	; copy data segment
	add	$10,$0,_bdata		; lowest dst addr to be written to
	add	$8,$0,_edata		; one above the top dst addr
	sub	$9,$8,$10		; $9 = size of data segment
	add	$9,$9,_ecode		; data is waiting right after code
	j	cpytest
cpyloop:
	ldw	$11,$9,0		; src addr in $9
	stw	$11,$8,0		; dst addr in $8
cpytest:
	sub	$8,$8,4			; downward
	sub	$9,$9,4
	bgeu	$8,$10,cpyloop
 
	; clear bss segment
	add	$8,$0,_bbss		; start with first word of bss
	add	$9,$0,_ebss		; this is one above the top
	j	clrtest
clrloop:
	stw	$0,$8,0			; dst addr in $8
	add	$8,$8,4			; upward
clrtest:
	bltu	$8,$9,clrloop
 
	; now do some useful work
	add	$29,$0,stacktop		; setup monitor stack
	jal	serinit			; init serial interface
	jal	main			; enter command loop
 
	; main should never return
	j	start			; just to be sure...
 
;***************************************************************
 
xtest1:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest1x:
	trap
	j	halt
	.syn
 
xtest2:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest2x:
	.word	0x1E << 26
	j	halt
	.syn
 
xtest3:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest3x:
	div	$5,$7,$0
	j	halt
	.syn
 
xtest4:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest4x:
	div	$5,$7,0
	j	halt
	.syn
 
xtest5:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest5x:
	divu	$5,$7,$0
	j	halt
	.syn
 
xtest6:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest6x:
	divu	$5,$7,0
	j	halt
	.syn
 
xtest7:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest7x:
	rem	$5,$7,$0
	j	halt
	.syn
 
xtest8:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest8x:
	rem	$5,$7,0
	j	halt
	.syn
 
xtest9:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest9x:
	remu	$5,$7,$0
	j	halt
	.syn
 
xtest10:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest10x:
	remu	$5,$7,0
	j	halt
	.syn
 
xtest11:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest11x:
	.set	xtest11x,0xFFFFFF10
	jr	$15
	j	halt
	.syn
 
xtest12:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest12x:
	ldw	$5,$15,0
	j	halt
	.syn
 
xtest13:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest13x:
	stw	$5,$15,0
	j	halt
	.syn
 
xtest14:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest14v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest14v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest14x:
	rfx
	j	halt
	.syn
 
xtest15:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest15v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest15v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest15x:
	mvts	$0,PSW
	j	halt
	.syn
 
xtest16:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest16v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest16v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest16x:
	tbs
	j	halt
	.syn
 
xtest17:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest17v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest17v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest17x:
	.set	xtest17x,0xFFFFFF10
	jr	$15
	j	halt
	.syn
 
xtest18:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest18v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest18v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest18x:
	ldw	$5,$15,0
	j	halt
	.syn
 
xtest19:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$16,$0,xtest19v		; switch to virtual addressing
	add	$8,$0,11
	mvts	$8,TLB_INDEX
	and	$8,$16,0x3FFFF000
	mvts	$8,TLB_ENTRY_HI
	and	$8,$16,0x3FFFF000
	or	$8,$8,3
	mvts	$8,TLB_ENTRY_LO
	tbwi
	mvfs	$8,TLB_INDEX		; we could cross a page boundary
	add	$8,$8,1
	mvts	$8,TLB_INDEX
	mvfs	$8,TLB_ENTRY_HI
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_HI
	mvfs	$8,TLB_ENTRY_LO
	add	$8,$8,0x1000
	mvts	$8,TLB_ENTRY_LO
	tbwi
	and	$16,$16,0x3FFFFFFF
	jr	$16
xtest19v:
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest19x:
	stw	$5,$15,0
	j	halt
	.syn
 
xtest20:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest20x:
	.set	xtest20x,0x11111122
	jr	$17
	j	halt
	.syn
 
xtest21:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest21x:
	.set	xtest21x,0x00000021
	jr	$16
	j	halt
	.syn
 
xtest22:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest22x:
	ldw	$5,$15,2
	j	halt
	.syn
 
xtest23:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest23x:
	ldw	$5,$15,1
	j	halt
	.syn
 
xtest24:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest24x:
	ldh	$5,$15,1
	j	halt
	.syn
 
xtest25:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest25x:
	stw	$5,$15,2
	j	halt
	.syn
 
xtest26:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest26x:
	stw	$5,$15,1
	j	halt
	.syn
 
xtest27:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest27x:
	sth	$5,$15,1
	j	halt
	.syn
 
xtest28:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest28x:
	.set	xtest28x,0x33333314
	jr	$3
	j	halt
	.syn
 
xtest29:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest29x:
	ldw	$5,$3,0
	j	halt
	.syn
 
xtest30:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest30x:
	stw	$5,$3,0
	j	halt
	.syn
 
xtest31:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest31x:
	.set	xtest31x,0xBBBBBB1C
	jr	$11
	j	halt
	.syn
 
xtest32:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest32x:
	ldw	$5,$11,0
	j	halt
	.syn
 
xtest33:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest33x:
	stw	$5,$11,0
	j	halt
	.syn
 
xtest34:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$8,$0,11		; construct TLB entry
	mvts	$8,TLB_INDEX
	add	$8,$0,0xBBBBBB1C
	and	$8,$8,0xFFFFF000
	mvts	$8,TLB_ENTRY_HI
	add	$8,$0,0
	mvts	$8,TLB_ENTRY_LO
	tbwi
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
;xtest34x:
	.set	xtest34x,0xBBBBBB1C
	jr	$11
	j	halt
	.syn
 
xtest35:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$8,$0,11		; construct TLB entry
	mvts	$8,TLB_INDEX
	add	$8,$0,0xBBBBBB1C
	and	$8,$8,0xFFFFF000
	mvts	$8,TLB_ENTRY_HI
	add	$8,$0,0
	mvts	$8,TLB_ENTRY_LO
	tbwi
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest35x:
	ldw	$5,$11,0
	j	halt
	.syn
 
xtest36:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$8,$0,11		; construct TLB entry
	mvts	$8,TLB_INDEX
	add	$8,$0,0xBBBBBB1C
	and	$8,$8,0xFFFFF000
	mvts	$8,TLB_ENTRY_HI
	add	$8,$0,0
	mvts	$8,TLB_ENTRY_LO
	tbwi
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest36x:
	stw	$5,$11,0
	j	halt
	.syn
 
xtest37:
	mvts	$0,PSW
	add	$8,$0,returnState
	stw	$4,$8,0*4		; pointer to interrupt context
	stw	$31,$8,1*4		; return address
	stw	$29,$8,2*4		; stack pointer
	stw	$16,$8,3*4		; local variables
	stw	$17,$8,4*4
	stw	$18,$8,5*4
	stw	$19,$8,6*4
	stw	$20,$8,7*4
	stw	$21,$8,8*4
	stw	$22,$8,9*4
	stw	$23,$8,10*4
	add	$8,$0,11		; construct TLB entry
	mvts	$8,TLB_INDEX
	add	$8,$0,0xBBBBBB1C
	and	$8,$8,0xFFFFF000
	mvts	$8,TLB_ENTRY_HI
	add	$8,$0,1
	mvts	$8,TLB_ENTRY_LO
	tbwi
	.nosyn
	add	$28,$4,$0
	ldw	$8,$28,33*4		; tlbIndex
	mvts	$8,TLB_INDEX
	ldw	$8,$28,34*4		; tlbWntryHi
	mvts	$8,TLB_ENTRY_HI
	ldw	$8,$28,35*4		; tlbEntryLo
	mvts	$8,TLB_ENTRY_LO
	;ldw	$0,$28,0*4		; registers
	ldw	$1,$28,1*4
	ldw	$2,$28,2*4
	ldw	$3,$28,3*4
	ldw	$4,$28,4*4
	ldw	$5,$28,5*4
	ldw	$6,$28,6*4
	ldw	$7,$28,7*4
	ldw	$8,$28,8*4
	ldw	$9,$28,9*4
	ldw	$10,$28,10*4
	ldw	$11,$28,11*4
	ldw	$12,$28,12*4
	ldw	$13,$28,13*4
	ldw	$14,$28,14*4
	ldw	$15,$28,15*4
	ldw	$16,$28,16*4
	ldw	$17,$28,17*4
	ldw	$18,$28,18*4
	ldw	$19,$28,19*4
	ldw	$20,$28,20*4
	ldw	$21,$28,21*4
	ldw	$22,$28,22*4
	ldw	$23,$28,23*4
	ldw	$24,$28,24*4
	ldw	$25,$28,25*4
	ldw	$26,$28,26*4
	ldw	$27,$28,27*4
	;ldw	$28,$28,28*4
	ldw	$29,$28,29*4
	ldw	$30,$28,30*4
	ldw	$31,$28,31*4
	ldw	$28,$28,32*4		; psw
	mvts	$28,PSW
xtest37x:
	stw	$5,$11,0
	j	halt
	.syn
 
	; last resort if the exception did not trigger
halt:
	j	halt
 
;***************************************************************
 
	; Word getTLB_HI(int index)
getTLB_HI:
	mvts	$4,TLB_INDEX
	tbri
	mvfs	$2,TLB_ENTRY_HI
	jr	$31
 
	; Word getTLB_LO(int index)
getTLB_LO:
	mvts	$4,TLB_INDEX
	tbri
	mvfs	$2,TLB_ENTRY_LO
	jr	$31
 
	; void setTLB(int index, Word entryHi, Word entryLo)
setTLB:
	mvts	$4,TLB_INDEX
	mvts	$5,TLB_ENTRY_HI
	mvts	$6,TLB_ENTRY_LO
	tbwi
	jr	$31
 
;***************************************************************
 
	; general interrupt entry
isr:
	.nosyn
	ldhi	$28,userMissTaken	; remember entry point
	or	$28,$28,userMissTaken
	stw	$0,$28,0
	j	common
 
	; TLB user miss entry
umsr:
	.nosyn
	ldhi	$28,userMissTaken	; remember entry point
	or	$28,$28,userMissTaken
	stw	$28,$28,0
	j	common
 
common:
	ldhi	$28,returnState
	or	$28,$28,returnState
	ldw	$28,$28,0		; pointer to interrupt context
	stw	$0,$28,0*4		; registers
	stw	$1,$28,1*4
	stw	$2,$28,2*4
	stw	$3,$28,3*4
	stw	$4,$28,4*4
	stw	$5,$28,5*4
	stw	$6,$28,6*4
	stw	$7,$28,7*4
	stw	$8,$28,8*4
	stw	$9,$28,9*4
	stw	$10,$28,10*4
	stw	$11,$28,11*4
	stw	$12,$28,12*4
	stw	$13,$28,13*4
	stw	$14,$28,14*4
	stw	$15,$28,15*4
	stw	$16,$28,16*4
	stw	$17,$28,17*4
	stw	$18,$28,18*4
	stw	$19,$28,19*4
	stw	$20,$28,20*4
	stw	$21,$28,21*4
	stw	$22,$28,22*4
	stw	$23,$28,23*4
	stw	$24,$28,24*4
	stw	$25,$28,25*4
	stw	$26,$28,26*4
	stw	$27,$28,27*4
	stw	$28,$28,28*4
	stw	$29,$28,29*4
	stw	$30,$28,30*4
	stw	$31,$28,31*4
	mvfs	$8,PSW
	stw	$8,$28,32*4		; psw
	mvfs	$8,TLB_INDEX
	stw	$8,$28,33*4		; tlbIndex
	mvfs	$8,TLB_ENTRY_HI
	stw	$8,$28,34*4		; tlbEntryHi
	mvfs	$8,TLB_ENTRY_LO
	stw	$8,$28,35*4		; tlbEntryLo
	.syn
	add	$8,$0,returnState
	ldw	$4,$8,0*4		; pointer to interrupt context
	ldw	$31,$8,1*4		; return address
	ldw	$29,$8,2*4		; stack pointer
	ldw	$16,$8,3*4		; local variables
	ldw	$17,$8,4*4
	ldw	$18,$8,5*4
	ldw	$19,$8,6*4
	ldw	$20,$8,7*4
	ldw	$21,$8,8*4
	ldw	$22,$8,9*4
	ldw	$23,$8,10*4
	jr	$31
 
	.bss
	.align	4
 
	; monitor state
	; stored when leaving to execute a user program
	; loaded when re-entering the monitor
returnState:
	.word	0		; pointer to interrupt context
	.word	0		; $31 (return address)
	.word	0		; $29 (stack pointer)
	.word	0		; $16 (local variable)
	.word	0		; $17 (local variable)
	.word	0		; $18 (local variable)
	.word	0		; $19 (local variable)
	.word	0		; $20 (local variable)
	.word	0		; $21 (local variable)
	.word	0		; $22 (local variable)
	.word	0		; $23 (local variable)
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.