1368b914e9
Now that all port tests live under testsuite/sim/*/, and none live in testsuite/ directly, flatten the structure by moving all of the dirs under testsuite/sim/ to testsuite/ directly. We need to stop passing --tool to dejagnu so that it searches all dirs and not just ones that start with "sim". Since we have no other dirs in this tree, and no plans to add any, should be fine.
131 lines
3.0 KiB
Plaintext
131 lines
3.0 KiB
Plaintext
# frv testcase to generate interrupts for bad register alignment
|
|
# mach: frv
|
|
.include "testutils.inc"
|
|
|
|
start
|
|
|
|
.global align
|
|
align:
|
|
and_spr_immed -4081,tbr ; clear tbr.tt
|
|
set_gr_spr tbr,gr17
|
|
inc_gr_immed 0x080,gr17 ; address of exception handler
|
|
set_bctrlr_0_0 gr17
|
|
inc_gr_immed 0x050,gr17 ; address of exception handler
|
|
set_bctrlr_0_0 gr17
|
|
set_spr_immed 128,lcr
|
|
set_spr_addr ok1,lr
|
|
set_psr_et 1
|
|
|
|
; Make the the register number odd at bad[1-4], bad9 and bada.
|
|
; We can't simply code an odd register number because the assembler
|
|
; will catch the error.
|
|
set_gr_mem bad1,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bad1
|
|
set_gr_addr bad1,gr10
|
|
flush_data_cache gr10
|
|
set_gr_mem bad2,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bad2
|
|
set_gr_addr bad2,gr10
|
|
flush_data_cache gr10
|
|
set_gr_mem bad3,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bad3
|
|
set_gr_addr bad3,gr10
|
|
flush_data_cache gr10
|
|
set_gr_mem bad4,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bad4
|
|
set_gr_addr bad4,gr10
|
|
flush_data_cache gr10
|
|
set_gr_mem bad9,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bad9
|
|
set_gr_addr bad9,gr10
|
|
flush_data_cache gr10
|
|
set_gr_mem bada,gr10
|
|
or_gr_immed 0x02000000,gr10
|
|
set_mem_gr gr10,bada
|
|
set_gr_addr bada,gr10
|
|
flush_data_cache gr10
|
|
|
|
set_gr_immed 4,gr20 ; PC increment
|
|
set_gr_immed 0,gr15
|
|
inc_gr_immed -12,sp ; for memory alignment
|
|
|
|
set_gr_addr bad1,gr17
|
|
bad1: stdi gr0,@(sp,0) ; misaligned reg
|
|
test_gr_immed 1,gr15
|
|
|
|
set_gr_addr bad2,gr17
|
|
bad2: lddi @(sp,0),gr8 ; misaligned reg
|
|
test_gr_immed 2,gr15
|
|
|
|
set_gr_addr bad3,gr17
|
|
bad3: stdc cpr0,@(sp,gr0) ; misaligned reg
|
|
test_gr_immed 3,gr15
|
|
|
|
set_gr_addr bad4,gr17
|
|
bad4: lddc @(sp,gr0),cpr8 ; misaligned reg
|
|
test_gr_immed 4,gr15
|
|
|
|
set_gr_addr bad5,gr17
|
|
bad5: stqi gr2,@(sp,0) ; misaligned reg
|
|
test_gr_immed 5,gr15
|
|
|
|
set_gr_addr bad6,gr17
|
|
bad6: ldqi @(sp,0),gr10 ; misaligned reg
|
|
test_gr_immed 6,gr15
|
|
|
|
set_gr_addr bad7,gr17
|
|
bad7: stqc cpr2,@(sp,gr0) ; misaligned reg
|
|
test_gr_immed 7,gr15
|
|
|
|
set_gr_addr bad8,gr17
|
|
bad8: ldqc @(sp,gr0),cpr10 ; misaligned reg
|
|
test_gr_immed 8,gr15
|
|
|
|
set_gr_immed 0,gr20 ; PC increment
|
|
set_gr_addr bad9,gr17
|
|
bad9: stdfi fr0,@(sp,0) ; misaligned reg
|
|
test_gr_immed 9,gr15
|
|
|
|
set_gr_addr bada,gr17
|
|
bada: lddfi @(sp,0),fr8 ; misaligned reg
|
|
test_gr_immed 10,gr15
|
|
|
|
set_gr_addr badb,gr17
|
|
badb: stqfi fr2,@(sp,0) ; misaligned reg
|
|
test_gr_immed 11,gr15
|
|
|
|
set_gr_addr badc,gr17
|
|
badc: ldqfi @(sp,0),fr10 ; misaligned reg
|
|
test_gr_immed 12,gr15
|
|
|
|
pass
|
|
|
|
; exception handler
|
|
ok1:
|
|
cmpi gr20,0,icc0
|
|
beq icc0,0,float
|
|
|
|
; check register_exception
|
|
test_spr_immed 0x1,esfr1 ; esr0 is active
|
|
test_spr_gr epcr0,gr17
|
|
test_spr_bits 0x0001,0,0x1,esr0 ; esr0 is valid
|
|
test_spr_bits 0x003e,1,0xc,esr0 ; esr0.ec is set
|
|
test_spr_bits 0x00c0,6,0x1,esr0 ; esr0.rec is set
|
|
test_spr_bits 0x0800,11,0x0,esr0 ; esr0.eav is not set
|
|
movsg pcsr,gr60
|
|
add gr60,gr20,gr60
|
|
movgs gr60,pcsr
|
|
bra ret
|
|
float:
|
|
; check fp_exception
|
|
test_spr_immed 0,esfr1 ; no esr's active
|
|
ret:
|
|
inc_gr_immed 1,gr15
|
|
rett 0
|
|
fail
|