(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
vax/
cmpelim-xx-insvsi.c
       1  /* { dg-do compile } */
       2  /* { dg-options "-fdump-rtl-cmpelim -dp" } */
       3  /* { dg-skip-if "code quality test" { *-*-* } { "-O0" } { "" } } */
       4  
       5  typedef signed int __attribute__ ((mode (SI))) int_t;
       6  typedef union
       7    {
       8      int_t i;
       9      struct
      10        {
      11  	int_t h : 7;
      12  	int_t i : 18;
      13  	int_t l : 7;
      14        } b;
      15    }
      16  bit_t;
      17  
      18  int
      19  xx_insvsi (bit_t x, int_t y)
      20  {
      21    int_t v;
      22  
      23    v = x.b.i;
      24    x.b.i = y;
      25    if (v == 0)
      26      return x.i;
      27    else if (v >= 0)
      28      return x.i + 2;
      29    else
      30      return x.i - 3;
      31  }
      32  
      33  /* Expect assembly like:
      34  
      35  	movl 4(%ap),%r0			# 50	[c=16]  *movsi_2
      36  	extv $7,$18,%r0,%r1		# 51	[c=60]  *extv_non_const_2_ccnz
      37  	insv 8(%ap),$7,$18,%r0		# 8	[c=16]  *insv_2
      38  	jeql .L1			# 53	[c=26]  *branch_ccz
      39  	jlss .L4			# 49	[c=26]  *branch_ccn
      40  	addl2 $2,%r0			# 47	[c=32]  *addsi3
      41  	ret				# 42	[c=0]  return
      42  .L4:
      43  	subl2 $3,%r0			# 46	[c=32]  *addsi3
      44  .L1:
      45  
      46   */
      47  
      48  /* { dg-final { scan-rtl-dump-times "deleting insn with uid" 2 "cmpelim" } } */
      49  /* { dg-final { scan-assembler-not "\t(bit|cmpz?|tst). " } } */
      50  /* { dg-final { scan-assembler "extv\[^ \]*_ccnz(/\[0-9\]+)?\n" } } */
      51  /* { dg-final { scan-assembler "extv.*insv.*branch" } } */
      52  /* { dg-final { scan-assembler "branch_ccn\n" } } */
      53  /* { dg-final { scan-assembler "branch_ccz\n" } } */