1102 lines
19 KiB
ArmAsm
1102 lines
19 KiB
ArmAsm
//Original:/proj/frio/dv/testcases/seq/se_undefinedinstruction1/se_undefinedinstruction1.dsp
|
|
// Description: 16 bit "holes" Undefined Instructions in Supervisor Mode
|
|
# mach: bfin
|
|
# sim: --environment operating
|
|
|
|
#include "test.h"
|
|
.include "testutils.inc"
|
|
start
|
|
|
|
//
|
|
// Constants and Defines
|
|
//
|
|
|
|
include(gen_int.inc)
|
|
include(selfcheck.inc)
|
|
include(std.inc)
|
|
include(mmrs.inc)
|
|
include(symtable.inc)
|
|
|
|
#ifndef STACKSIZE
|
|
#define STACKSIZE 0x10 // change for how much stack you need
|
|
#endif
|
|
#ifndef ITABLE
|
|
#define ITABLE 0xF0000000
|
|
#endif
|
|
|
|
GEN_INT_INIT(ITABLE) // set location for interrupt table
|
|
|
|
//
|
|
// Reset/Bootstrap Code
|
|
// (Here we should set the processor operating modes, initialize registers,
|
|
// etc.)
|
|
//
|
|
|
|
BOOT:
|
|
INIT_R_REGS(0); // initialize general purpose regs
|
|
|
|
INIT_P_REGS(0); // initialize the pointers
|
|
|
|
INIT_I_REGS(0); // initialize the dsp address regs
|
|
INIT_M_REGS(0);
|
|
INIT_L_REGS(0);
|
|
INIT_B_REGS(0);
|
|
|
|
CLI R1; // inhibit events during MMR writes
|
|
|
|
LD32_LABEL(sp, USTACK); // setup the user stack pointer
|
|
USP = SP;
|
|
|
|
LD32_LABEL(sp, KSTACK); // setup the kernel stack pointer
|
|
FP = SP; // and frame pointer
|
|
|
|
LD32(p0, EVT0); // Setup Event Vectors and Handlers
|
|
|
|
P0 += 4; // EVT0 not used (Emulation)
|
|
|
|
P0 += 4; // EVT1 not used (Reset)
|
|
|
|
LD32_LABEL(r0, NHANDLE); // NMI Handler (Int2)
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, XHANDLE); // Exception Handler (Int3)
|
|
[ P0 ++ ] = R0;
|
|
|
|
P0 += 4; // EVT4 not used (Global Interrupt Enable)
|
|
|
|
LD32_LABEL(r0, HWHANDLE); // HW Error Handler (Int5)
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, THANDLE); // Timer Handler (Int6)
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I7HANDLE); // IVG7 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I8HANDLE); // IVG8 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I9HANDLE); // IVG9 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I10HANDLE);// IVG10 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I11HANDLE);// IVG11 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I12HANDLE);// IVG12 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I13HANDLE);// IVG13 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I14HANDLE);// IVG14 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32_LABEL(r0, I15HANDLE);// IVG15 Handler
|
|
[ P0 ++ ] = R0;
|
|
|
|
LD32(p0, EVT_OVERRIDE);
|
|
R0 = 0;
|
|
[ P0 ++ ] = R0;
|
|
|
|
R1 = -1; // Change this to mask interrupts (*)
|
|
CSYNC; // wait for MMR writes to finish
|
|
STI R1; // sync and reenable events (implicit write to IMASK)
|
|
|
|
DUMMY:
|
|
|
|
A0 = 0; // reset accumulators
|
|
A1 = 0;
|
|
|
|
R0 = 0 (Z);
|
|
|
|
LT0 = r0; // set loop counters to something deterministic
|
|
LB0 = r0;
|
|
LC0 = r0;
|
|
LT1 = r0;
|
|
LB1 = r0;
|
|
LC1 = r0;
|
|
|
|
ASTAT = r0; // reset other internal regs
|
|
SYSCFG = r0;
|
|
RETS = r0; // prevent X's breaking LINK instruction
|
|
|
|
// The following code sets up the test for running in USER mode
|
|
|
|
LD32_LABEL(r0, STARTUSER);// One gets to user mode by doing a
|
|
// ReturnFromInterrupt (RTI)
|
|
RETI = r0; // We need to load the return address
|
|
|
|
// Comment the following line for a USER Mode test
|
|
|
|
JUMP STARTSUP; // jump to code start for SUPERVISOR mode
|
|
|
|
RTI;
|
|
|
|
STARTSUP:
|
|
LD32_LABEL(p1, BEGIN);
|
|
|
|
LD32(p0, EVT15);
|
|
|
|
CLI R1; // inhibit events during write to MMR
|
|
[ P0 ] = P1; // IVG15 (General) handler (Int 15) load with start
|
|
CSYNC; // wait for it
|
|
STI R1; // reenable events with proper imask
|
|
|
|
RAISE 15; // after we RTI, INT 15 should be taken
|
|
|
|
RTI;
|
|
|
|
//
|
|
// The Main Program
|
|
//
|
|
|
|
STARTUSER:
|
|
|
|
LINK 0; // change for how much stack frame space you need.
|
|
|
|
JUMP BEGIN;
|
|
|
|
//*********************************************************************
|
|
|
|
BEGIN:
|
|
|
|
// COMMENT the following line for USER MODE tests
|
|
[ -- SP ] = RETI; // enable interrupts in supervisor mode
|
|
|
|
// **** YOUR CODE GOES HERE ****
|
|
|
|
// count of UI's will be in r5, which was initialized to 0 by header
|
|
|
|
|
|
.dw 0x1 ;
|
|
.dw 0x2 ;
|
|
.dw 0x3 ;
|
|
.dw 0x4 ;
|
|
.dw 0x5 ;
|
|
.dw 0x6 ;
|
|
.dw 0x7 ;
|
|
.dw 0x8 ;
|
|
.dw 0x9 ;
|
|
.dw 0xA ;
|
|
.dw 0xB ;
|
|
.dw 0xC ;
|
|
.dw 0xD ;
|
|
.dw 0xE ;
|
|
.dw 0xF ;
|
|
.dw 0x15 ;
|
|
.dw 0x16 ;
|
|
.dw 0x17 ;
|
|
.dw 0x18 ;
|
|
.dw 0x19 ;
|
|
.dw 0x1A ;
|
|
.dw 0x1B ;
|
|
.dw 0x1C ;
|
|
.dw 0x1D ;
|
|
.dw 0x1E ;
|
|
.dw 0x1F ;
|
|
.dw 0x21 ;
|
|
.dw 0x22 ;
|
|
.dw 0x26 ;
|
|
.dw 0x27 ; // XXX: hardware doesnt trigger illegal exception ?
|
|
.dw 0x28 ;
|
|
.dw 0x29 ;
|
|
.dw 0x2A ;
|
|
.dw 0x2B ;
|
|
.dw 0x2C ;
|
|
.dw 0x2D ;
|
|
.dw 0x2E ;
|
|
.dw 0x2F ;
|
|
.dw 0x38 ;
|
|
.dw 0x39 ;
|
|
.dw 0x3A ;
|
|
.dw 0x3B ;
|
|
.dw 0x3C ;
|
|
.dw 0x3D ;
|
|
.dw 0x3E ;
|
|
.dw 0x3F ;
|
|
.dw 0x48 ;
|
|
.dw 0x49 ;
|
|
.dw 0x4A ;
|
|
.dw 0x4B ;
|
|
.dw 0x4C ;
|
|
.dw 0x4D ;
|
|
.dw 0x4E ;
|
|
.dw 0x4F ;
|
|
.dw 0x58 ;
|
|
.dw 0x59 ;
|
|
.dw 0x5A ;
|
|
.dw 0x5B ;
|
|
.dw 0x5C ;
|
|
.dw 0x5D ;
|
|
.dw 0x5E ;
|
|
.dw 0x5F ;
|
|
.dw 0x68 ;
|
|
.dw 0x69 ;
|
|
.dw 0x6A ;
|
|
.dw 0x6B ;
|
|
.dw 0x6C ;
|
|
.dw 0x6D ;
|
|
.dw 0x6E ;
|
|
.dw 0x6F ;
|
|
.dw 0x78 ;
|
|
.dw 0x79 ;
|
|
.dw 0x7A ;
|
|
.dw 0x7B ;
|
|
.dw 0x7C ;
|
|
.dw 0x7D ;
|
|
.dw 0x7E ;
|
|
.dw 0x7F ;
|
|
.dw 0x88 ;
|
|
.dw 0x89 ;
|
|
.dw 0x8A ;
|
|
.dw 0x8B ;
|
|
.dw 0x8C ;
|
|
.dw 0x8D ;
|
|
.dw 0x8E ;
|
|
.dw 0x8F ;
|
|
.dw 0xB8 ;
|
|
.dw 0xB9 ;
|
|
.dw 0xBA ;
|
|
.dw 0xBB ;
|
|
.dw 0xBC ;
|
|
.dw 0xBD ;
|
|
.dw 0xBE ;
|
|
.dw 0xBF ;
|
|
.dw 0xC0 ;
|
|
.dw 0xC1 ;
|
|
.dw 0xC2 ;
|
|
.dw 0xC3 ;
|
|
.dw 0xC4 ;
|
|
.dw 0xC5 ;
|
|
.dw 0xC6 ;
|
|
.dw 0xC7 ;
|
|
.dw 0xC8 ;
|
|
.dw 0xC9 ;
|
|
.dw 0xCA ;
|
|
.dw 0xCB ;
|
|
.dw 0xCC ;
|
|
.dw 0xCD ;
|
|
.dw 0xCE ;
|
|
.dw 0xCF ;
|
|
.dw 0xD0 ;
|
|
.dw 0xD1 ;
|
|
.dw 0xD2 ;
|
|
.dw 0xD3 ;
|
|
.dw 0xD4 ;
|
|
.dw 0xD5 ;
|
|
.dw 0xD6 ;
|
|
.dw 0xD7 ;
|
|
.dw 0xD8 ;
|
|
.dw 0xD9 ;
|
|
.dw 0xDA ;
|
|
.dw 0xDB ;
|
|
.dw 0xDC ;
|
|
.dw 0xDD ;
|
|
.dw 0xDE ;
|
|
.dw 0xDF ;
|
|
.dw 0xE0 ;
|
|
.dw 0xE1 ;
|
|
.dw 0xE2 ;
|
|
.dw 0xE3 ;
|
|
.dw 0xE4 ;
|
|
.dw 0xE5 ;
|
|
.dw 0xE6 ;
|
|
.dw 0xE7 ;
|
|
.dw 0xE8 ;
|
|
.dw 0xE9 ;
|
|
.dw 0xEA ;
|
|
.dw 0xEB ;
|
|
.dw 0xEC ;
|
|
.dw 0xED ;
|
|
.dw 0xEE ;
|
|
.dw 0xEF ;
|
|
.dw 0xF0 ;
|
|
.dw 0xF1 ;
|
|
.dw 0xF2 ;
|
|
.dw 0xF3 ;
|
|
.dw 0xF4 ;
|
|
.dw 0xF5 ;
|
|
.dw 0xF6 ;
|
|
.dw 0xF7 ;
|
|
.dw 0xF8 ;
|
|
.dw 0xF9 ;
|
|
.dw 0xFA ;
|
|
.dw 0xFB ;
|
|
.dw 0xFC ;
|
|
.dw 0xFD ;
|
|
.dw 0xFE ;
|
|
.dw 0xFF ;
|
|
.dw 0x220 ;
|
|
.dw 0x221 ;
|
|
.dw 0x222 ;
|
|
.dw 0x223 ;
|
|
.dw 0x224 ;
|
|
.dw 0x225 ;
|
|
.dw 0x226 ;
|
|
.dw 0x227 ;
|
|
.dw 0x228 ;
|
|
.dw 0x229 ;
|
|
.dw 0x22A ;
|
|
.dw 0x22B ;
|
|
.dw 0x22C ;
|
|
.dw 0x22D ;
|
|
.dw 0x22E ;
|
|
.dw 0x22F ;
|
|
.dw 0x230 ;
|
|
.dw 0x231 ;
|
|
.dw 0x232 ;
|
|
.dw 0x233 ;
|
|
.dw 0x234 ;
|
|
.dw 0x235 ;
|
|
.dw 0x236 ;
|
|
.dw 0x237 ;
|
|
.dw 0x238 ;
|
|
.dw 0x239 ;
|
|
.dw 0x23A ;
|
|
.dw 0x23B ;
|
|
.dw 0x23C ;
|
|
.dw 0x23D ;
|
|
.dw 0x23E ;
|
|
.dw 0x23F ;
|
|
.dw 0x280 ;
|
|
.dw 0x281 ;
|
|
.dw 0x282 ;
|
|
.dw 0x283 ;
|
|
.dw 0x284 ;
|
|
.dw 0x285 ;
|
|
.dw 0x286 ;
|
|
.dw 0x287 ;
|
|
.dw 0x288 ;
|
|
.dw 0x289 ;
|
|
.dw 0x28A ;
|
|
.dw 0x28B ;
|
|
.dw 0x28C ;
|
|
.dw 0x28D ;
|
|
.dw 0x28E ;
|
|
.dw 0x28F ;
|
|
.dw 0x290 ;
|
|
.dw 0x291 ;
|
|
.dw 0x292 ;
|
|
.dw 0x293 ;
|
|
.dw 0x294 ;
|
|
.dw 0x295 ;
|
|
.dw 0x296 ;
|
|
.dw 0x297 ;
|
|
.dw 0x298 ;
|
|
.dw 0x299 ;
|
|
.dw 0x29A ;
|
|
.dw 0x29B ;
|
|
.dw 0x29C ;
|
|
.dw 0x29D ;
|
|
.dw 0x29E ;
|
|
.dw 0x29F ;
|
|
.dw 0x2A0 ;
|
|
.dw 0x2A1 ;
|
|
.dw 0x2A2 ;
|
|
.dw 0x2A3 ;
|
|
.dw 0x2A4 ;
|
|
.dw 0x2A5 ;
|
|
.dw 0x2A6 ;
|
|
.dw 0x2A7 ;
|
|
.dw 0x2A8 ;
|
|
.dw 0x2A9 ;
|
|
.dw 0x2AA ;
|
|
.dw 0x2AB ;
|
|
.dw 0x2AC ;
|
|
.dw 0x2AD ;
|
|
.dw 0x2AE ;
|
|
.dw 0x2AF ;
|
|
.dw 0x2B0 ;
|
|
.dw 0x2B1 ;
|
|
.dw 0x2B2 ;
|
|
.dw 0x2B3 ;
|
|
.dw 0x2B4 ;
|
|
.dw 0x2B5 ;
|
|
.dw 0x2B6 ;
|
|
.dw 0x2B7 ;
|
|
.dw 0x2B8 ;
|
|
.dw 0x2B9 ;
|
|
.dw 0x2BA ;
|
|
.dw 0x2BB ;
|
|
.dw 0x2BC ;
|
|
.dw 0x2BD ;
|
|
.dw 0x2BE ;
|
|
.dw 0x2BF ;
|
|
.dw 0x2C0 ;
|
|
.dw 0x2C1 ;
|
|
.dw 0x2C2 ;
|
|
.dw 0x2C3 ;
|
|
.dw 0x2C4 ;
|
|
.dw 0x2C5 ;
|
|
.dw 0x2C6 ;
|
|
.dw 0x2C7 ;
|
|
.dw 0x2C8 ;
|
|
.dw 0x2C9 ;
|
|
.dw 0x2CA ;
|
|
.dw 0x2CB ;
|
|
.dw 0x2CC ;
|
|
.dw 0x2CD ;
|
|
.dw 0x2CE ;
|
|
.dw 0x2CF ;
|
|
.dw 0x2D0 ;
|
|
.dw 0x2D1 ;
|
|
.dw 0x2D2 ;
|
|
.dw 0x2D3 ;
|
|
.dw 0x2D4 ;
|
|
.dw 0x2D5 ;
|
|
.dw 0x2D6 ;
|
|
.dw 0x2D7 ;
|
|
.dw 0x2D8 ;
|
|
.dw 0x2D9 ;
|
|
.dw 0x2DA ;
|
|
.dw 0x2DB ;
|
|
.dw 0x2DC ;
|
|
.dw 0x2DD ;
|
|
.dw 0x2DE ;
|
|
.dw 0x2DF ;
|
|
.dw 0x2E0 ;
|
|
.dw 0x2E1 ;
|
|
.dw 0x2E2 ;
|
|
.dw 0x2E3 ;
|
|
.dw 0x2E4 ;
|
|
.dw 0x2E5 ;
|
|
.dw 0x2E6 ;
|
|
.dw 0x2E7 ;
|
|
.dw 0x2E8 ;
|
|
.dw 0x2E9 ;
|
|
.dw 0x2EA ;
|
|
.dw 0x2EB ;
|
|
.dw 0x2EC ;
|
|
.dw 0x2ED ;
|
|
.dw 0x2EE ;
|
|
.dw 0x2EF ;
|
|
.dw 0x2F0 ;
|
|
.dw 0x2F1 ;
|
|
.dw 0x2F2 ;
|
|
.dw 0x2F3 ;
|
|
.dw 0x2F4 ;
|
|
.dw 0x2F5 ;
|
|
.dw 0x2F6 ;
|
|
.dw 0x2F7 ;
|
|
.dw 0x2F8 ;
|
|
.dw 0x2F9 ;
|
|
.dw 0x2FA ;
|
|
.dw 0x2FB ;
|
|
.dw 0x2FC ;
|
|
.dw 0x2FD ;
|
|
.dw 0x2FE ;
|
|
.dw 0x2FF ;
|
|
.dw 0x4600 ;
|
|
.dw 0x4601 ;
|
|
.dw 0x4602 ;
|
|
.dw 0x4603 ;
|
|
.dw 0x4604 ;
|
|
.dw 0x4605 ;
|
|
.dw 0x4606 ;
|
|
.dw 0x4607 ;
|
|
.dw 0x4608 ;
|
|
.dw 0x4609 ;
|
|
.dw 0x460A ;
|
|
.dw 0x460B ;
|
|
.dw 0x460C ;
|
|
.dw 0x460D ;
|
|
.dw 0x460E ;
|
|
.dw 0x460F ;
|
|
.dw 0x4610 ;
|
|
.dw 0x4611 ;
|
|
.dw 0x4612 ;
|
|
.dw 0x4613 ;
|
|
.dw 0x4614 ;
|
|
.dw 0x4615 ;
|
|
.dw 0x4616 ;
|
|
.dw 0x4617 ;
|
|
.dw 0x4618 ;
|
|
.dw 0x4619 ;
|
|
.dw 0x461A ;
|
|
.dw 0x461B ;
|
|
.dw 0x461C ;
|
|
.dw 0x461D ;
|
|
.dw 0x461E ;
|
|
.dw 0x461F ;
|
|
.dw 0x4620 ;
|
|
.dw 0x4621 ;
|
|
.dw 0x4622 ;
|
|
.dw 0x4623 ;
|
|
.dw 0x4624 ;
|
|
.dw 0x4625 ;
|
|
.dw 0x4626 ;
|
|
.dw 0x4627 ;
|
|
.dw 0x4628 ;
|
|
.dw 0x4629 ;
|
|
.dw 0x462A ;
|
|
.dw 0x462B ;
|
|
.dw 0x462C ;
|
|
.dw 0x462D ;
|
|
.dw 0x462E ;
|
|
.dw 0x462F ;
|
|
.dw 0x4630 ;
|
|
.dw 0x4631 ;
|
|
.dw 0x4632 ;
|
|
.dw 0x4633 ;
|
|
.dw 0x4634 ;
|
|
.dw 0x4635 ;
|
|
.dw 0x4636 ;
|
|
.dw 0x4637 ;
|
|
.dw 0x4638 ;
|
|
.dw 0x4639 ;
|
|
.dw 0x463A ;
|
|
.dw 0x463B ;
|
|
.dw 0x463C ;
|
|
.dw 0x463D ;
|
|
.dw 0x463E ;
|
|
.dw 0x463F ;
|
|
.dw 0x4640 ;
|
|
.dw 0x4641 ;
|
|
.dw 0x4642 ;
|
|
.dw 0x4643 ;
|
|
.dw 0x4644 ;
|
|
.dw 0x4645 ;
|
|
.dw 0x4646 ;
|
|
.dw 0x4647 ;
|
|
.dw 0x4648 ;
|
|
.dw 0x4649 ;
|
|
.dw 0x464A ;
|
|
.dw 0x464B ;
|
|
.dw 0x464C ;
|
|
.dw 0x464D ;
|
|
.dw 0x464E ;
|
|
.dw 0x464F ;
|
|
.dw 0x4650 ;
|
|
.dw 0x4651 ;
|
|
.dw 0x4652 ;
|
|
.dw 0x4653 ;
|
|
.dw 0x4654 ;
|
|
.dw 0x4655 ;
|
|
.dw 0x4656 ;
|
|
.dw 0x4657 ;
|
|
.dw 0x4658 ;
|
|
.dw 0x4659 ;
|
|
.dw 0x465A ;
|
|
.dw 0x465B ;
|
|
.dw 0x465C ;
|
|
.dw 0x465D ;
|
|
.dw 0x465E ;
|
|
.dw 0x465F ;
|
|
.dw 0x4660 ;
|
|
.dw 0x4661 ;
|
|
.dw 0x4662 ;
|
|
.dw 0x4663 ;
|
|
.dw 0x4664 ;
|
|
.dw 0x4665 ;
|
|
.dw 0x4666 ;
|
|
.dw 0x4667 ;
|
|
.dw 0x4668 ;
|
|
.dw 0x4669 ;
|
|
.dw 0x466A ;
|
|
.dw 0x466B ;
|
|
.dw 0x466C ;
|
|
.dw 0x466D ;
|
|
.dw 0x466E ;
|
|
.dw 0x466F ;
|
|
.dw 0x4670 ;
|
|
.dw 0x4671 ;
|
|
.dw 0x4672 ;
|
|
.dw 0x4673 ;
|
|
.dw 0x4674 ;
|
|
.dw 0x4675 ;
|
|
.dw 0x4676 ;
|
|
.dw 0x4677 ;
|
|
.dw 0x4678 ;
|
|
.dw 0x4679 ;
|
|
.dw 0x467A ;
|
|
.dw 0x467B ;
|
|
.dw 0x467C ;
|
|
.dw 0x467D ;
|
|
.dw 0x467E ;
|
|
.dw 0x467F ;
|
|
.dw 0x4680 ;
|
|
.dw 0x4681 ;
|
|
.dw 0x4682 ;
|
|
.dw 0x4683 ;
|
|
.dw 0x4684 ;
|
|
.dw 0x4685 ;
|
|
.dw 0x4686 ;
|
|
.dw 0x4687 ;
|
|
.dw 0x4688 ;
|
|
.dw 0x4689 ;
|
|
.dw 0x468A ;
|
|
.dw 0x468B ;
|
|
.dw 0x468C ;
|
|
.dw 0x468D ;
|
|
.dw 0x468E ;
|
|
.dw 0x468F ;
|
|
.dw 0x4690 ;
|
|
.dw 0x4691 ;
|
|
.dw 0x4692 ;
|
|
.dw 0x4693 ;
|
|
.dw 0x4694 ;
|
|
.dw 0x4695 ;
|
|
.dw 0x4696 ;
|
|
.dw 0x4697 ;
|
|
.dw 0x4698 ;
|
|
.dw 0x4699 ;
|
|
.dw 0x469A ;
|
|
.dw 0x469B ;
|
|
.dw 0x469C ;
|
|
.dw 0x469D ;
|
|
.dw 0x469E ;
|
|
.dw 0x469F ;
|
|
.dw 0x46A0 ;
|
|
.dw 0x46A1 ;
|
|
.dw 0x46A2 ;
|
|
.dw 0x46A3 ;
|
|
.dw 0x46A4 ;
|
|
.dw 0x46A5 ;
|
|
.dw 0x46A6 ;
|
|
.dw 0x46A7 ;
|
|
.dw 0x46A8 ;
|
|
.dw 0x46A9 ;
|
|
.dw 0x46AA ;
|
|
.dw 0x46AB ;
|
|
.dw 0x46AC ;
|
|
.dw 0x46AD ;
|
|
.dw 0x46AE ;
|
|
.dw 0x46AF ;
|
|
.dw 0x46B0 ;
|
|
.dw 0x46B1 ;
|
|
.dw 0x46B2 ;
|
|
.dw 0x46B3 ;
|
|
.dw 0x46B4 ;
|
|
.dw 0x46B5 ;
|
|
.dw 0x46B6 ;
|
|
.dw 0x46B7 ;
|
|
.dw 0x46B8 ;
|
|
.dw 0x46B9 ;
|
|
.dw 0x46BA ;
|
|
.dw 0x46BB ;
|
|
.dw 0x46BC ;
|
|
.dw 0x46BD ;
|
|
.dw 0x46BE ;
|
|
.dw 0x46BF ;
|
|
.dw 0x46C0 ;
|
|
.dw 0x46C1 ;
|
|
.dw 0x46C2 ;
|
|
.dw 0x46C3 ;
|
|
.dw 0x46C4 ;
|
|
.dw 0x46C5 ;
|
|
.dw 0x46C6 ;
|
|
.dw 0x46C7 ;
|
|
.dw 0x46C8 ;
|
|
.dw 0x46C9 ;
|
|
.dw 0x46CA ;
|
|
.dw 0x46CB ;
|
|
.dw 0x46CC ;
|
|
.dw 0x46CD ;
|
|
.dw 0x46CE ;
|
|
.dw 0x46CF ;
|
|
.dw 0x46D0 ;
|
|
.dw 0x46D1 ;
|
|
.dw 0x46D2 ;
|
|
.dw 0x46D3 ;
|
|
.dw 0x46D4 ;
|
|
.dw 0x46D5 ;
|
|
.dw 0x46D6 ;
|
|
.dw 0x46D7 ;
|
|
.dw 0x46D8 ;
|
|
.dw 0x46D9 ;
|
|
.dw 0x46DA ;
|
|
.dw 0x46DB ;
|
|
.dw 0x46DC ;
|
|
.dw 0x46DD ;
|
|
.dw 0x46DE ;
|
|
.dw 0x46DF ;
|
|
.dw 0x46E0 ;
|
|
.dw 0x46E1 ;
|
|
.dw 0x46E2 ;
|
|
.dw 0x46E3 ;
|
|
.dw 0x46E4 ;
|
|
.dw 0x46E5 ;
|
|
.dw 0x46E6 ;
|
|
.dw 0x46E7 ;
|
|
.dw 0x46E8 ;
|
|
.dw 0x46E9 ;
|
|
.dw 0x46EA ;
|
|
.dw 0x46EB ;
|
|
.dw 0x46EC ;
|
|
.dw 0x46ED ;
|
|
.dw 0x46EE ;
|
|
.dw 0x46EF ;
|
|
.dw 0x46F0 ;
|
|
.dw 0x46F1 ;
|
|
.dw 0x46F2 ;
|
|
.dw 0x46F3 ;
|
|
.dw 0x46F4 ;
|
|
.dw 0x46F5 ;
|
|
.dw 0x46F6 ;
|
|
.dw 0x46F7 ;
|
|
.dw 0x46F8 ;
|
|
.dw 0x46F9 ;
|
|
.dw 0x46FA ;
|
|
.dw 0x46FB ;
|
|
.dw 0x46FC ;
|
|
.dw 0x46FD ;
|
|
.dw 0x46FE ;
|
|
.dw 0x46FF ;
|
|
.dw 0x4700 ;
|
|
.dw 0x4701 ;
|
|
.dw 0x4702 ;
|
|
.dw 0x4703 ;
|
|
.dw 0x4704 ;
|
|
.dw 0x4705 ;
|
|
.dw 0x4706 ;
|
|
.dw 0x4707 ;
|
|
.dw 0x4708 ;
|
|
.dw 0x4709 ;
|
|
.dw 0x470A ;
|
|
.dw 0x470B ;
|
|
.dw 0x470C ;
|
|
.dw 0x470D ;
|
|
.dw 0x470E ;
|
|
.dw 0x470F ;
|
|
.dw 0x4710 ;
|
|
.dw 0x4711 ;
|
|
.dw 0x4712 ;
|
|
.dw 0x4713 ;
|
|
.dw 0x4714 ;
|
|
.dw 0x4715 ;
|
|
.dw 0x4716 ;
|
|
.dw 0x4717 ;
|
|
.dw 0x4718 ;
|
|
.dw 0x4719 ;
|
|
.dw 0x471A ;
|
|
.dw 0x471B ;
|
|
.dw 0x471C ;
|
|
.dw 0x471D ;
|
|
.dw 0x471E ;
|
|
.dw 0x471F ;
|
|
.dw 0x4720 ;
|
|
.dw 0x4721 ;
|
|
.dw 0x4722 ;
|
|
.dw 0x4723 ;
|
|
.dw 0x4724 ;
|
|
.dw 0x4725 ;
|
|
.dw 0x4726 ;
|
|
.dw 0x4727 ;
|
|
.dw 0x4728 ;
|
|
.dw 0x4729 ;
|
|
.dw 0x472A ;
|
|
.dw 0x472B ;
|
|
.dw 0x472C ;
|
|
.dw 0x472D ;
|
|
.dw 0x472E ;
|
|
.dw 0x472F ;
|
|
.dw 0x4730 ;
|
|
.dw 0x4731 ;
|
|
.dw 0x4732 ;
|
|
.dw 0x4733 ;
|
|
.dw 0x4734 ;
|
|
.dw 0x4735 ;
|
|
.dw 0x4736 ;
|
|
.dw 0x4737 ;
|
|
.dw 0x4738 ;
|
|
.dw 0x4739 ;
|
|
.dw 0x473A ;
|
|
.dw 0x473B ;
|
|
.dw 0x473C ;
|
|
.dw 0x473D ;
|
|
.dw 0x473E ;
|
|
.dw 0x473F ;
|
|
.dw 0x4740 ;
|
|
.dw 0x4741 ;
|
|
.dw 0x4742 ;
|
|
.dw 0x4743 ;
|
|
.dw 0x4744 ;
|
|
.dw 0x4745 ;
|
|
.dw 0x4746 ;
|
|
.dw 0x4747 ;
|
|
.dw 0x4748 ;
|
|
.dw 0x4749 ;
|
|
.dw 0x474A ;
|
|
.dw 0x474B ;
|
|
.dw 0x474C ;
|
|
.dw 0x474D ;
|
|
.dw 0x474E ;
|
|
.dw 0x474F ;
|
|
.dw 0x4750 ;
|
|
.dw 0x4751 ;
|
|
.dw 0x4752 ;
|
|
.dw 0x4753 ;
|
|
.dw 0x4754 ;
|
|
.dw 0x4755 ;
|
|
.dw 0x4756 ;
|
|
.dw 0x4757 ;
|
|
.dw 0x4758 ;
|
|
.dw 0x4759 ;
|
|
.dw 0x475A ;
|
|
.dw 0x475B ;
|
|
.dw 0x475C ;
|
|
.dw 0x475D ;
|
|
.dw 0x475E ;
|
|
.dw 0x475F ;
|
|
.dw 0x4760 ;
|
|
.dw 0x4761 ;
|
|
.dw 0x4762 ;
|
|
.dw 0x4763 ;
|
|
.dw 0x4764 ;
|
|
.dw 0x4765 ;
|
|
.dw 0x4766 ;
|
|
.dw 0x4767 ;
|
|
.dw 0x4768 ;
|
|
.dw 0x4769 ;
|
|
.dw 0x476A ;
|
|
.dw 0x476B ;
|
|
.dw 0x476C ;
|
|
.dw 0x476D ;
|
|
.dw 0x476E ;
|
|
.dw 0x476F ;
|
|
.dw 0x4770 ;
|
|
.dw 0x4771 ;
|
|
.dw 0x4772 ;
|
|
.dw 0x4773 ;
|
|
.dw 0x4774 ;
|
|
.dw 0x4775 ;
|
|
.dw 0x4776 ;
|
|
.dw 0x4777 ;
|
|
.dw 0x4778 ;
|
|
.dw 0x4779 ;
|
|
.dw 0x477A ;
|
|
.dw 0x477B ;
|
|
.dw 0x477C ;
|
|
.dw 0x477D ;
|
|
.dw 0x477E ;
|
|
.dw 0x477F ;
|
|
.dw 0x4780 ;
|
|
.dw 0x4781 ;
|
|
.dw 0x4782 ;
|
|
.dw 0x4783 ;
|
|
.dw 0x4784 ;
|
|
.dw 0x4785 ;
|
|
.dw 0x4786 ;
|
|
.dw 0x4787 ;
|
|
.dw 0x4788 ;
|
|
.dw 0x4789 ;
|
|
.dw 0x478A ;
|
|
.dw 0x478B ;
|
|
.dw 0x478C ;
|
|
.dw 0x478D ;
|
|
.dw 0x478E ;
|
|
.dw 0x478F ;
|
|
.dw 0x4790 ;
|
|
.dw 0x4791 ;
|
|
.dw 0x4792 ;
|
|
.dw 0x4793 ;
|
|
.dw 0x4794 ;
|
|
.dw 0x4795 ;
|
|
.dw 0x4796 ;
|
|
.dw 0x4797 ;
|
|
.dw 0x4798 ;
|
|
.dw 0x4799 ;
|
|
.dw 0x479A ;
|
|
.dw 0x479B ;
|
|
.dw 0x479C ;
|
|
.dw 0x479D ;
|
|
.dw 0x479E ;
|
|
.dw 0x479F ;
|
|
.dw 0x47A0 ;
|
|
.dw 0x47A1 ;
|
|
.dw 0x47A2 ;
|
|
.dw 0x47A3 ;
|
|
.dw 0x47A4 ;
|
|
.dw 0x47A5 ;
|
|
.dw 0x47A6 ;
|
|
.dw 0x47A7 ;
|
|
.dw 0x47A8 ;
|
|
.dw 0x47A9 ;
|
|
.dw 0x47AA ;
|
|
.dw 0x47AB ;
|
|
.dw 0x47AC ;
|
|
.dw 0x47AD ;
|
|
.dw 0x47AE ;
|
|
.dw 0x47AF ;
|
|
.dw 0x47B0 ;
|
|
.dw 0x47B1 ;
|
|
.dw 0x47B2 ;
|
|
.dw 0x47B3 ;
|
|
.dw 0x47B4 ;
|
|
.dw 0x47B5 ;
|
|
.dw 0x47B6 ;
|
|
.dw 0x47B7 ;
|
|
.dw 0x47B8 ;
|
|
.dw 0x47B9 ;
|
|
.dw 0x47BA ;
|
|
.dw 0x47BB ;
|
|
.dw 0x47BC ;
|
|
.dw 0x47BD ;
|
|
.dw 0x47BE ;
|
|
.dw 0x47BF ;
|
|
.dw 0x47C0 ;
|
|
.dw 0x47C1 ;
|
|
.dw 0x47C2 ;
|
|
.dw 0x47C3 ;
|
|
.dw 0x47C4 ;
|
|
.dw 0x47C5 ;
|
|
.dw 0x47C6 ;
|
|
.dw 0x47C7 ;
|
|
.dw 0x47C8 ;
|
|
.dw 0x47C9 ;
|
|
.dw 0x47CA ;
|
|
.dw 0x47CB ;
|
|
.dw 0x47CC ;
|
|
.dw 0x47CD ;
|
|
.dw 0x47CE ;
|
|
.dw 0x47CF ;
|
|
.dw 0x47D0 ;
|
|
.dw 0x47D1 ;
|
|
.dw 0x47D2 ;
|
|
.dw 0x47D3 ;
|
|
.dw 0x47D4 ;
|
|
.dw 0x47D5 ;
|
|
.dw 0x47D6 ;
|
|
.dw 0x47D7 ;
|
|
.dw 0x47D8 ;
|
|
.dw 0x47D9 ;
|
|
.dw 0x47DA ;
|
|
.dw 0x47DB ;
|
|
.dw 0x47DC ;
|
|
.dw 0x47DD ;
|
|
.dw 0x47DE ;
|
|
.dw 0x47DF ;
|
|
.dw 0x47E0 ;
|
|
.dw 0x47E1 ;
|
|
.dw 0x47E2 ;
|
|
.dw 0x47E3 ;
|
|
.dw 0x47E4 ;
|
|
.dw 0x47E5 ;
|
|
.dw 0x47E6 ;
|
|
.dw 0x47E7 ;
|
|
.dw 0x47E8 ;
|
|
.dw 0x47E9 ;
|
|
.dw 0x47EA ;
|
|
.dw 0x47EB ;
|
|
.dw 0x47EC ;
|
|
.dw 0x47ED ;
|
|
.dw 0x47EE ;
|
|
.dw 0x47EF ;
|
|
.dw 0x47F0 ;
|
|
.dw 0x47F1 ;
|
|
.dw 0x47F2 ;
|
|
.dw 0x47F3 ;
|
|
.dw 0x47F4 ;
|
|
.dw 0x47F5 ;
|
|
.dw 0x47F6 ;
|
|
.dw 0x47F7 ;
|
|
.dw 0x47F8 ;
|
|
.dw 0x47F9 ;
|
|
.dw 0x47FA ;
|
|
.dw 0x47FB ;
|
|
.dw 0x47FC ;
|
|
.dw 0x47FD ;
|
|
.dw 0x47FE ;
|
|
.dw 0x47FF ;
|
|
|
|
CHECK_INIT_DEF(p0); //CHECK_INIT(p0, 0xFF7FFFFC);
|
|
// Xhandler counts all EXCAUSE = 0x21;
|
|
CHECKREG(r5, 830); // count of all 16 bit UI's.
|
|
|
|
END:
|
|
dbg_pass; // End the test
|
|
|
|
//*********************************************************************
|
|
|
|
//
|
|
// Handlers for Events
|
|
//
|
|
|
|
NHANDLE: // NMI Handler 2
|
|
RTN;
|
|
|
|
XHANDLE: // Exception Handler 3
|
|
// 16 bit illegal opcode handler - skips bad instruction
|
|
|
|
[ -- SP ] = ASTAT; // save what we damage
|
|
[ -- SP ] = ( R7:6 );
|
|
R7 = SEQSTAT;
|
|
R7 <<= 26;
|
|
R7 >>= 26; // only want EXCAUSE
|
|
R6 = 0x21; // EXCAUSE 0x21 means I-Fetch Undefined Instruction
|
|
CC = r7 == r6;
|
|
IF CC JUMP UNDEFINEDINSTRUCTION; // If EXCAUSE != 0x21 then leave
|
|
|
|
JUMP.S OUT; // if the EXCAUSE is wrong the test will infinite loop
|
|
|
|
UNDEFINEDINSTRUCTION:
|
|
R7 = RETX; // Fix up return address
|
|
|
|
R7 += 2; // skip offending 16 bit instruction
|
|
|
|
RETX = r7; // and put back in RETX
|
|
|
|
R5 += 1; // Increment global counter
|
|
|
|
OUT:
|
|
( R7:6 ) = [ SP ++ ];
|
|
ASTAT = [sp++];
|
|
|
|
RTX;
|
|
|
|
HWHANDLE: // HW Error Handler 5
|
|
RTI;
|
|
|
|
THANDLE: // Timer Handler 6
|
|
RTI;
|
|
|
|
I7HANDLE: // IVG 7 Handler
|
|
RTI;
|
|
|
|
I8HANDLE: // IVG 8 Handler
|
|
RTI;
|
|
|
|
I9HANDLE: // IVG 9 Handler
|
|
RTI;
|
|
|
|
I10HANDLE: // IVG 10 Handler
|
|
RTI;
|
|
|
|
I11HANDLE: // IVG 11 Handler
|
|
RTI;
|
|
|
|
I12HANDLE: // IVG 12 Handler
|
|
RTI;
|
|
|
|
I13HANDLE: // IVG 13 Handler
|
|
RTI;
|
|
|
|
I14HANDLE: // IVG 14 Handler
|
|
RTI;
|
|
|
|
I15HANDLE: // IVG 15 Handler
|
|
RTI;
|
|
|
|
|
|
// padding for the icache
|
|
|
|
EXCPT 0; EXCPT 0; EXCPT 0; EXCPT 0; EXCPT 0; EXCPT 0; EXCPT 0;
|
|
|
|
//
|
|
// Data Segment
|
|
//
|
|
|
|
.data
|
|
DATA:
|
|
.space (0x10);
|
|
|
|
// Stack Segments (Both Kernel and User)
|
|
|
|
.space (STACKSIZE);
|
|
KSTACK:
|
|
|
|
.space (STACKSIZE);
|
|
USTACK:
|