lw1.s 4.57 KB
/****************************************************************
  This program tests the instruction: lw
 ****************************************************************/

#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);
	ChkLd( 1,lw,r5 ,0x0505,0x0505,0x0000,r4 ,0x0400,0x0000,0x0182,0x0384,r2 )
	ChkLd( 2,lw,r6 ,0x0606,0x0606,0x0004,r5 ,0x0400,0x0000,0x8506,0x8708,r3 )
	ChkLd( 3,lw,r7 ,0x0707,0x0707,0x0008,r6 ,0x0400,0x0000,0x098A,0x0B8C,r4 )
	ChkLd( 4,lw,r8 ,0x0808,0x0808,0x000C,r7 ,0x0400,0x0000,0x8D0E,0x8F10,r5 )
	ChkLd( 5,lw,r9 ,0x0909,0x0909,0x0010,r8 ,0x0400,0x0000,0x1192,0x1394,r6 )
	ChkLd( 6,lw,r10,0x0A0A,0x0A0A,0x0014,r9 ,0x0400,0x0000,0x9516,0x9718,r7 )
	ChkLd( 7,lw,r11,0x0B0B,0x0B0B,0x0018,r10,0x0400,0x0000,0x199A,0x1B9C,r8 )
	ChkLd( 8,lw,r12,0x0C0C,0x0C0C,0x001C,r11,0x0400,0x0000,0x9D1E,0x9F20,r9 )
	ChkLd( 9,lw,r13,0x0D0D,0x0D0D,0x0020,r12,0x0400,0x0000,0x21A2,0x23A4,r10)
	ChkLd(10,lw,r14,0x0E0E,0x0E0E,0x0024,r13,0x0400,0x0000,0xA526,0xA728,r11)
	ChkLd(11,lw,r15,0x0F0F,0x0F0F,0x0028,r14,0x0400,0x0000,0x29AA,0x2BAC,r12)
	ChkLd(12,lw,r16,0x1010,0x1010,0x002C,r15,0x0400,0x0000,0xAD2E,0xAF30,r13)
	ChkLd(13,lw,r17,0x1111,0x1111,0x0030,r16,0x0400,0x0000,0x31B2,0x33B4,r14)
	ChkLd(14,lw,r18,0x1212,0x1212,0x0034,r17,0x0400,0x0000,0xB536,0xB738,r15)
	ChkLd(15,lw,r19,0x1313,0x1313,0x0038,r18,0x0400,0x0000,0x39BA,0x3BBC,r16)
	ChkLd(16,lw,r20,0x1414,0x1414,0x003C,r19,0x0400,0x0000,0xBD3E,0xBF40,r17)
	ChkLd(17,lw,r21,0x1515,0x1515,0x0040,r20,0x0400,0x0000,0x41C2,0x43C4,r18)
	ChkLd(18,lw,r22,0x1616,0x1616,0x0044,r21,0x0400,0x0000,0xC546,0xC748,r19)
	ChkLd(19,lw,r23,0x1717,0x1717,0x0048,r22,0x0400,0x0000,0x49CA,0x4BCC,r20)
	ChkLd(20,lw,r24,0x1818,0x1818,0x004C,r23,0x0400,0x0000,0xCD4E,0xCF50,r21)
	ChkLd(21,lw,r25,0x1919,0x1919,0xFFFC,r24,0x0400,0x0050,0xCD4E,0xCF50,r22)
	ChkLd(22,lw,r26,0x1A1A,0x1A1A,0xFFF8,r25,0x0400,0x0050,0x49CA,0x4BCC,r23)
	ChkLd(23,lw,r27,0x1B1B,0x1B1B,0xFFF4,r26,0x0400,0x0050,0xC546,0xC748,r24)
	ChkLd(24,lw,r28,0x1C1C,0x1C1C,0xFFF0,r27,0x0400,0x0050,0x41C2,0x43C4,r25)
	ChkLd(25,lw,r29,0x1D1D,0x1D1D,0xFFEC,r28,0x0400,0x0050,0xBD3E,0xBF40,r26)
	ChkLd(26,lw,r30,0x1E1E,0x1E1E,0xFFE8,r29,0x0400,0x0050,0x39BA,0x3BBC,r27)
	ChkLd(27,lw,r2 ,0x0182,0x0384,0xFFE4,r30,0x0400,0x0050,0xB536,0xB738,r28)
	ChkLd(28,lw,r3 ,0x8506,0x8708,0xFFE0,r2 ,0x0400,0x0050,0x31B2,0x33B4,r29)
	ChkLd(29,lw,r4 ,0x098A,0x0B8C,0xFFDC,r3 ,0x0400,0x0050,0xAD2E,0xAF30,r30)
	ChkLd(30,lw,r5 ,0x8D0E,0x8F10,0xFFD8,r4 ,0x0400,0x0050,0x29AA,0x2BAC,r2 )
	ChkLd(31,lw,r6 ,0x1192,0x1394,0xFFD4,r5 ,0x0400,0x0050,0xA526,0xA728,r3 )
	ChkLd(32,lw,r7 ,0x9516,0x9718,0xFFD0,r6 ,0x0400,0x0050,0x21A2,0x23A4,r4 )
	ChkLd(33,lw,r8 ,0x199A,0x1B9C,0xFFCC,r7 ,0x0400,0x0050,0x9D1E,0x9F20,r5 )
	ChkLd(34,lw,r9 ,0x9D1E,0x9F20,0xFFC8,r8 ,0x0400,0x0050,0x199A,0x1B9C,r6 )
	ChkLd(35,lw,r10,0x21A2,0x23A4,0xFFC4,r9 ,0x0400,0x0050,0x9516,0x9718,r7 )
	ChkLd(36,lw,r11,0xA526,0xA728,0xFFC0,r10,0x0400,0x0050,0x1192,0x1394,r8 )
	ChkLd(37,lw,r12,0x29AA,0x2BAC,0xFFBC,r11,0x0400,0x0050,0x8D0E,0x8F10,r9 )
	ChkLd(38,lw,r13,0xAD2E,0xAF30,0xFFB8,r12,0x0400,0x0050,0x098A,0x0B8C,r10)
	ChkLd(39,lw,r14,0x31B2,0x33B4,0xFFB4,r13,0x0400,0x0050,0x8506,0x8708,r11)
	ChkLd(40,lw,r15,0xB536,0xB738,0xFFB0,r14,0x0400,0x0050,0x0182,0x0384,r12)

	ori	r1, r0, 0xFEED;
Fail:	break;