lsmisc1.s 5.96 KB
/****************************************************************
  This program tests control paths for vector loads.
 ****************************************************************/

#include "suregre.h"

.base 0x04001000

	.data	0x04000000
	.word	0x01820384
	.word	0x85068708
	.word	0x098A0B8C
	.word	0x8D0E8F10	
	.word	0x11921394
	.word	0x95169718
	.word	0x199A1B9C
	.word	0x9D1E9F20
	.word	0x21A223A4
	.word	0xA526A728
	.word	0x29AA2BAC
	.word	0xAD2EAF30
	.word	0x31B233B4
	.word	0xB536B738
	.word	0x39BA3BBC
	.word	0xBD3EBF40
	.word	0x41C243C4
	.word	0xC546C748
	.word	0x49CA4BCC
	.word	0xCD4ECF50
	.word	0x51D253D4
	.word	0xD556D758
	.word	0x59DA5BDC
	.word	0xDD5EDF60
	.word	0x61E263E4
	.word	0xE566E768
	.word	0x69EA6BEC
	.word	0xED6EEF70
	.word	0x71F273F4
	.word	0xF576F778
	.word	0x79FA7BFC
	.word	0xFD7E0080

	LI(r0 , 0xFFFF, 0xFFFF);
	LI(r1 , 0x0101, 0x0101);
	LI(r2 , 0x0202, 0x0202);
	LI(r3 , 0x0303, 0x0303);
	LI(r4 , 0x0404, 0x0404);
	LI(r5 , 0x0505, 0x0505);
	LI(r6 , 0x0606, 0x0606);
	LI(r7 , 0x0707, 0x0707);
	LI(r8 , 0x0808, 0x0808);
	LI(r9 , 0x0909, 0x0909);
	LI(r10, 0x0A0A, 0x0A0A);
	LI(r11, 0x0B0B, 0x0B0B);
	LI(r12, 0x0C0C, 0x0C0C);
	LI(r13, 0x0D0D, 0x0D0D);
	LI(r14, 0x0E0E, 0x0E0E);
	LI(r15, 0x0F0F, 0x0F0F);
	LI(r16, 0x1010, 0x1010);
	LI(r17, 0x1111, 0x1111);
	LI(r18, 0x1212, 0x1212);
	LI(r19, 0x1313, 0x1313);
	LI(r20, 0x1414, 0x1414);
	LI(r21, 0x1515, 0x1515);
	LI(r22, 0x1616, 0x1616);
	LI(r23, 0x1717, 0x1717);
	LI(r24, 0x1818, 0x1818);
	LI(r25, 0x1919, 0x1919);
	LI(r26, 0x1A1A, 0x1A1A);
	LI(r27, 0x1B1B, 0x1B1B);
	LI(r28, 0x1C1C, 0x1C1C);
	LI(r29, 0x1D1D, 0x1D1D);
	LI(r30, 0x1E1E, 0x1E1E);
	LI(r31, 0x1F1F, 0x1F1F);
	lqv	v0[0], 0 (r0);
	vxor	v0 , v0, v0
	vxor	v1 , v0, v0
	vxor	v2 , v0, v0
	vxor	v3 , v0, v0
	vxor	v4 , v0, v0
	vxor	v5 , v0, v0
	vxor	v6 , v0, v0
	vxor	v7 , v0, v0
	vxor	v8 , v0, v0
	vxor	v9 , v0, v0
	vxor	v10, v0, v0
	vxor	v11, v0, v0
	vxor	v12, v0, v0
	vxor	v13, v0, v0
	vxor	v14, v0, v0
	vxor	v15, v0, v0
	vxor	v16, v0, v0
	vxor	v17, v0, v0
	vxor	v18, v0, v0
	vxor	v19, v0, v0
	vxor	v20, v0, v0
	vxor	v21, v0, v0
	vxor	v22, v0, v0
	vxor	v23, v0, v0
	vxor	v24, v0, v0
	vxor	v25, v0, v0
	vxor	v26, v0, v0
	vxor	v27, v0, v0
	vxor	v28, v0, v0
	vxor	v29, v0, v0
	vxor	v30, v0, v0
	vxor	v31, v0, v0

	.word	0x41000000
	.word	0x00000000
	.word	0x00000000
	.word	0x00000000

	ChkVldTV( 1,lbv,r3 ,r4 ,r5 ,r2 ,v1 ,v0 ,0x0400,0x0080,0x0400,0x0040,0x0000,e0 ,0x00FF)

	.word	0x41000000
	.word	0x00000000
	.word	0x49CA0000
	.word	0x00000000

	ChkVldTV( 2,lsv,r4 ,r5 ,r6 ,r3 ,v18,v1 ,0x0400,0x0090,0x0400,0x0040,0x0008,e8 ,0x00FF)

	.word	0x39BA3BBC
	.word	0x00000000
	.word	0x49CA0000
	.word	0x00000000

	ChkVldTV( 3,llv,r5 ,r6 ,r7 ,r4 ,v19,v18,0x0400,0x00A0,0x0400,0x0038,0,e0 ,0x00FF)

	.word	0x39BA3BBC
	.word	0x00000000
	.word	0x71F273F4
	.word	0xF576F778

	ChkVldTV( 4,lrv,r6 ,r7 ,r8 ,r5 ,v20,v19,0x0400,0x00B0,0x0400,0x0078,0x0000,e0 ,0x00FF)

	.word	0x01008200
	.word	0x03008400
	.word	0x85000600
	.word	0x87000800

	ChkVldTV( 5,lpv,r7 ,r8 ,r9 ,r6 ,v21,v20,0x0400,0x00C0,0x0400,0x0000,0x0000,e0 ,0x00FF)

	.word	0x00804100
	.word	0x01804200
	.word	0x42800300
	.word	0x43800400

	ChkVldTV( 6,luv,r8 ,r9 ,r10,r7 ,v22,v21,0x0400,0x00D0,0x0400,0x0000,0x0000,e0 ,0x00FF)

	.word	0x61006200
	.word	0x23002400
	.word	0x65006600
	.word	0x27002800

	ChkVldTV( 7,lhv,r9 ,r10,r11,r8 ,v23,v22,0x0400,0x00E0,0x0400,0x0041,0x0000,e0 ,0x00FF)

	.word	0x61006200
	.word	0x23002400
	.word	0x42000400
	.word	0x46000800

	ChkVldTV( 8,lfv,r10,r11,r12,r9 ,v24,v23,0x0400,0x00F0,0x0400,0x0003,0x0000,e8 ,0x00FF)

        ori     $1,     $0,     9
	vxor	v0 , v0, v0
	vxor	v1 , v0, v0
	vxor	v2 , v0, v0
	vxor	v3 , v0, v0
	vxor	v4 , v0, v0
	vxor	v5 , v0, v0
	vxor	v6 , v0, v0
	vxor	v7 , v0, v0
	vxor	v8 , v0, v0
	vxor	v9 , v0, v0
	vxor	v10, v0, v0
	vxor	v11, v0, v0
	vxor	v12, v0, v0
	vxor	v13, v0, v0
	vxor	v14, v0, v0
	vxor	v15, v0, v0
        addi    $3,     $0,     0x0
        lsv     $v8[10],        0x0($3)
        lsv     $v9[12],        0x2($3)
        lsv     $v10[14],       0x4($3)
        lsv     $v11[0],        0x6($3)
        lsv     $v12[2],        0x8($3)
        lsv     $v13[4],        0xA($3)
        lsv     $v14[6],        0xC($3)
        lsv     $v15[8],        0xE($3)
        nop
        nop
        nop
        ltv     $v0[6], 0($3)
        nop
        nop
        nop

        ctc2    $0,     $v0
        nop
        veq     $v31,   $v0,    $v8
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v1,    $v9
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v2,    $v10
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v3,    $v11
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v4,    $v12
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v5,    $v13
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v6,    $v14
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop
        ctc2    $0,     $v0
        nop
        veq     $v31,   $v7,    $v15
        nop
        cfc2    $5,     $v1
        nop
        bne     $4,     $5,     Fail
        nop

	sqv	v0[0], 0x700 (r0); 
	sqv	v1[0], 0x710 (r0); 
	sqv	v2[0], 0x720 (r0); 
	sqv	v3[0], 0x730 (r0); 
	sqv	v4[0], 0x740 (r0); 
	sqv	v5[0], 0x750 (r0); 
	sqv	v6[0], 0x760 (r0); 
	sqv	v7[0], 0x770 (r0); 

        ori     r1, r0, 0xFEED;

Fail:   
        sw      r1, 0(r0)
        nop
        nop
        nop
        nop
        break
	nop
	nop
	nop
	nop
	nop