1//Original:/proj/frio/dv/testcases/core/c_dsp32mac_dr_a1a0_m/c_dsp32mac_dr_a1a0_m.dsp 2// Spec Reference: dsp32mac dr_a1a0 m 3# mach: bfin 4 5.include "testutils.inc" 6 start 7 8 A1 = A0 = 0; 9 R0 = 0; 10 ASTAT = R0; 11 12// The result accumulated in A , and stored to a reg half 13 imm32 r0, 0x13545abd; 14 imm32 r1, 0xb2bcfec7; 15 imm32 r2, 0xc1348679; 16 imm32 r3, 0xd0049007; 17 imm32 r4, 0xefbc5569; 18 imm32 r5, 0xcd35560b; 19 imm32 r6, 0xe00c807d; 20 imm32 r7, 0xf78e9008; 21 A1 = A0 = 0; 22 R6.H = (A1 += R0.L * R0.L) (M), R6.L = (A0 = R0.L * R0.L); 23 P1 = A1.w; 24 P2 = A0.w; 25 R1.H = (A1 += R2.L * R3.L) (M), R1.L = (A0 -= R2.H * R3.L); 26 P3 = A1.w; 27 P4 = A0.w; 28 R2.H = (A1 -= R4.L * R5.L) (M), R2.L = (A0 -= R4.H * R5.H); 29 P5 = A1.w; 30 FP = A0.w; 31 R3.H = (A1 += R0.L * R7.L) (M), R3.L = (A0 += R0.L * R7.H); 32 R4 = A1.w; 33 R5 = A0.w; 34 CHECKREG r0, 0x13545ABD; 35 CHECKREG r1, 0xDBCA0964; 36 CHECKREG r2, 0xBF1502EF; 37 CHECKREG r3, 0xF222FCF3; 38 CHECKREG r4, 0xF222613D; 39 CHECKREG r5, 0xFCF2D20E; 40 CHECKREG r6, 0x20294053; 41 CHECKREG r7, 0xF78E9008; 42 CHECKREG p1, 0x20296F89; 43 CHECKREG p2, 0x4052DF12; 44 CHECKREG p3, 0xDBCA2CD8; 45 CHECKREG p4, 0x0963CE3A; 46 CHECKREG p5, 0xBF153B55; 47 CHECKREG fp, 0x02EF7262; 48 49 imm32 r0, 0x13545abd; 50 imm32 r1, 0x22bcfec7; 51 imm32 r2, 0x43348679; 52 imm32 r3, 0x50049007; 53 imm32 r4, 0x6fbc5569; 54 imm32 r5, 0x7d35560b; 55 imm32 r6, 0x800c807d; 56 imm32 r7, 0xf98e9008; 57 A1 = A0 = 0; 58 R0.H = (A1 += R1.L * R0.H) (M), R0.L = (A0 -= R1.L * R0.L); 59 P1 = A1.w; 60 P2 = A0.w; 61 R6.H = (A1 += R2.L * R2.H) (M), R6.L = (A0 = R2.H * R2.L); 62 P3 = A1.w; 63 P4 = A0.w; 64 R2.H = (A1 -= R4.L * R5.H) (M), R2.L = (A0 += R4.H * R5.H); 65 P5 = A1.w; 66 FP = A0.w; 67 R3.H = (A1 += R3.L * R7.H) (M), R3.L = (A0 -= R3.L * R7.H); 68 R4 = A1.w; 69 R5 = A0.w; 70 CHECKREG r0, 0xFFE800DE; 71 CHECKREG r1, 0x22BCFEC7; 72 CHECKREG r2, 0xB63B2D7E; 73 CHECKREG r3, 0x800027DA; 74 CHECKREG r4, 0x49141905; 75 CHECKREG r5, 0x27DA6D3C; 76 CHECKREG r6, 0xE001C032; 77 CHECKREG r7, 0xF98E9008; 78 CHECKREG p1, 0xFFE85E4C; 79 CHECKREG p2, 0x00DDE22A; 80 CHECKREG p3, 0xE00159E0; 81 CHECKREG p4, 0xC031F728; 82 CHECKREG p5, 0xB63B6623; 83 CHECKREG fp, 0x2D7DD300; 84 85 imm32 r0, 0x13545abd; 86 imm32 r1, 0x42bcfec7; 87 imm32 r2, 0x51348679; 88 imm32 r3, 0x60049007; 89 imm32 r4, 0x7fbc5569; 90 imm32 r5, 0x8d35560b; 91 imm32 r6, 0x900c807d; 92 imm32 r7, 0xa78e9008; 93 A1 = A0 = 0; 94 R0.H = (A1 += R1.H * R0.L) (M), R0.L = (A0 = R1.L * R0.L); 95 P1 = A1.w; 96 P2 = A0.w; 97 R1.H = (A1 -= R2.H * R3.L) (M), R1.L = (A0 -= R2.H * R3.L); 98 P3 = A1.w; 99 P4 = A0.w; 100 R2.H = (A1 -= R4.H * R5.L) (M), R2.L = (A0 += R4.H * R5.H); 101 P5 = A1.w; 102 FP = A0.w; 103 R3.H = (A1 += R6.H * R7.L) (M), R3.L = (A0 += R6.L * R7.H); 104 R4 = A1.w; 105 R5 = A0.w; 106 CHECKREG r0, 0x17A7FF22; 107 CHECKREG r1, 0xE9F8462B; 108 CHECKREG r2, 0xBF09D39D; 109 CHECKREG r3, 0x800C2BB9; 110 CHECKREG r4, 0x800C7FAC; 111 CHECKREG r5, 0x2BB8C982; 112 CHECKREG r6, 0x900C807D; 113 CHECKREG r7, 0xA78E9008; 114 CHECKREG p1, 0x17A75CCC; 115 CHECKREG p2, 0xFF221DD6; 116 CHECKREG p3, 0xE9F7E460; 117 CHECKREG p4, 0x462B2CFE; 118 CHECKREG p5, 0xBF093F4C; 119 CHECKREG fp, 0xD39D28D6; 120 121 imm32 r0, 0x03545abd; 122 imm32 r1, 0xb3bcfec7; 123 imm32 r2, 0x24348679; 124 imm32 r3, 0x60049007; 125 imm32 r4, 0x7fbc5569; 126 imm32 r5, 0x9d35560b; 127 imm32 r6, 0xa00c807d; 128 imm32 r7, 0x078e9008; 129 A1 = A0 = 0; 130 R0.H = (A1 += R1.H * R0.H) (M), R0.L = (A0 -= R1.L * R0.L); 131 P1 = A1.w; 132 P2 = A0.w; 133 R1.H = (A1 -= R2.H * R3.H) (M), R1.L = (A0 = R2.H * R3.L); 134 P3 = A1.w; 135 P4 = A0.w; 136 R2.H = (A1 = R4.H * R5.H) (M), R2.L = (A0 += R4.H * R5.H); 137 P5 = A1.w; 138 FP = A0.w; 139 R3.H = (A1 += R6.H * R7.H) (M), R3.L = (A0 += R6.L * R7.H); 140 R4 = A1.w; 141 R5 = A0.w; 142 CHECKREG r0, 0xFF0200DE; 143 CHECKREG r1, 0xF16EE054; 144 CHECKREG r2, 0x4E718000; 145 CHECKREG r3, 0x4B9C8000; 146 CHECKREG r4, 0x4B9BD894; 147 CHECKREG r5, 0x7637575C; 148 CHECKREG r6, 0xA00C807D; 149 CHECKREG r7, 0x078E9008; 150 CHECKREG p1, 0xFF022DB0; 151 CHECKREG p2, 0x00DDE22A; 152 CHECKREG p3, 0xF16E1CE0; 153 CHECKREG p4, 0xE0547AD8; 154 CHECKREG p5, 0x4E70BDEC; 155 CHECKREG fp, 0x7DBDF6B0; 156 157 pass 158