| # frv testcase for rsth $GRk,@($GRi,$GRj) |
| # mach: frv |
| # as(frv): -mcpu=frv |
| |
| .include "testutils.inc" |
| |
| start |
| |
| .global add |
| add: |
| ; No nesr's active |
| set_gr_gr sp,gr22 |
| set_mem_limmed 0x2222,0x2222,gr22 |
| set_gr_gr gr22,gr21 |
| inc_gr_immed -4,gr21 |
| set_mem_limmed 0x3333,0x3333,gr21 |
| set_gr_gr gr22,gr23 |
| set_gr_limmed 0x1111,0x1111,gr20 |
| set_gr_immed 0,gr7 |
| set_gr_limmed 0xffff,0xffff,gr8 |
| rsth gr8,@(sp,gr7) |
| test_mem_limmed 0xffff,0x2222,gr22 |
| test_mem_limmed 0x3333,0x3333,gr21 |
| test_gr_limmed 0x1111,0x1111,gr20 |
| |
| ; 1 nesr active with the incorrect address in neear for gr |
| nlduhi @(sp,0),gr20 |
| test_spr_gr neear0,gr23 |
| set_mem_limmed 0x2222,0x2222,gr22 |
| set_mem_limmed 0x3333,0x3333,gr21 |
| set_gr_limmed 0x1111,0x1111,gr20 |
| set_gr_limmed 0xffff,0xffff,gr8 |
| set_gr_immed 2,gr7 |
| rsth gr8,@(sp,gr7) |
| test_mem_limmed 0x2222,0xffff,gr22 |
| test_mem_limmed 0x3333,0x3333,gr21 |
| test_gr_limmed 0x1111,0x1111,gr20 |
| |
| ; 1 nesr active with the incorrect address in neear for fr |
| inc_gr_immed 2,gr23 |
| nldhfi @(sp,2),fr20 |
| test_spr_gr neear1,gr23 |
| set_mem_limmed 0x2222,0x2222,gr22 |
| set_mem_limmed 0x3333,0x3333,gr21 |
| set_fr_iimmed 0x1111,0x1111,fr20 |
| set_gr_limmed 0xffff,0xffff,gr8 |
| inc_gr_immed 4,sp |
| set_gr_immed -4,gr7 |
| rsth gr8,@(sp,gr7) |
| test_mem_limmed 0xffff,0x2222,gr22 |
| test_mem_limmed 0x3333,0x3333,gr21 |
| test_fr_limmed 0x1111,0x1111,fr20 |
| |
| ; 1 nesr active with the correct address in neear for gr |
| inc_gr_immed -4,gr23 |
| nlduhi @(sp,-6),gr20 |
| test_spr_gr neear2,gr23 |
| set_mem_limmed 0x2222,0x2222,gr22 |
| set_mem_limmed 0x3333,0x3333,gr21 |
| set_gr_limmed 0x1111,0x1111,gr20 |
| set_gr_limmed 0xffff,0xffff,gr8 |
| inc_gr_immed -4,sp |
| set_gr_immed -2,gr7 |
| rsth gr8,@(sp,gr7) |
| test_mem_limmed 0x2222,0x2222,gr22 |
| test_mem_limmed 0x3333,0xffff,gr21 |
| test_gr_limmed 0x0000,0xffff,gr20 |
| |
| ; 1 nesr active with the correct address in neear for fr |
| inc_gr_immed -2,gr23 |
| nldhfi @(sp,-4),fr20 |
| test_spr_gr neear3,gr23 |
| set_mem_limmed 0x2222,0x2222,gr22 |
| set_mem_limmed 0x3333,0x3333,gr21 |
| set_fr_iimmed 0x1111,0x1111,fr20 |
| set_gr_limmed 0xffff,0xffff,gr8 |
| set_gr_immed -4,gr7 |
| rsth gr8,@(sp,gr7) |
| test_mem_limmed 0x2222,0x2222,gr22 |
| test_mem_limmed 0xffff,0x3333,gr21 |
| test_fr_limmed 0x0000,0xffff,fr20 |
| |
| pass |