| /* { dg-options "isa>=3" } */ |
| /* { dg-skip-if "naming registers makes this a code quality test" { *-*-* } { "-O0" } { "" } } */ |
| |
| NOMIPS16 void |
| f1 (int *area) |
| { |
| __builtin_mips_cache (20, area); |
| } |
| |
| NOMIPS16 void |
| f2 (const short *area) |
| { |
| __builtin_mips_cache (24, area + 10); |
| } |
| |
| NOMIPS16 void |
| f3 (volatile unsigned int *area, int offset) |
| { |
| __builtin_mips_cache (0, area + offset); |
| } |
| |
| NOMIPS16 void |
| f4 (const volatile unsigned char *area) |
| { |
| __builtin_mips_cache (4, area - 80); |
| } |
| |
| /* { dg-final { scan-assembler "\tcache\t0x14,0\\(\\\$4\\)" } } */ |
| /* { dg-final { scan-assembler "\tcache\t0x18,20\\(\\\$4\\)" } } */ |
| /* { dg-final { scan-assembler "\tcache\t(0x|)0,0\\(\\\$.\\)" } } */ |
| /* { dg-final { scan-assembler "\tcache\t0x4,-80\\(\\\$4\\)" } } */ |