123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355 |
- //Original:/testcases/core/c_dspldst_ld_drlo_ipp/c_dspldst_ld_drlo_ipp.dsp
- // Spec Reference: c_dspldst ld_drlo_i++/--
- # mach: bfin
- .include "testutils.inc"
- start
- INIT_R_REGS 0;
- loadsym i0, DATA_ADDR_3;
- loadsym i1, DATA_ADDR_4;
- loadsym i2, DATA_ADDR_5;
- loadsym i3, DATA_ADDR_6;
- // Load Lower half of Dregs
- R0.L = W [ I0 ++ ];
- R1.L = W [ I1 ++ ];
- R2.L = W [ I2 ++ ];
- R3.L = W [ I3 ++ ];
- R4.L = W [ I0 ++ ];
- R5.L = W [ I1 ++ ];
- R6.L = W [ I2 ++ ];
- R7.L = W [ I3 ++ ];
- CHECKREG r0, 0x00000203;
- CHECKREG r1, 0x00002223;
- CHECKREG r2, 0x00004243;
- CHECKREG r3, 0x00006263;
- CHECKREG r4, 0x00000001;
- CHECKREG r5, 0x00002021;
- CHECKREG r6, 0x00004041;
- CHECKREG r7, 0x00006061;
- R1.L = W [ I0 ++ ];
- R2.L = W [ I1 ++ ];
- R3.L = W [ I2 ++ ];
- R4.L = W [ I3 ++ ];
- R5.L = W [ I0 ++ ];
- R6.L = W [ I1 ++ ];
- R7.L = W [ I2 ++ ];
- R0.L = W [ I3 ++ ];
- CHECKREG r0, 0x00006465;
- CHECKREG r1, 0x00000607;
- CHECKREG r2, 0x00002627;
- CHECKREG r3, 0x00004647;
- CHECKREG r4, 0x00006667;
- CHECKREG r5, 0x00000405;
- CHECKREG r6, 0x00002425;
- CHECKREG r7, 0x00004445;
- R2.L = W [ I0 ++ ];
- R3.L = W [ I1 ++ ];
- R4.L = W [ I2 ++ ];
- R5.L = W [ I3 ++ ];
- R6.L = W [ I0 ++ ];
- R7.L = W [ I1 ++ ];
- R0.L = W [ I2 ++ ];
- R1.L = W [ I3 ++ ];
- CHECKREG r0, 0x00004849;
- CHECKREG r1, 0x00006869;
- CHECKREG r2, 0x00000A0B;
- CHECKREG r3, 0x00002A2B;
- CHECKREG r4, 0x00004A4B;
- CHECKREG r5, 0x00006A6B;
- CHECKREG r6, 0x00000809;
- CHECKREG r7, 0x00002829;
- R3.L = W [ I0 ++ ];
- R4.L = W [ I1 ++ ];
- R5.L = W [ I2 ++ ];
- R6.L = W [ I3 ++ ];
- R7.L = W [ I0 ++ ];
- R0.L = W [ I1 ++ ];
- R1.L = W [ I2 ++ ];
- R2.L = W [ I3 ++ ];
- CHECKREG r0, 0x00002C2D;
- CHECKREG r1, 0x00004C4D;
- CHECKREG r2, 0x00006C6D;
- CHECKREG r3, 0x00000E0F;
- CHECKREG r4, 0x00002E2F;
- CHECKREG r5, 0x00004E4F;
- CHECKREG r6, 0x00006E6F;
- CHECKREG r7, 0x00000C0D;
- // reverse to minus mninus i--
- // Load Lower half of Dregs
- R0.L = W [ I0 -- ];
- R1.L = W [ I1 -- ];
- R2.L = W [ I2 -- ];
- R3.L = W [ I3 -- ];
- R4.L = W [ I0 -- ];
- R5.L = W [ I1 -- ];
- R6.L = W [ I2 -- ];
- R7.L = W [ I3 -- ];
- CHECKREG r0, 0x00001213;
- CHECKREG r1, 0x00003233;
- CHECKREG r2, 0x00005253;
- CHECKREG r3, 0x00007273;
- CHECKREG r4, 0x00000C0D;
- CHECKREG r5, 0x00002C2D;
- CHECKREG r6, 0x00004C4D;
- CHECKREG r7, 0x00006C6D;
- R1.L = W [ I0 -- ];
- R2.L = W [ I1 -- ];
- R3.L = W [ I2 -- ];
- R4.L = W [ I3 -- ];
- R5.L = W [ I0 -- ];
- R6.L = W [ I1 -- ];
- R7.L = W [ I2 -- ];
- R0.L = W [ I3 -- ];
- CHECKREG r0, 0x00006869;
- CHECKREG r1, 0x00000E0F;
- CHECKREG r2, 0x00002E2F;
- CHECKREG r3, 0x00004E4F;
- CHECKREG r4, 0x00006E6F;
- CHECKREG r5, 0x00000809;
- CHECKREG r6, 0x00002829;
- CHECKREG r7, 0x00004849;
- R2.L = W [ I0 -- ];
- R3.L = W [ I1 -- ];
- R4.L = W [ I2 -- ];
- R5.L = W [ I3 -- ];
- R6.L = W [ I0 -- ];
- R7.L = W [ I1 -- ];
- R0.L = W [ I2 -- ];
- R1.L = W [ I3 -- ];
- CHECKREG r0, 0x00004445;
- CHECKREG r1, 0x00006465;
- CHECKREG r2, 0x00000A0B;
- CHECKREG r3, 0x00002A2B;
- CHECKREG r4, 0x00004A4B;
- CHECKREG r5, 0x00006A6B;
- CHECKREG r6, 0x00000405;
- CHECKREG r7, 0x00002425;
- R3.L = W [ I0 -- ];
- R4.L = W [ I1 -- ];
- R5.L = W [ I2 -- ];
- R6.L = W [ I3 -- ];
- R7.L = W [ I0 -- ];
- R0.L = W [ I1 -- ];
- R1.L = W [ I2 -- ];
- R2.L = W [ I3 -- ];
- CHECKREG r0, 0x00002021;
- CHECKREG r1, 0x00004041;
- CHECKREG r2, 0x00006061;
- CHECKREG r3, 0x00000607;
- CHECKREG r4, 0x00002627;
- CHECKREG r5, 0x00004647;
- CHECKREG r6, 0x00006667;
- CHECKREG r7, 0x00000001;
- pass
- // Pre-load memory with known data
- // More data is defined than will actually be used
- .data
- DATA_ADDR_3:
- .dd 0x00010203
- .dd 0x04050607
- .dd 0x08090A0B
- .dd 0x0C0D0E0F
- .dd 0x10111213
- .dd 0x14151617
- .dd 0x18191A1B
- .dd 0x1C1D1E1F
- .dd 0x11223344
- .dd 0x55667788
- .dd 0x99717273
- .dd 0x74757677
- .dd 0x82838485
- .dd 0x86878889
- .dd 0x80818283
- .dd 0x84858687
- .dd 0x01020304
- .dd 0x05060708
- .dd 0x09101112
- .dd 0x14151617
- .dd 0x18192021
- .dd 0x22232425
- .dd 0x26272829
- .dd 0x30313233
- .dd 0x34353637
- .dd 0x38394041
- .dd 0x42434445
- .dd 0x46474849
- .dd 0x50515253
- .dd 0x54555657
- .dd 0x58596061
- .dd 0x62636465
- .dd 0x66676869
- DATA_ADDR_4:
- .dd 0x20212223
- .dd 0x24252627
- .dd 0x28292A2B
- .dd 0x2C2D2E2F
- .dd 0x30313233
- .dd 0x34353637
- .dd 0x38393A3B
- .dd 0x3C3D3E3F
- .dd 0x91929394
- .dd 0x95969798
- .dd 0x99A1A2A3
- .dd 0xA5A6A7A8
- .dd 0xA9B0B1B2
- .dd 0xB3B4B5B6
- .dd 0xB7B8B9C0
- .dd 0x70717273
- .dd 0x74757677
- .dd 0x78798081
- .dd 0x82838485
- .dd 0x86C283C4
- .dd 0x81C283C4
- .dd 0x82C283C4
- .dd 0x83C283C4
- .dd 0x84C283C4
- .dd 0x85C283C4
- .dd 0x86C283C4
- .dd 0x87C288C4
- .dd 0x88C283C4
- .dd 0x89C283C4
- .dd 0x80C283C4
- .dd 0x81C283C4
- .dd 0x82C288C4
- DATA_ADDR_5:
- .dd 0x40414243
- .dd 0x44454647
- .dd 0x48494A4B
- .dd 0x4C4D4E4F
- .dd 0x50515253
- .dd 0x54555657
- .dd 0x58595A5B
- .dd 0xC5C6C7C8
- .dd 0xC9CACBCD
- .dd 0xCFD0D1D2
- .dd 0xD3D4D5D6
- .dd 0xD7D8D9DA
- .dd 0xDBDCDDDE
- .dd 0xDFE0E1E2
- .dd 0xE3E4E5E6
- .dd 0x91E899EA
- .dd 0x92E899EA
- .dd 0x93E899EA
- .dd 0x94E899EA
- .dd 0x95E899EA
- .dd 0x96E899EA
- .dd 0x97E899EA
- .dd 0x98E899EA
- .dd 0x99E899EA
- .dd 0x91E899EA
- .dd 0x92E899EA
- .dd 0x93E899EA
- .dd 0x94E899EA
- .dd 0x95E899EA
- .dd 0x96E899EA
- .dd 0x977899EA
- DATA_ADDR_6:
- .dd 0x60616263
- .dd 0x64656667
- .dd 0x68696A6B
- .dd 0x6C6D6E6F
- .dd 0x70717273
- .dd 0x74757677
- .dd 0x78797A7B
- .dd 0x7C7D7E7F
- .dd 0xEBECEDEE
- .dd 0xF3F4F5F6
- .dd 0xF7F8F9FA
- .dd 0xFBFCFDFE
- .dd 0xFF000102
- .dd 0x03040506
- .dd 0x0708090A
- .dd 0x0B0CAD0E
- .dd 0xAB0CAD01
- .dd 0xAB0CAD02
- .dd 0xAB0CAD03
- .dd 0xAB0CAD04
- .dd 0xAB0CAD05
- .dd 0xAB0CAD06
- .dd 0xAB0CAA07
- .dd 0xAB0CAD08
- .dd 0xAB0CAD09
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- .dd 0xAB0CAD0E
- DATA_ADDR_7:
- .dd 0x80818283
- .dd 0x84858687
- .dd 0x88898A8B
- .dd 0x8C8D8E8F
- .dd 0x90919293
- .dd 0x94959697
- .dd 0x98999A9B
- .dd 0x9C9D9E9F
- .dd 0x0F101213
- .dd 0x14151617
- .dd 0x18191A1B
- .dd 0x1C1D1E1F
- .dd 0x20212223
- .dd 0x24252627
- .dd 0x28292A2B
- .dd 0x2C2D2E2F
- .dd 0xBC0DBE21
- .dd 0xBC1DBE22
- .dd 0xBC2DBE23
- .dd 0xBC3DBE24
- .dd 0xBC4DBE65
- .dd 0xBC5DBE27
- .dd 0xBC6DBE28
- .dd 0xBC7DBE29
- .dd 0xBC8DBE2F
- .dd 0xBC9DBE20
- .dd 0xBCADBE21
- .dd 0xBCBDBE2F
- .dd 0xBCCDBE23
- .dd 0xBCDDBE24
- .dd 0xBCFDBE25
- .dd 0xBC0DBE26
- DATA_ADDR_8:
- .dd 0xA0A1A2A3
- .dd 0xA4A5A6A7
- .dd 0xA8A9AAAB
- .dd 0xACADAEAF
- .dd 0xB0B1B2B3
- .dd 0xB4B5B6B7
- .dd 0xB8B9BABB
- .dd 0xBCBDBEBF
- .dd 0xC0C1C2C3
- .dd 0xC4C5C6C7
- .dd 0xC8C9CACB
- .dd 0xCCCDCECF
- .dd 0xD0D1D2D3
- .dd 0xD4D5D6D7
- .dd 0xD8D9DADB
- .dd 0xDCDDDEDF
- .dd 0xE0E1E2E3
- .dd 0xE4E5E6E7
- .dd 0xE8E9EAEB
- .dd 0xECEDEEEF
- .dd 0xF0F1F2F3
- .dd 0xF4F5F6F7
- .dd 0xF8F9FAFB
- .dd 0xFCFDFEFF
|