blob: 042621e3ef0bc02cf18cefe5644f04c34fa5c162 [file] [log] [blame]
/*
* Blackfin testcase for testing illegal/legal 16-bit opcodes from userspace
* we track all instructions which cause some sort of exception when run from
* userspace, this is normally EXCAUSE :
* - 0x21 : illegal instruction
* - 0x22 : illegal instruction combination
* - 0x2e : use of supervisor resource from userspace
* and walk every instruction from 0x0000 to 0xbfff
*/
# mach: bfin
# sim: --environment operating
#include "test.h"
#define SE_ALL_BITS 16
#define SE_ALL_NEW_INSN_STUB
#include "se_allopcodes.h"
.include "testutils.inc"
.macro se_all_load_insn
R2 = W[P5];
R0 = R2;
.endm
.macro se_all_next_insn
/* increment, and go again. */
R0 = R2;
R0 += 1;
/* finish once we hit the 32bit limit */
R1 = 0xC000 (Z);
CC = R1 == R0;
IF CC JUMP pass_lvl;
W[P5] = R0;
.endm
.macro se_all_new_insn_stub
jump _legal_instruction;
.endm
.macro se_all_insn_init
.dw 0x0000;
.endm
.macro se_all_insn_table
/* this table must be sorted, and end with zero */
/* start end SEQSTAT */
.dw 0x0001, 0x000f, 0x21
.dw 0x0011, 0x0013, 0x2e
.ifndef BFIN_JTAG
.dw 0x0014, 0x0014, 0x2e /* anomaly - RTX works when emulator attached */
.endif
.dw 0x0015, 0x001F, 0x21
.dw 0x0021, 0x0022, 0x21
.dw 0x0026, 0x0026, 0x21
.ifndef BFIN_JTAG
.dw 0x0027, 0x0027, 0x21 /* anomaly 492 - unknown */
.endif
.dw 0x0028, 0x002F, 0x21
.dw 0x0030, 0x0037, 0x2e
.dw 0x0038, 0x003F, 0x21
.dw 0x0040, 0x0047, 0x2e
.dw 0x0048, 0x004F, 0x21
.dw 0x0058, 0x005F, 0x21
.dw 0x0068, 0x006F, 0x21
.dw 0x0078, 0x007F, 0x21
.dw 0x0088, 0x008F, 0x21
.dw 0x0090, 0x009F, 0x2E
.dw 0x00a0, 0x00a0, 0x00
.dw 0x00a1, 0x00a1, 0x01
.dw 0x00a2, 0x00a2, 0x02
.dw 0x00a3, 0x00a3, 0x03
.dw 0x00a4, 0x00a4, 0x04
.dw 0x00a5, 0x00a5, 0x05
.dw 0x00a6, 0x00a6, 0x06
.dw 0x00a7, 0x00a7, 0x07
.dw 0x00a8, 0x00a8, 0x08
.dw 0x00a9, 0x00a9, 0x09
.dw 0x00aa, 0x00aa, 0x0a
.dw 0x00ab, 0x00ab, 0x0b
.dw 0x00ac, 0x00ac, 0x0c
.dw 0x00ad, 0x00ad, 0x0d
.dw 0x00ae, 0x00ae, 0x0e
.dw 0x00af, 0x00af, 0x0f
.dw 0x00b6, 0x010f, 0x21
.dw 0x0124, 0x0124, 0x21
.ifndef BFIN_JTAG
.dw 0x0125, 0x0125, 0x21 /* anomaly 492 res = [SP++] */
.endif
.dw 0x0128, 0x012F, 0x21
.dw 0x0138, 0x0138, 0x22
.dw 0x0139, 0x013F, 0x2E
.dw 0x0164, 0x0164, 0x21
.ifndef BFIN_JTAG
.dw 0x0165, 0x0165, 0x21 /* anomaly 492 [--SP] = res */
.endif
.dw 0x0168, 0x016F, 0x21
.dw 0x0178, 0x017F, 0x2E
.dw 0x0180, 0x01FF, 0x21
.dw 0x0210, 0x0217, 0x21
.ifndef BFIN_JTAG
.dw 0x0219, 0x021F, 0x21 /* anomaly 492 CC = !CC opcode is 0000 0010 0001 1xxx */
.endif
.dw 0x0220, 0x023F, 0x21
.dw 0x0280, 0x02FF, 0x21
.dw 0x0305, 0x0305, 0x21
.dw 0x0325, 0x0325, 0x21
.dw 0x0345, 0x0345, 0x21
.dw 0x0365, 0x0365, 0x21
.dw 0x0385, 0x0385, 0x21
.dw 0x03a5, 0x03a5, 0x21
.dw 0x03c5, 0x03c5, 0x21
.dw 0x03e5, 0x03e5, 0x21
.dw 0x0400, 0x047F, 0x21
.dw 0x0486, 0x04Bf, 0x21
.dw 0x04c6, 0x04FF, 0x21
.dw 0x0501, 0x0507, 0x21
.dw 0x0509, 0x050F, 0x21
.dw 0x0511, 0x0517, 0x21
.dw 0x0519, 0x051F, 0x21
.dw 0x0521, 0x0527, 0x21
.dw 0x0529, 0x052F, 0x21
.dw 0x0531, 0x0537, 0x21
.dw 0x0539, 0x053F, 0x21
.dw 0x0541, 0x0547, 0x21
.dw 0x0549, 0x054F, 0x21
.dw 0x0551, 0x0557, 0x21
.dw 0x0559, 0x055F, 0x21
.dw 0x0561, 0x0567, 0x21
.dw 0x0569, 0x056F, 0x21
.dw 0x0571, 0x0577, 0x21
.dw 0x0579, 0x057F, 0x21
.dw 0x0586, 0x0587, 0x21
.dw 0x058e, 0x058F, 0x21
.dw 0x0596, 0x0597, 0x21
.dw 0x059e, 0x059f, 0x21
.dw 0x05a6, 0x05a7, 0x21
.dw 0x05ae, 0x05af, 0x21
.dw 0x05b6, 0x05b7, 0x21
.dw 0x05be, 0x05bf, 0x21
.dw 0x05c6, 0x05c7, 0x21
.dw 0x05ce, 0x05cf, 0x21
.dw 0x05d6, 0x05d7, 0x21
.dw 0x05de, 0x05df, 0x21
.dw 0x05e6, 0x05e7, 0x21
.dw 0x05ee, 0x05ef, 0x21
.dw 0x05f6, 0x05f7, 0x21
.dw 0x05fe, 0x05ff, 0x21
.dw 0x0a81, 0x0aff, 0x21
.dw 0x0b01, 0x0b7f, 0x21
.dw 0x0b81, 0x0bff, 0x21
.dw 0x0e80, 0x0fff, 0x21
.dw 0x3104, 0x3105, 0x21
.dw 0x310c, 0x310d, 0x21
.dw 0x3114, 0x3115, 0x21
.dw 0x311c, 0x311d, 0x21
.dw 0x3124, 0x3125, 0x21
.dw 0x312c, 0x312d, 0x21
.dw 0x3134, 0x3135, 0x21
.dw 0x313c, 0x313d, 0x21
.dw 0x3140, 0x317F, 0x21
.dw 0x31c0, 0x31ff, 0x2E
.dw 0x3304, 0x3305, 0x21
.dw 0x330c, 0x330d, 0x21
.dw 0x3314, 0x3315, 0x21
.dw 0x331c, 0x331d, 0x21
.dw 0x3324, 0x3325, 0x21
.dw 0x332c, 0x332d, 0x21
.dw 0x3334, 0x3335, 0x21
.dw 0x333c, 0x333d, 0x21
.dw 0x3340, 0x337f, 0x21
.dw 0x33c0, 0x33ff, 0x2e
.dw 0x3504, 0x3507, 0x21
.dw 0x350c, 0x350F, 0x21
.dw 0x3514, 0x3517, 0x21
.dw 0x351c, 0x351F, 0x21
.dw 0x3524, 0x3527, 0x21
.dw 0x352c, 0x352f, 0x21
.dw 0x3534, 0x3537, 0x21
.dw 0x353c, 0x353f, 0x21
.dw 0x3540, 0x35c6, 0x21
.dw 0x35c7, 0x35c7, 0x2e
.dw 0x35c8, 0x35ce, 0x21
.dw 0x35cf, 0x35cf, 0x2e
.dw 0x35d0, 0x35d6, 0x21
.dw 0x35d7, 0x35d7, 0x2e
.dw 0x35d8, 0x35de, 0x21
.dw 0x35df, 0x35df, 0x2e
.dw 0x35e0, 0x35e6, 0x21
.dw 0x35e7, 0x35e7, 0x2e
.dw 0x35e8, 0x35ee, 0x21
.dw 0x35ef, 0x35ef, 0x2e
.dw 0x35f0, 0x35f6, 0x21
.dw 0x35f7, 0x35f7, 0x2e
.dw 0x35f8, 0x35fe, 0x21
.dw 0x35ff, 0x35ff, 0x2e
.dw 0x3704, 0x3707, 0x21
.dw 0x370c, 0x370f, 0x21
.dw 0x3714, 0x3717, 0x21
.dw 0x371c, 0x371f, 0x21
.dw 0x3724, 0x3727, 0x21
.dw 0x372c, 0x372f, 0x21
.dw 0x3734, 0x3737, 0x21
.dw 0x373c, 0x37c6, 0x21
.dw 0x37c7, 0x37c7, 0x2e
.dw 0x37c8, 0x37ce, 0x21
.dw 0x37cf, 0x37cf, 0x2e
.dw 0x37d0, 0x37d6, 0x21
.dw 0x37d7, 0x37d7, 0x2e
.dw 0x37d8, 0x37de, 0x21
.dw 0x37df, 0x37df, 0x2e
.dw 0x37e0, 0x37e6, 0x21
.dw 0x37e7, 0x37e7, 0x2e
.dw 0x37e8, 0x37ee, 0x21
.dw 0x37ef, 0x37ef, 0x2e
.dw 0x37f0, 0x37f6, 0x21
.dw 0x37f7, 0x37f7, 0x2e
.dw 0x37f8, 0x37fe, 0x21
.dw 0x37ff, 0x37ff, 0x2e
.dw 0x3820, 0x382f, 0x21
.dw 0x3860, 0x386f, 0x21
.dw 0x38a0, 0x38af, 0x21
.dw 0x38b0, 0x38bf, 0x21
.dw 0x38e0, 0x38ef, 0x21
.dw 0x38f0, 0x38ff, 0x21
.dw 0x3904, 0x3907, 0x21
.dw 0x390c, 0x390f, 0x21
.dw 0x3914, 0x3917, 0x21
.dw 0x391c, 0x392f, 0x21
.dw 0x3934, 0x3937, 0x21
.dw 0x393c, 0x39bf, 0x21
.dw 0x397f, 0x397f, 0x2e
.dw 0x3980, 0x39bf, 0x21
.dw 0x39c0, 0x39c0, 0x2e
.dw 0x39c1, 0x39c7, 0x21
.dw 0x39c8, 0x39c8, 0x2e
.dw 0x39c9, 0x39cf, 0x21
.dw 0x39d0, 0x39d0, 0x2e
.dw 0x39d1, 0x39d7, 0x21
.dw 0x39d8, 0x39d8, 0x2e
.dw 0x39d9, 0x39ef, 0x21
.dw 0x39f0, 0x39f0, 0x2e
.dw 0x39f1, 0x39f6, 0x21
.dw 0x39f7, 0x39f8, 0x2e
.dw 0x39f9, 0x39fe, 0x21
.dw 0x39ff, 0x39ff, 0x2e
.dw 0x3a00, 0x3bff, 0x21
.dw 0x3c80, 0x3cff, 0x21
.dw 0x3d04, 0x3d07, 0x21
.dw 0x3d0c, 0x3d0f, 0x21
.dw 0x3d14, 0x3d17, 0x21
.dw 0x3d1c, 0x3d1f, 0x21
.dw 0x3d24, 0x3d27, 0x21
.dw 0x3d2c, 0x3d2f, 0x21
.dw 0x3d34, 0x3d37, 0x21
.dw 0x3d3c, 0x3dbf, 0X21
.dw 0x3dc0, 0x3dc0, 0x2e
.dw 0x3dc1, 0x3dc6, 0x21
.dw 0x3dc7, 0x3dc8, 0x2e
.dw 0x3dc9, 0x3dce, 0x21
.dw 0x3dcf, 0x3dd0, 0x2e
.dw 0x3dd1, 0x3dd6, 0x21
.dw 0x3dd7, 0x3dd8, 0x2e
.dw 0x3dd9, 0x3dde, 0x21
.dw 0x3ddf, 0x3de0, 0x2e
.dw 0x3de1, 0x3de6, 0x21
.dw 0x3de7, 0x3de8, 0x2e
.dw 0x3de9, 0x3dee, 0x21
.dw 0x3def, 0x3df0, 0x2e
.dw 0x3df1, 0x3df6, 0x21
.dw 0x3df7, 0x3df8, 0x2e
.dw 0x3df9, 0x3dfe, 0x21
.dw 0x3dff, 0x3e7f, 0x2e
.dw 0x3e80, 0x3eb7, 0x21
.dw 0x3eb8, 0x3ebf, 0x2e
.dw 0x3ec0, 0x3ef7, 0x21
.dw 0x3ef8, 0x3f03, 0x2e
.dw 0x3f04, 0x3f07, 0x21
.dw 0x3f08, 0x3f0b, 0x2e
.dw 0x3f0c, 0x3f0f, 0x21
.dw 0x3f10, 0x3f13, 0x2e
.dw 0x3f14, 0x3f17, 0x21
.dw 0x3f18, 0x3f1b, 0x2e
.dw 0x3f1c, 0x3f1f, 0x21
.dw 0x3f20, 0x3f23, 0x2e
.dw 0x3f24, 0x3f27, 0x21
.dw 0x3f28, 0x3f2b, 0x2e
.dw 0x3f2c, 0x3f2f, 0x21
.dw 0x3f30, 0x3f33, 0x2e
.dw 0x3f34, 0x3f37, 0x21
.dw 0x3f38, 0x3f3b, 0x2e
.dw 0x3f3c, 0x3f3d, 0x21
.dw 0x3f3e, 0x3f3f, 0x2e
.dw 0x3f40, 0x3fb7, 0x21
.dw 0x3fb8, 0x3fc0, 0x2e
.dw 0x3fc1, 0x3fc6, 0x21
.dw 0x3fc7, 0x3fc8, 0x2e
.dw 0x3fc9, 0x3fce, 0x21
.dw 0x3fcf, 0x3fd0, 0x2e
.dw 0x3fd1, 0x3fd6, 0x21
.dw 0x3fd7, 0x3fd8, 0x2e
.dw 0x3fd9, 0x3fde, 0x21
.dw 0x3fdf, 0x3fe0, 0x2e
.dw 0x3fe1, 0x3fe6, 0x21
.dw 0x3fe7, 0x3fe8, 0x2e
.dw 0x3fe9, 0x3fee, 0x21
.dw 0x3fef, 0x3ff0, 0x2e
.dw 0x3ff1, 0x3ff6, 0x21
.dw 0x3ff7, 0x3fff, 0x2e
.dw 0x4180, 0x41FF, 0x21
.dw 0x4480, 0x44bF, 0x21
.dw 0x4600, 0x47FF, 0x21
.dw 0x7000, 0x7FFF, 0x21
.dw 0x9040, 0x9040, 0x22
.dw 0x9049, 0x9049, 0x22
.dw 0x9052, 0x9052, 0x22
.dw 0x905b, 0x905b, 0x22
.dw 0x9064, 0x9064, 0x22
.dw 0x906d, 0x906d, 0x22
.dw 0x9076, 0x9076, 0x22
.dw 0x907f, 0x907f, 0x22
.dw 0x90c0, 0x90c0, 0x22
.dw 0x90c9, 0x90c9, 0x22
.dw 0x90d2, 0x90d2, 0x22
.dw 0x90db, 0x90db, 0x22
.dw 0x90e4, 0x90e4, 0x22
.dw 0x90ed, 0x90ed, 0x22
.dw 0x90f6, 0x90f6, 0x22
.dw 0x90ff, 0x90ff, 0x22
.dw 0x9180, 0x91ff, 0x21
.dw 0x9380, 0x93ff, 0x21
.dw 0x9580, 0x95ff, 0x21
.dw 0x9640, 0x967f, 0x21
.dw 0x96c0, 0x96ff, 0x21
.dw 0x9740, 0x97ff, 0x21
.dw 0x9980, 0x99ff, 0x21
.dw 0x9a40, 0x9a7f, 0x21
.dw 0x9ac0, 0x9aff, 0x21
.dw 0x9b40, 0x9bff, 0x21
.dw 0x9c60, 0x9c7f, 0x21
.dw 0x9ce0, 0x9cff, 0x21
.dw 0x9d60, 0x9d7f, 0x21
.dw 0x9ef0, 0x9eff, 0x21
.dw 0x9f70, 0x9f7f, 0x21
.dw 0x0000, 0x0000, 0x00
.endm
se_all_test