| //Original:/testcases/core/c_dsp32shiftim_lhalf_rp/c_dsp32shiftim_lhalf_rp.dsp |
| // Spec Reference: dspshiftimm dreg_lo(hi) = lshift (dreg_lo(hi) by imm5) |
| # mach: bfin |
| |
| .include "testutils.inc" |
| start |
| |
| |
| |
| // lshift : positive data, count (+)=left (half reg) |
| // d_lo = lshift (d_lo BY d_lo) |
| // RLx by RLx |
| imm32 r0, 0x00000000; |
| R0.L = -1; |
| imm32 r1, 0x90000001; |
| imm32 r2, 0x90000002; |
| imm32 r3, 0x90000003; |
| imm32 r4, 0x90000004; |
| imm32 r5, 0x90000005; |
| imm32 r6, 0x90000006; |
| imm32 r7, 0x90000007; |
| R0.L = R0.L << 0; |
| R1.L = R1.L >> 1; |
| R2.L = R2.L >> 2; |
| R3.L = R3.L >> 3; |
| R4.L = R4.L >> 4; |
| R5.L = R5.L >> 5; |
| R6.L = R6.L >> 6; |
| R7.L = R7.L >> 7; |
| CHECKREG r0, 0x0000FFFF; |
| CHECKREG r1, 0x90000000; |
| CHECKREG r2, 0x90000000; |
| CHECKREG r3, 0x90000000; |
| CHECKREG r4, 0x90000000; |
| CHECKREG r5, 0x90000000; |
| CHECKREG r6, 0x90000000; |
| CHECKREG r7, 0x90000000; |
| |
| imm32 r0, 0x00001001; |
| R1.L = -1; |
| imm32 r2, 0xa0002002; |
| imm32 r3, 0xa0003003; |
| imm32 r4, 0xa0004004; |
| imm32 r5, 0xa0005005; |
| imm32 r6, 0xa0006006; |
| imm32 r7, 0xa0007007; |
| R0.L = R0.L >> 1; |
| R1.L = R1.L >> 1; |
| R2.L = R2.L >> 1; |
| R3.L = R3.L >> 1; |
| R4.L = R4.L >> 1; |
| R5.L = R5.L >> 1; |
| R6.L = R6.L >> 1; |
| R7.L = R7.L >> 1; |
| CHECKREG r0, 0x00000800; |
| CHECKREG r1, 0x90007FFF; |
| CHECKREG r2, 0xA0001001; |
| CHECKREG r3, 0xA0001801; |
| CHECKREG r4, 0xA0002002; |
| CHECKREG r5, 0xA0002802; |
| CHECKREG r6, 0xA0003003; |
| CHECKREG r7, 0xA0003803; |
| |
| |
| imm32 r0, 0xb0001001; |
| imm32 r1, 0xb0001001; |
| R2.L = -15; |
| imm32 r3, 0xb0003003; |
| imm32 r4, 0xb0004004; |
| imm32 r5, 0xb0005005; |
| imm32 r6, 0xb0006006; |
| imm32 r7, 0xb0007007; |
| R0.L = R0.L >> 15; |
| R1.L = R1.L >> 15; |
| R2.L = LSHIFT R2.L BY R2.L; |
| R3.L = R3.L >> 15; |
| R4.L = R4.L >> 15; |
| R5.L = R5.L >> 15; |
| R6.L = R6.L >> 15; |
| R7.L = R7.L >> 15; |
| CHECKREG r0, 0xb0000000; |
| CHECKREG r1, 0xb0000000; |
| CHECKREG r2, 0xA0000001; |
| CHECKREG r3, 0xB0000000; |
| CHECKREG r4, 0xb0000000; |
| CHECKREG r5, 0xb0000000; |
| CHECKREG r6, 0xb0000000; |
| CHECKREG r7, 0xB0000000; |
| |
| imm32 r0, 0xc0001001; |
| imm32 r1, 0xc0001001; |
| imm32 r2, 0xc0002002; |
| R3.L = -16; |
| imm32 r4, 0xc0004004; |
| imm32 r5, 0xc0005005; |
| imm32 r6, 0xc0006006; |
| imm32 r7, 0xc0007007; |
| R0.L = R0.L >> 13; |
| R1.L = R1.L >> 13; |
| R2.L = R2.L >> 13; |
| R3.L = R3.L >> 13; |
| R4.L = R4.L >> 13; |
| R5.L = R5.L >> 13; |
| R6.L = R6.L >> 13; |
| R7.L = R7.L >> 13; |
| CHECKREG r0, 0xc0000000; |
| CHECKREG r1, 0xc0000000; |
| CHECKREG r2, 0xC0000001; |
| CHECKREG r3, 0xB0000007; |
| CHECKREG r4, 0xC0000002; |
| CHECKREG r5, 0xC0000002; |
| CHECKREG r6, 0xC0000003; |
| CHECKREG r7, 0xC0000003; |
| |
| // RHx by RLx |
| imm32 r0, 0x0000c000; |
| imm32 r1, 0x0001c000; |
| imm32 r2, 0x0002c000; |
| imm32 r3, 0x0003c000; |
| imm32 r4, 0x0004c000; |
| imm32 r5, 0x0005c000; |
| imm32 r6, 0x0006c000; |
| imm32 r7, 0x0007c000; |
| R0.L = R0.H << 0; |
| R1.L = R1.H << 0; |
| R2.L = R2.H << 0; |
| R3.L = R3.H << 0; |
| R4.L = R4.H << 0; |
| R5.L = R5.H << 0; |
| R6.L = R6.H << 0; |
| R7.L = R7.H << 0; |
| CHECKREG r0, 0x00000000; |
| CHECKREG r1, 0x00010001; |
| CHECKREG r2, 0x00020002; |
| CHECKREG r3, 0x00030003; |
| CHECKREG r4, 0x00040004; |
| CHECKREG r5, 0x00050005; |
| CHECKREG r6, 0x00060006; |
| CHECKREG r7, 0x00070007; |
| |
| imm32 r0, 0x10010000; |
| R1.L = -1; |
| imm32 r2, 0x20020000; |
| imm32 r3, 0x30030000; |
| imm32 r4, 0x40040000; |
| imm32 r5, 0x50050000; |
| imm32 r6, 0x60060000; |
| imm32 r7, 0x70070000; |
| R0.L = R0.H >> 1; |
| R1.L = R1.H >> 1; |
| R2.L = R2.H >> 1; |
| R3.L = R3.H >> 1; |
| R4.L = R4.H >> 1; |
| R5.L = R5.H >> 1; |
| R6.L = R6.H >> 1; |
| R7.L = R7.H >> 1; |
| CHECKREG r0, 0x10010800; |
| CHECKREG r1, 0x00010000; |
| CHECKREG r2, 0x20021001; |
| CHECKREG r3, 0x30031801; |
| CHECKREG r4, 0x40042002; |
| CHECKREG r5, 0x50052802; |
| CHECKREG r6, 0x60063003; |
| CHECKREG r7, 0x70073803; |
| |
| |
| imm32 r0, 0x1001e000; |
| imm32 r1, 0x1001e000; |
| R2.L = -15; |
| imm32 r3, 0x3003e000; |
| imm32 r4, 0x4004e000; |
| imm32 r5, 0x5005e000; |
| imm32 r6, 0x6006e000; |
| imm32 r7, 0x7007e000; |
| R0.L = R0.H >> 15; |
| R1.L = R1.H >> 15; |
| R2.L = R2.H >> 15; |
| R3.L = R3.H >> 15; |
| R4.L = R4.H >> 15; |
| R5.L = R5.H >> 15; |
| R6.L = R6.H >> 15; |
| R7.L = R7.H >> 15; |
| CHECKREG r0, 0x10010000; |
| CHECKREG r1, 0x10010000; |
| CHECKREG r2, 0x20020000; |
| CHECKREG r3, 0x30030000; |
| CHECKREG r4, 0x40040000; |
| CHECKREG r5, 0x50050000; |
| CHECKREG r6, 0x60060000; |
| CHECKREG r7, 0x70070000; |
| |
| imm32 r0, 0x1001f001; |
| imm32 r1, 0x1001f001; |
| imm32 r2, 0x2002f002; |
| R3.L = -16; |
| imm32 r4, 0x4004f004; |
| imm32 r5, 0x5005f005; |
| imm32 r6, 0x6006f006; |
| imm32 r7, 0x7007f007; |
| R0.L = R0.H >> 13; |
| R1.L = R1.H >> 13; |
| R2.L = R2.H >> 13; |
| R3.L = R3.H >> 13; |
| R4.L = R4.H >> 13; |
| R5.L = R5.H >> 13; |
| R6.L = R6.H >> 13; |
| R7.L = R7.H >> 13; |
| CHECKREG r0, 0x10010000; |
| CHECKREG r1, 0x10010000; |
| CHECKREG r2, 0x20020001; |
| CHECKREG r3, 0x30030001; |
| CHECKREG r4, 0x40040002; |
| CHECKREG r5, 0x50050002; |
| CHECKREG r6, 0x60060003; |
| CHECKREG r7, 0x70070003; |
| |
| // RLx by RLx |
| imm32 r0, 0x00001001; |
| imm32 r1, 0x00001001; |
| imm32 r2, 0x00001002; |
| imm32 r3, 0x00001003; |
| imm32 r4, 0x00001000; |
| imm32 r5, 0x00001005; |
| imm32 r6, 0x00001006; |
| imm32 r7, 0x00001007; |
| R0.H = R0.L >> 14; |
| R1.H = R1.L >> 14; |
| R2.H = R2.L >> 14; |
| R3.H = R3.L >> 14; |
| R4.H = R4.L >> 14; |
| R5.H = R5.L >> 14; |
| R6.H = R6.L >> 14; |
| R7.H = R7.L >> 14; |
| CHECKREG r0, 0x00001001; |
| CHECKREG r1, 0x00001001; |
| CHECKREG r2, 0x00001002; |
| CHECKREG r3, 0x00001003; |
| CHECKREG r4, 0x00001000; |
| CHECKREG r5, 0x00001005; |
| CHECKREG r6, 0x00001006; |
| CHECKREG r7, 0x00001007; |
| |
| imm32 r0, 0x00002001; |
| imm32 r1, 0x00002001; |
| imm32 r2, 0x00002002; |
| imm32 r3, 0x00002003; |
| imm32 r4, 0x00002004; |
| R5.L = -1; |
| imm32 r6, 0x00000006; |
| imm32 r7, 0x00000007; |
| R0.H = R0.L >> 5; |
| R1.H = R1.L >> 5; |
| R2.H = R2.L >> 5; |
| R3.H = R3.L >> 5; |
| R4.H = R4.L >> 5; |
| R5.H = R5.L >> 5; |
| R6.H = R6.L >> 5; |
| R7.H = R7.L >> 5; |
| CHECKREG r0, 0x01002001; |
| CHECKREG r1, 0x01002001; |
| CHECKREG r2, 0x01002002; |
| CHECKREG r3, 0x01002003; |
| CHECKREG r4, 0x01002004; |
| CHECKREG r5, 0x07FFFFFF; |
| CHECKREG r6, 0x00000006; |
| CHECKREG r7, 0x00000007; |
| |
| |
| imm32 r0, 0x30001001; |
| imm32 r1, 0x30001001; |
| imm32 r1, 0x30002002; |
| imm32 r3, 0x30003003; |
| imm32 r4, 0x30004004; |
| imm32 r5, 0x30005005; |
| R6.L = -15; |
| imm32 r7, 0x00007007; |
| R0.H = R0.L >> 15; |
| R1.H = R1.L >> 15; |
| R2.H = R2.L >> 15; |
| R3.H = R3.L >> 15; |
| R4.H = R4.L >> 15; |
| R5.H = R5.L >> 15; |
| R6.H = R6.L >> 15; |
| R7.H = R7.L >> 15; |
| CHECKREG r0, 0x00001001; |
| CHECKREG r1, 0x00002002; |
| CHECKREG r2, 0x00002002; |
| CHECKREG r3, 0x00003003; |
| CHECKREG r4, 0x00004004; |
| CHECKREG r5, 0x00005005; |
| CHECKREG r6, 0x0001FFF1; |
| CHECKREG r7, 0x00007007; |
| |
| imm32 r0, 0x40001001; |
| imm32 r1, 0x40002001; |
| imm32 r2, 0x40002002; |
| imm32 r3, 0x40003003; |
| imm32 r4, 0x40004004; |
| imm32 r5, 0x40005005; |
| imm32 r6, 0x40006006; |
| R7.L = -16; |
| R0.H = R0.L >> 7; |
| R1.H = R1.L >> 7; |
| R2.H = R2.L >> 7; |
| R3.H = R3.L >> 7; |
| R4.H = R4.L >> 7; |
| R5.H = R5.L >> 7; |
| R6.H = R6.L >> 7; |
| R7.H = R7.L >> 7; |
| CHECKREG r0, 0x00201001; |
| CHECKREG r1, 0x00402001; |
| CHECKREG r2, 0x00402002; |
| CHECKREG r3, 0x00603003; |
| CHECKREG r4, 0x00804004; |
| CHECKREG r5, 0x00A05005; |
| CHECKREG r6, 0x00C06006; |
| CHECKREG r7, 0x01FFFFF0; |
| |
| // RHx by RLx |
| imm32 r0, 0x50010000; |
| imm32 r1, 0x50010000; |
| imm32 r2, 0x50020000; |
| imm32 r3, 0x50030000; |
| R4.L = -1; |
| imm32 r5, 0x50050000; |
| imm32 r6, 0x50060000; |
| imm32 r7, 0x50070000; |
| R0.H = R0.H >> 1; |
| R1.H = R1.H >> 1; |
| R2.H = R2.H >> 1; |
| R3.H = R3.H >> 1; |
| R4.H = R4.H >> 1; |
| R5.H = R5.H >> 1; |
| R6.H = R6.H >> 1; |
| R7.H = R7.H >> 1; |
| CHECKREG r0, 0x28000000; |
| CHECKREG r1, 0x28000000; |
| CHECKREG r2, 0x28010000; |
| CHECKREG r3, 0x28010000; |
| CHECKREG r4, 0x0040FFFF; |
| CHECKREG r5, 0x28020000; |
| CHECKREG r6, 0x28030000; |
| CHECKREG r7, 0x28030000; |
| |
| imm32 r0, 0x10010000; |
| imm32 r1, 0x10010000; |
| imm32 r2, 0x20020000; |
| imm32 r3, 0x30030000; |
| imm32 r4, 0x40040000; |
| R5.L = -1; |
| imm32 r6, 0x60060000; |
| imm32 r7, 0x70070000; |
| R0.H = R0.H >> 5; |
| R1.H = R1.H >> 5; |
| R2.H = R2.H >> 5; |
| R3.H = R3.H >> 5; |
| R4.H = R4.H >> 5; |
| R5.H = R5.H >> 5; |
| R6.H = R6.H >> 5; |
| R7.H = R7.H >> 5; |
| CHECKREG r0, 0x00800000; |
| CHECKREG r1, 0x00800000; |
| CHECKREG r2, 0x01000000; |
| CHECKREG r3, 0x01800000; |
| CHECKREG r4, 0x02000000; |
| CHECKREG r5, 0x0140FFFF; |
| CHECKREG r6, 0x03000000; |
| CHECKREG r7, 0x03800000; |
| |
| |
| imm32 r0, 0x10010000; |
| imm32 r1, 0x10010000; |
| imm32 r2, 0x20020000; |
| imm32 r3, 0x30030000; |
| imm32 r4, 0x40040000; |
| imm32 r5, 0x50050000; |
| R6.L = -15; |
| imm32 r7, 0x70070000; |
| R0.L = R0.H >> 6; |
| R1.L = R1.H >> 6; |
| R2.L = R2.H >> 6; |
| R3.L = R3.H >> 6; |
| R4.L = R4.H >> 6; |
| R5.L = R5.H >> 6; |
| R6.L = R6.H >> 6; |
| R7.L = R7.H >> 6; |
| CHECKREG r0, 0x10010040; |
| CHECKREG r1, 0x10010040; |
| CHECKREG r2, 0x20020080; |
| CHECKREG r3, 0x300300C0; |
| CHECKREG r4, 0x40040100; |
| CHECKREG r5, 0x50050140; |
| CHECKREG r6, 0x0300000C; |
| CHECKREG r7, 0x700701C0; |
| |
| imm32 r0, 0x10010000; |
| imm32 r1, 0x10010000; |
| imm32 r2, 0x20020000; |
| imm32 r2, 0x30030000; |
| imm32 r4, 0x40040000; |
| imm32 r5, 0x50050000; |
| imm32 r6, 0x60060000; |
| R7.L = -16; |
| R0.H = R0.H >> 15; |
| R1.H = R1.H >> 15; |
| R2.H = R2.H >> 15; |
| R3.H = R3.H >> 15; |
| R4.H = R4.H >> 15; |
| R5.H = R5.H >> 15; |
| R6.H = R6.H >> 15; |
| R7.H = R7.H >> 15; |
| CHECKREG r0, 0x00000000; |
| CHECKREG r1, 0x00000000; |
| CHECKREG r2, 0x00000000; |
| CHECKREG r3, 0x000000C0; |
| CHECKREG r4, 0x00000000; |
| CHECKREG r5, 0x00000000; |
| CHECKREG r6, 0x00000000; |
| CHECKREG r7, 0x0000FFF0; |
| |
| pass |