mtc2.s 3.17 KB
/****************************************************************
  This program tests control paths for scalar loads and stores 
  moves from the VU (mfc2).
 ****************************************************************/

#include "suregre.h"

.base 0x04001000

	.data	0x04000000
	.word	0xfedcba98
	.word	0x01234567
	.word	0xfedcba98
	.word	0x01234567
	.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
	
	lw	r1, 0(r0)
	mtc2	r1, v1[0]
	sqv	v1, 0x100(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[0]
	sqv	v1, 0x200(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[2]
	sqv	v1, 0x110(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[2]
	sqv	v1, 0x210(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[4]
	sqv	v1, 0x120(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[4]
	sqv	v1, 0x220(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[6]
	sqv	v1, 0x130(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[6]
	sqv	v1, 0x230(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[8]
	sqv	v1, 0x140(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[8]
	sqv	v1, 0x240(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[10]
	sqv	v1, 0x150(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[10]
	sqv	v1, 0x250(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[12]
	sqv	v1, 0x160(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[12]
	sqv	v1, 0x260(r0)

	lw	r1, 0(r0)
	mtc2	r1, v1[14]
	sqv	v1, 0x170(r0)
	lw	r1, 4(r0)
	mtc2	r1, v1[14]
	sqv	v1, 0x270(r0)

	ori	r1, r0, 0xFEED;
        sw      r1, 0(r0)

        nop
        nop
        nop
        break
	nop
	nop
	nop
	nop
	nop