(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
mips/
interrupt_handler-4.c
       1  /* Test optional argument for interrupt and use_shadow_register_set
       2     attributes.  */
       3  /* { dg-do compile } */
       4  /* { dg-options "isa_rev>=2" } */
       5  /* { dg-final { scan-assembler "e0:.*ins\t\\\$27,\\\$26,10,6.*\.end\te0" } } */
       6  /* { dg-final { scan-assembler-times "mfc0\t\\\$26,\\\$13" 3 } } */
       7  /* { dg-final { scan-assembler-times "mfc0\t\\\$27,\\\$14" 11 } } */
       8  /* { dg-final { scan-assembler "v0:.*ins\t\\\$27,\\\$0,8,1.*\.end\tv0" } } */
       9  /* { dg-final { scan-assembler "v1:.*ins\t\\\$27,\\\$0,8,2.*\.end\tv1" } } */
      10  /* { dg-final { scan-assembler "v2:.*ins\t\\\$27,\\\$0,8,3.*\.end\tv2" } } */
      11  /* { dg-final { scan-assembler "v3:.*ins\t\\\$27,\\\$0,8,4.*\.end\tv3" } } */
      12  /* { dg-final { scan-assembler "v4:.*ins\t\\\$27,\\\$0,8,5.*\.end\tv4" } } */
      13  /* { dg-final { scan-assembler "v5:.*ins\t\\\$27,\\\$0,8,6.*\.end\tv5" } } */
      14  /* { dg-final { scan-assembler "v6:.*ins\t\\\$27,\\\$0,8,7.*\.end\tv6" } } */
      15  /* { dg-final { scan-assembler "v7:.*ins\t\\\$27,\\\$0,8,8.*\.end\tv7" } } */
      16  
      17  /* { dg-final { scan-assembler-times "rdpgpr\t\\\$sp,\\\$sp" 1 } } */
      18  /* { dg-final { scan-assembler-not "s1:.*rdpgpr\t\\\$sp,\\\$sp.*\.end\ts1" } } */
      19  
      20  NOMIPS16 void __attribute__ ((interrupt("eic"))) e0 () { }
      21  NOMIPS16 void __attribute__ ((interrupt("vector=sw0"))) v0 () { }
      22  NOMIPS16 void __attribute__ ((interrupt("vector=sw1"))) v1 () { }
      23  NOMIPS16 void __attribute__ ((interrupt("vector=hw0"))) v2 () { }
      24  NOMIPS16 void __attribute__ ((interrupt("vector=hw1"))) v3 () { }
      25  NOMIPS16 void __attribute__ ((interrupt("vector=hw2"))) v4 () { }
      26  NOMIPS16 void __attribute__ ((interrupt("vector=hw3"))) v5 () { }
      27  NOMIPS16 void __attribute__ ((interrupt("vector=hw4"))) v6 () { }
      28  NOMIPS16 void __attribute__ ((interrupt("vector=hw5"))) v7 () { }
      29  
      30  NOMIPS16 void __attribute__ ((interrupt, use_shadow_register_set)) s0 () { }
      31  NOMIPS16 void __attribute__ ((interrupt, use_shadow_register_set("intstack"))) s1 () { }