OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [gcc.c-torture/] [compile/] [20011114-4.c] - Rev 774

Go to most recent revision | Compare with Previous | Blame | View Log

static inline int foo (long x)
{
  register int a = 0;
  register unsigned b;
 
  do
    {
      b = (x & 0x7f);
      x = (x >> 7) | ~(-1L >> 7);
      a += 1;
    }
  while ((x != 0 || (b & 0x40) != 0) && (x != -1 || (b & 0x40) == 0));
  return a;
}
 
static inline int bar (unsigned long x)
{
  register int a = 0;
  register unsigned b;
 
  do
    {
      b = (x & 0x7f);
      x >>= 7;
      a++;
    }
  while (x != 0);
  return a;
}
 
int
baz (unsigned long x, int y)
{
  if (y)
    return foo ((long) x);
  else
    return bar (x);
}
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.