1 #include <stdio.h> 2 3 unsigned int mem[] = { 4 0x121f1e1f, 0, 3, -1, 5 0x232f2e2f, 0x242c2b2b, 0x252a2e2b, 0x262d2d2a, 6 0x3f343f3e, 0x3e353d3c, 0x363a3c3b, 0x3b373b3a, 7 0x454f4e45, 0x4e464d46, 0x474d474c, 0x4a484a4c 8 }; 9 10 unsigned int mem1[] = { 11 0, 0, 0, 0, 12 0, 0, 0, 0, 13 0xffffffff, 0, 0, 0, 14 0, 0, 0, 0 15 }; 16 17 unsigned int mem2[] = { 18 0x0000e680, 0x00010700, 0x0000e7dc, 0x0000b0d0, 19 0x2ab05fd0, 0x0000b6a0, 0x0000be80, 0x0000de10, 20 0x0000df20, 0x2ab05fe0, 0x0000dfd0, 0x00010300 21 }; 22 23 // sb $t0, 0($t1) 24 #define TESTINST1(instruction, RTval, offset, RT, RS) \ 25 { \ 26 unsigned int out; \ 27 __asm__ volatile( \ 28 "move $" #RS", %1\n\t" \ 29 "li $" #RT", " #RTval"\n\t" \ 30 instruction "\n\t" \ 31 "lw %0, "#offset"($"#RS")\n\t" \ 32 : "=&r" (out) \ 33 : "r" (mem1), "r" (RTval) \ 34 : #RT, "cc", "memory" \ 35 ); \ 36 printf("%s :: RTval: 0x%x, out: 0x%x\n", \ 37 instruction, RTval, out); \ 38 out = 0; \ 39 __asm__ volatile( \ 40 "move $" #RS", %1\n\t" \ 41 "li $" #RT", " #RTval"\n\t" \ 42 instruction "\n\t" \ 43 "lw %0, "#offset"($"#RS")\n\t" \ 44 : "=&r" (out) \ 45 : "r" (mem), "r" (RTval) \ 46 : #RT, "cc", "memory" \ 47 ); \ 48 printf("%s :: RTval: 0x%x, out: 0x%x\n", \ 49 instruction, RTval, out); \ 50 } 51 52 // swl $t0, 3($t1) 53 // swr $t0, 0($t1) 54 #define TESTINSTsw(RTval, offset, RT, RS) \ 55 { \ 56 unsigned int out; \ 57 __asm__ volatile( \ 58 "move $" #RS", %1\n\t" \ 59 "addiu $"#RS", $"#RS", "#offset"\n\t" \ 60 "li $" #RT", " #RTval"\n\t" \ 61 "swl $t0, 3($t1) \n\t" \ 62 "swr $t0, 0($t1) \n\t" \ 63 "lw %0, 0($"#RS")\n\t" \ 64 : "=&r" (out) \ 65 : "r" (mem2), "r" (RTval) \ 66 : #RT, #RS, "cc", "memory" \ 67 ); \ 68 printf("swl $t0, 3($t1)\nswr $t0, 0($t1)\n :: RTval: 0x%x, out: 0x%x\n", \ 69 RTval, out); \ 70 } 71 72 void ppMem(unsigned int* mem, int len) 73 { 74 int i; 75 printf("MEM1:\n"); 76 for (i = 0; i < len; i=i+4) 77 { 78 printf("0x%x, 0x%x, 0x%x, 0x%x\n", mem[i], mem[i+1], mem[i+2], mem[i+3]); 79 mem[i] = 0; 80 mem[i+1] = 0; 81 mem[i+2] = 0; 82 mem[i+3] = 0; 83 if (i == 2) 84 { 85 mem[i] = 0xffffffff; 86 mem[i+1] = 0; 87 mem[i+2] = 0; 88 mem[i+3] = 0; 89 } 90 } 91 } 92 93 void ppMem1(unsigned int* mem, int len) 94 { 95 int i; 96 printf("MEM:\n"); 97 for (i = 0; i < len; i=i+4) 98 { 99 printf("0x%x, 0x%x, 0x%x, 0x%x\n", mem[i], mem[i+1], mem[i+2], mem[i+3]); 100 } 101 mem[0] = 0x121f1e1f; 102 mem[1] = 0; 103 mem[2] = 3; 104 mem[3] = -1; 105 mem[4] = 0x232f2e2f; 106 mem[5] = 0x242c2b2b; 107 mem[6] = 0x252a2e2b; 108 mem[7] = 0x262d2d2a; 109 mem[8] = 0x3f343f3e; 110 mem[9] = 0x3e353d3c; 111 mem[10] = 0x363a3c3b; 112 mem[11] = 0x3b373b3a; 113 mem[12] = 0x454f4e45; 114 mem[13] = 0x4e464d46; 115 mem[14] = 0x474d474c; 116 mem[15] = 0x4a484a4c; 117 } 118 119 void ppMem0(unsigned int* mem, int len) 120 { 121 int i; 122 printf("MEM:\n"); 123 for (i = 0; i < len; i=i+4) 124 { 125 printf("0x%x, 0x%x, 0x%x, 0x%x\n", mem[i], mem[i+1], mem[i+2], mem[i+3]); 126 } 127 128 mem[0] = 0x0000e680; 129 mem[1] = 0x00010700; 130 mem[2] = 0x0000e7dc; 131 mem[3] = 0x0000b0d0; 132 mem[4] = 0x2ab05fd0; 133 mem[5] = 0x0000b6a0; 134 mem[6] = 0x0000be80; 135 mem[7] = 0x0000de10; 136 mem[8] = 0x0000df20; 137 mem[9] = 0x2ab05fe0; 138 mem[10] = 0x0000dfd0; 139 mem[11] = 0x00010300; 140 } 141 142 int main() 143 { 144 printf("sb\n"); 145 TESTINST1("sb $t0, 0($t1)", 0, 0, t0, t1); 146 TESTINST1("sb $t0, 0($t1)", 0x31415927, 0, t0, t1); 147 TESTINST1("sb $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 148 TESTINST1("sb $t0, 0($t1)", 0x80000000, 0, t0, t1); 149 TESTINST1("sb $t0, 2($t1)", 0x80000000, 2, t0, t1); 150 TESTINST1("sb $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 151 TESTINST1("sb $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 152 TESTINST1("sb $t0, 8($t1)", -1, 8, t0, t1); 153 TESTINST1("sb $t0, 0($t1)", 0x31415927, 0, t0, t1); 154 TESTINST1("sb $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 155 TESTINST1("sb $t0, 0($t1)", 655, 0, t0, t1); 156 TESTINST1("sb $t0, 0($t1)", -655, 0, t0, t1); 157 TESTINST1("sb $t0, 0($t1)", 15, 0, t0, t1); 158 TESTINST1("sb $t0, 0($t1)", 1, 0, t0, t1); 159 TESTINST1("sb $t0, 0($t1)", 53, 0, t0, t1); 160 TESTINST1("sb $t0, 2($t1)", 0xffffffff, 2, t0, t1); 161 TESTINST1("sb $t0, 2($t1)", 0xffffffff, 2, t0, t1); 162 TESTINST1("sb $t0, 32($t1)", 0xffffffff, 32, t0, t1); 163 TESTINST1("sb $t0, 36($t1)", 0xffffffff, 36, t0, t1); 164 TESTINST1("sb $t0, 40($t1)", 0x31415927, 40, t0, t1); 165 TESTINST1("sb $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 166 TESTINST1("sb $t0, 48($t1)", 0x80000000, 48, t0, t1); 167 TESTINST1("sb $t0, 52($t1)", 655, 52, t0, t1); 168 ppMem(mem1, 16); 169 ppMem1(mem, 16); 170 171 printf("sh\n"); 172 TESTINST1("sh $t0, 0($t1)", 0, 0, t0, t1); 173 TESTINST1("sh $t0, 0($t1)", 0x31415927, 0, t0, t1); 174 TESTINST1("sh $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 175 TESTINST1("sh $t0, 0($t1)", 0x80000000, 0, t0, t1); 176 TESTINST1("sh $t0, 2($t1)", 0x80000000, 2, t0, t1); 177 TESTINST1("sh $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 178 TESTINST1("sh $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 179 TESTINST1("sh $t0, 8($t1)", -1, 8, t0, t1); 180 TESTINST1("sh $t0, 0($t1)", 0x31415927, 0, t0, t1); 181 TESTINST1("sh $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 182 TESTINST1("sh $t0, 0($t1)", 655, 0, t0, t1); 183 TESTINST1("sh $t0, 0($t1)", -655, 0, t0, t1); 184 TESTINST1("sh $t0, 0($t1)", 15, 0, t0, t1); 185 TESTINST1("sh $t0, 0($t1)", 1, 0, t0, t1); 186 TESTINST1("sh $t0, 0($t1)", 53, 0, t0, t1); 187 TESTINST1("sh $t0, 2($t1)", 0xffffffff, 2, t0, t1); 188 TESTINST1("sh $t0, 2($t1)", 0xffffffff, 2, t0, t1); 189 TESTINST1("sh $t0, 32($t1)", 0xffffffff, 32, t0, t1); 190 TESTINST1("sh $t0, 36($t1)", 0xffffffff, 36, t0, t1); 191 TESTINST1("sh $t0, 40($t1)", 0x31415927, 40, t0, t1); 192 TESTINST1("sh $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 193 TESTINST1("sh $t0, 48($t1)", 0x80000000, 48, t0, t1); 194 TESTINST1("sh $t0, 52($t1)", 655, 52, t0, t1); 195 ppMem(mem1, 16); 196 ppMem1(mem, 16); 197 198 printf("sw\n"); 199 TESTINST1("sw $t0, 0($t1)", 0, 0, t0, t1); 200 TESTINST1("sw $t0, 0($t1)", 0x31415927, 0, t0, t1); 201 TESTINST1("sw $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 202 TESTINST1("sw $t0, 0($t1)", 0x80000000, 0, t0, t1); 203 TESTINST1("sw $t0, 2($t1)", 0x80000000, 2, t0, t1); 204 TESTINST1("sw $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 205 TESTINST1("sw $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 206 TESTINST1("sw $t0, 8($t1)", -1, 8, t0, t1); 207 TESTINST1("sw $t0, 0($t1)", 0x31415927, 0, t0, t1); 208 TESTINST1("sw $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 209 TESTINST1("sw $t0, 0($t1)", 655, 0, t0, t1); 210 TESTINST1("sw $t0, 0($t1)", -655, 0, t0, t1); 211 TESTINST1("sw $t0, 0($t1)", 15, 0, t0, t1); 212 TESTINST1("sw $t0, 0($t1)", 1, 0, t0, t1); 213 TESTINST1("sw $t0, 0($t1)", 53, 0, t0, t1); 214 TESTINST1("sw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 215 TESTINST1("sw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 216 TESTINST1("sw $t0, 32($t1)", 0xffffffff, 32, t0, t1); 217 TESTINST1("sw $t0, 36($t1)", 0xffffffff, 36, t0, t1); 218 TESTINST1("sw $t0, 40($t1)", 0x31415927, 40, t0, t1); 219 TESTINST1("sw $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 220 TESTINST1("sw $t0, 48($t1)", 0x80000000, 48, t0, t1); 221 TESTINST1("sw $t0, 52($t1)", 655, 52, t0, t1); 222 ppMem(mem1, 16); 223 ppMem1(mem, 16); 224 225 printf("swl\n"); 226 TESTINST1("swl $t0, 0($t1)", 0, 0, t0, t1); 227 TESTINST1("swl $t0, 0($t1)", 0x31415927, 0, t0, t1); 228 TESTINST1("swl $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 229 TESTINST1("swl $t0, 0($t1)", 0x80000000, 0, t0, t1); 230 TESTINST1("swl $t0, 2($t1)", 0x80000000, 2, t0, t1); 231 TESTINST1("swl $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 232 TESTINST1("swl $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 233 TESTINST1("swl $t0, 8($t1)", -1, 8, t0, t1); 234 TESTINST1("swl $t0, 0($t1)", 0x31415927, 0, t0, t1); 235 TESTINST1("swl $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 236 TESTINST1("swl $t0, 0($t1)", 655, 0, t0, t1); 237 TESTINST1("swl $t0, 0($t1)", -655, 0, t0, t1); 238 TESTINST1("swl $t0, 0($t1)", 15, 0, t0, t1); 239 TESTINST1("swl $t0, 0($t1)", 1, 0, t0, t1); 240 TESTINST1("swl $t0, 0($t1)", 53, 0, t0, t1); 241 TESTINST1("swl $t0, 2($t1)", 0xffffffff, 2, t0, t1); 242 TESTINST1("swl $t0, 2($t1)", 0xffffffff, 2, t0, t1); 243 TESTINST1("swl $t0, 32($t1)", 0xffffffff, 32, t0, t1); 244 TESTINST1("swl $t0, 36($t1)", 0xffffffff, 36, t0, t1); 245 TESTINST1("swl $t0, 40($t1)", 0x31415927, 40, t0, t1); 246 TESTINST1("swl $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 247 TESTINST1("swl $t0, 48($t1)", 0x80000000, 48, t0, t1); 248 TESTINST1("swl $t0, 52($t1)", 655, 52, t0, t1); 249 ppMem(mem1, 16); 250 ppMem1(mem, 16); 251 252 printf("swr\n"); 253 TESTINST1("swr $t0, 0($t1)", 0, 0, t0, t1); 254 TESTINST1("swr $t0, 0($t1)", 0x31415927, 0, t0, t1); 255 TESTINST1("swr $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 256 TESTINST1("swr $t0, 0($t1)", 0x80000000, 0, t0, t1); 257 TESTINST1("swr $t0, 2($t1)", 0x80000000, 2, t0, t1); 258 TESTINST1("swr $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 259 TESTINST1("swr $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 260 TESTINST1("swr $t0, 8($t1)", -1, 8, t0, t1); 261 TESTINST1("swr $t0, 0($t1)", 0x31415927, 0, t0, t1); 262 TESTINST1("swr $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 263 TESTINST1("swr $t0, 0($t1)", 655, 0, t0, t1); 264 TESTINST1("swr $t0, 0($t1)", -655, 0, t0, t1); 265 TESTINST1("swr $t0, 0($t1)", 15, 0, t0, t1); 266 TESTINST1("swr $t0, 0($t1)", 1, 0, t0, t1); 267 TESTINST1("swr $t0, 0($t1)", 53, 0, t0, t1); 268 TESTINST1("swr $t0, 2($t1)", 0xffffffff, 2, t0, t1); 269 TESTINST1("swr $t0, 2($t1)", 0xffffffff, 2, t0, t1); 270 TESTINST1("swr $t0, 32($t1)", 0xffffffff, 32, t0, t1); 271 TESTINST1("swr $t0, 36($t1)", 0xffffffff, 36, t0, t1); 272 TESTINST1("swr $t0, 40($t1)", 0x31415927, 40, t0, t1); 273 TESTINST1("swr $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 274 TESTINST1("swr $t0, 48($t1)", 0x80000000, 48, t0, t1); 275 TESTINST1("swr $t0, 52($t1)", 655, 52, t0, t1); 276 ppMem(mem1, 16); 277 ppMem1(mem, 16); 278 279 printf("ulw\n"); 280 TESTINST1("ulw $t0, 0($t1)", 0, 0, t0, t1); 281 TESTINST1("ulw $t0, 0($t1)", 0x31415927, 0, t0, t1); 282 TESTINST1("ulw $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 283 TESTINST1("ulw $t0, 0($t1)", 0x80000000, 0, t0, t1); 284 TESTINST1("ulw $t0, 2($t1)", 0x80000000, 2, t0, t1); 285 TESTINST1("ulw $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 286 TESTINST1("ulw $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 287 TESTINST1("ulw $t0, 8($t1)", -1, 8, t0, t1); 288 TESTINST1("ulw $t0, 0($t1)", 0x31415927, 0, t0, t1); 289 TESTINST1("ulw $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 290 TESTINST1("ulw $t0, 0($t1)", 655, 0, t0, t1); 291 TESTINST1("ulw $t0, 0($t1)", -655, 0, t0, t1); 292 TESTINST1("ulw $t0, 0($t1)", 15, 0, t0, t1); 293 TESTINST1("ulw $t0, 0($t1)", 1, 0, t0, t1); 294 TESTINST1("ulw $t0, 0($t1)", 53, 0, t0, t1); 295 TESTINST1("ulw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 296 TESTINST1("ulw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 297 TESTINST1("ulw $t0, 32($t1)", 0xffffffff, 32, t0, t1); 298 TESTINST1("ulw $t0, 36($t1)", 0xffffffff, 36, t0, t1); 299 TESTINST1("ulw $t0, 40($t1)", 0x31415927, 40, t0, t1); 300 TESTINST1("ulw $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 301 TESTINST1("ulw $t0, 48($t1)", 0x80000000, 48, t0, t1); 302 TESTINST1("ulw $t0, 52($t1)", 655, 52, t0, t1); 303 ppMem(mem1, 16); 304 ppMem1(mem, 16); 305 306 printf("usw\n"); 307 TESTINST1("usw $t0, 0($t1)", 0, 0, t0, t1); 308 TESTINST1("usw $t0, 0($t1)", 0x31415927, 0, t0, t1); 309 TESTINST1("usw $t0, 0($t1)", 0x7fffffff, 0, t0, t1); 310 TESTINST1("usw $t0, 0($t1)", 0x80000000, 0, t0, t1); 311 TESTINST1("usw $t0, 2($t1)", 0x80000000, 2, t0, t1); 312 TESTINST1("usw $t0, 6($t1)", 0x7fffffff, 6, t0, t1); 313 TESTINST1("usw $t0, 10($t1)", 0x7fffffff, 10, t0, t1); 314 TESTINST1("usw $t0, 8($t1)", -1, 8, t0, t1); 315 TESTINST1("usw $t0, 0($t1)", 0x31415927, 0, t0, t1); 316 TESTINST1("usw $t0, 0($t1)", 0x0dd00000, 0, t0, t1); 317 TESTINST1("usw $t0, 0($t1)", 655, 0, t0, t1); 318 TESTINST1("usw $t0, 0($t1)", -655, 0, t0, t1); 319 TESTINST1("usw $t0, 0($t1)", 15, 0, t0, t1); 320 TESTINST1("usw $t0, 0($t1)", 1, 0, t0, t1); 321 TESTINST1("usw $t0, 0($t1)", 53, 0, t0, t1); 322 TESTINST1("usw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 323 TESTINST1("usw $t0, 2($t1)", 0xffffffff, 2, t0, t1); 324 TESTINST1("usw $t0, 32($t1)", 0xffffffff, 32, t0, t1); 325 TESTINST1("usw $t0, 36($t1)", 0xffffffff, 36, t0, t1); 326 TESTINST1("usw $t0, 40($t1)", 0x31415927, 40, t0, t1); 327 TESTINST1("usw $t0, 44($t1)", 0x7fffffff, 44, t0, t1); 328 TESTINST1("usw $t0, 48($t1)", 0x80000000, 48, t0, t1); 329 TESTINST1("usw $t0, 52($t1)", 655, 52, t0, t1); 330 ppMem(mem1, 16); 331 ppMem1(mem, 16); 332 333 printf("swl $t0, 3($t0)\nswr $t0, 0($t0)\n"); 334 TESTINSTsw(0x4853000, 0, t0, t1); 335 ppMem0(mem2, 12); 336 TESTINSTsw(0x4853000, 4, t0, t1); 337 ppMem0(mem2, 12); 338 TESTINSTsw(0x4863700, 8, t0, t1); 339 ppMem0(mem2, 12); 340 TESTINSTsw(0x48aedd0, 12, t0, t1); 341 ppMem0(mem2, 12); 342 TESTINSTsw(0x2aaee700, 16, t0, t1); 343 ppMem0(mem2, 12); 344 TESTINSTsw(0x2aaee7ff, 20, t0, t1); 345 ppMem0(mem2, 12); 346 TESTINSTsw(0x2aaeffff, 24, t0, t1); 347 ppMem0(mem2, 12); 348 TESTINSTsw(0x4863700, 28, t0, t1); 349 ppMem0(mem2, 12); 350 TESTINSTsw(0x2aaee700, 32, t0, t1); 351 ppMem0(mem2, 12); 352 return 0; 353 } 354