blob: 4a3ffd1876e717361fb965640ee34dabdcf2bc14 [file] [log] [blame]
/* Check that addc and subc patterns are converted if the T value is
inverted. */
/* { dg-do compile } */
/* { dg-options "-O2" } */
/* { dg-final { scan-assembler-times "cmp/eq" 7 } } */
/* { dg-final { scan-assembler-times "subc" 5 { target { ! sh2a } } } } */
/* { dg-final { scan-assembler-times "not\t" 3 { target { ! sh2a } } } } */
/* { dg-final { scan-assembler-times "addc" 2 { target { ! sh2a } } } } */
/* { dg-final { scan-assembler-times "subc" 2 { target { sh2a } } } } */
/* { dg-final { scan-assembler-times "addc" 5 { target { sh2a } } } } */
/* { dg-final { scan-assembler-times "nott" 3 { target { sh2a } } } } */
/* { dg-final { scan-assembler-not "movt" } } */
/* { dg-final { scan-assembler-not "negc" } } */
/* { dg-final { scan-assembler-not "movrt" } } */
int
test_0 (int a, int b, int c)
{
/* 1x cmp/eq, 1x subc */
return c + (a != b);
}
int
test_1 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x not, 1x subc
SH2A: 1x cmp/eq, 1x nott, 1x addc */
return (a != b) + c + d;
}
int
test_2 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x not, 1x subc
SH2A: 1x cmp/eq, 1x nott, 1x addc */
return c + (a != b) + d;
}
int
test_3 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x not, 1x subc
SH2A: 1x cmp/eq, 1x nott, 1x addc */
return c + d + (a != b);
}
int
test_4 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x subc */
return (a != b) - c;
}
int
test_5 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x add #-1, 1x addc */
return c - (a != b);
}
int
test_6 (int a, int b, int c, int d)
{
/* 1x cmp/eq, 1x add #-1, 1x addc */
return c - (a != b) + d;
}