aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/mips/ext-2.c
blob: 97703217991903c324f0f0dc615cfd8e76ba4110 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/* Turn the truncate,zero_extend,lshiftrt sequence before the or into a
   zero_extract.  The truncate is due to TARGET_PROMOTE_PROTOTYPES, the
   zero_extend to PROMOTE_MODE.  As of GCC 6, we no longer define
   TARGET_PROMOTE_PROTOTYPES so that truncate is gone and we can
   generate either a single extract or a single shift instruction.  */
/* { dg-do compile } */
/* { dg-options "isa_rev>=2 -mgp64 -mlong64" } */
/* { dg-skip-if "code quality test" { *-*-* } { "-O0" } { "" } } */
/* { dg-final { scan-assembler-times "\tdext\t|\td?srl" 1 } } */
/* { dg-final { scan-assembler-not "\tand" } } */

NOMIPS16 void
f (unsigned char x, unsigned char *r)
{
  *r = 0x50 | (x >> 4);
}