(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
nios2/
lo-addr-int.c
       1  /* { dg-do compile } */
       2  /* { dg-options "-O2" } */
       3  /* { dg-final { scan-assembler-times "addi\tr., r., %lo" 4 } } */
       4  /* { dg-final { scan-assembler-times "ldw\tr., %lo" 4 } } */
       5  /* { dg-final { scan-assembler-times "stw\tr., %lo" 4 } } */
       6  
       7  /* Check that various address forms involving a symbolic constant
       8     with a possible constant offset and/or index register are optimized
       9     to generate a %lo relocation in the load/store instructions instead
      10     of a plain register indirect addressing mode.  */
      11  
      12  #define TYPE int
      13  
      14  struct ss
      15  {
      16    TYPE x1,x2;
      17  };
      18  
      19  extern TYPE S1;
      20  extern TYPE S2[];
      21  
      22  extern struct ss S3;
      23  extern struct ss S4[];
      24  
      25  TYPE *addr1 (void) { return &S1; }
      26  TYPE get1 (void) { return S1; }
      27  void set1 (TYPE value) { S1 = value; }
      28  
      29  TYPE *addr2 (int i) { return &(S2[i]); }
      30  TYPE get2 (int i) { return S2[i]; }
      31  void set2 (int i, TYPE value) { S2[i] = value; }
      32  
      33  TYPE *addr3 (void) { return &(S3.x2); }
      34  TYPE get3 (void) { return S3.x2; }
      35  void set3 (TYPE value) { S3.x2 = value; }
      36  
      37  TYPE *addr4 (int i) { return &(S4[i].x2); }
      38  TYPE get4 (int i) { return S4[i].x2; }
      39  void set4 (int i, TYPE value) { S4[i].x2 = value; }
      40