/* PR tree-optimization/45903 */
/* { dg-do compile } */
/* { dg-options "-O2" } */

unsigned long long a, b;
unsigned char c;

void
f1 (void)
{
  c = (a >> 8) + (b >> 8);
}

void
f2 (void)
{
  c = (a >> 8) | (b >> 8);
}

void
f3 (void)
{
  c = (a >> 16) ^ (b >> 56);
}

unsigned char
f4 (void)
{
  return (a >> 48) + (b >> 40);
}

unsigned char
f5 (void)
{
  return (a >> 32) | (b >> 16);
}

unsigned char
f6 (void)
{
  return (a >> 24) ^ (b >> 32);
}

/* { dg-final { scan-assembler-not "shr\[qdl\]" } } */