URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 154 |
Rev 816 |
/* PR optimization/11018 */
|
/* PR optimization/11018 */
|
/* Originator: <partain@dcs.gla.ac.uk> */
|
/* Originator: <partain@dcs.gla.ac.uk> */
|
/* { dg-do run { target sparc*-*-* } } */
|
/* { dg-do run { target sparc*-*-* } } */
|
/* { dg-options "-O2 -mcpu=ultrasparc" } */
|
/* { dg-options "-O2 -mcpu=ultrasparc" } */
|
|
|
/* This used to fail on 32-bit Ultrasparc because
|
/* This used to fail on 32-bit Ultrasparc because
|
of broken DImode shift patterns. */
|
of broken DImode shift patterns. */
|
|
|
extern void abort(void);
|
extern void abort(void);
|
|
|
typedef unsigned long long uint64_t;
|
typedef unsigned long long uint64_t;
|
typedef unsigned int size_t;
|
typedef unsigned int size_t;
|
|
|
|
|
void to_octal (uint64_t value, char *where, size_t size)
|
void to_octal (uint64_t value, char *where, size_t size)
|
{
|
{
|
uint64_t v = value;
|
uint64_t v = value;
|
size_t i = size;
|
size_t i = size;
|
|
|
do
|
do
|
{
|
{
|
where[--i] = '0' + (v & ((1 << 3) - 1));
|
where[--i] = '0' + (v & ((1 << 3) - 1));
|
v >>= 3;
|
v >>= 3;
|
}
|
}
|
while (i);
|
while (i);
|
}
|
}
|
|
|
|
|
int main (void)
|
int main (void)
|
{
|
{
|
char buf[8];
|
char buf[8];
|
|
|
to_octal(010644, buf, 6);
|
to_octal(010644, buf, 6);
|
|
|
if (buf[1] != '1')
|
if (buf[1] != '1')
|
abort();
|
abort();
|
|
|
return 0;
|
return 0;
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.