2003-08-30 00:41:31 +08:00
|
|
|
# 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
|
|
|
|
|
2003-10-11 03:30:50 +08:00
|
|
|
; 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
|
|
|
|
|
2003-08-30 00:41:31 +08:00
|
|
|
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
|
2003-10-11 03:30:50 +08:00
|
|
|
bad1: stdi gr0,@(sp,0) ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
test_gr_immed 1,gr15
|
|
|
|
|
|
|
|
set_gr_addr bad2,gr17
|
2003-10-11 03:30:50 +08:00
|
|
|
bad2: lddi @(sp,0),gr8 ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
test_gr_immed 2,gr15
|
|
|
|
|
|
|
|
set_gr_addr bad3,gr17
|
2003-10-11 03:30:50 +08:00
|
|
|
bad3: stdc cpr0,@(sp,gr0) ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
test_gr_immed 3,gr15
|
|
|
|
|
|
|
|
set_gr_addr bad4,gr17
|
2003-10-11 03:30:50 +08:00
|
|
|
bad4: lddc @(sp,gr0),cpr8 ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
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
|
2003-10-11 03:30:50 +08:00
|
|
|
bad9: stdfi fr0,@(sp,0) ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
test_gr_immed 9,gr15
|
|
|
|
|
|
|
|
set_gr_addr bada,gr17
|
2003-10-11 03:30:50 +08:00
|
|
|
bada: lddfi @(sp,0),fr8 ; misaligned reg
|
2003-08-30 00:41:31 +08:00
|
|
|
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
|