URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Subversion Repositories openrisc_2011-10-31
[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [gcc.c-torture/] [execute/] [shiftdi.c] - Rev 297
Compare with Previous | Blame | View Log
/* Failed on sparc with -mv8plus because sparc.c:set_extends() thought erroneously that SImode ASHIFT chops the upper bits, it does not. */ typedef unsigned long long uint64; void g(uint64 x, int y, int z, uint64 *p) { unsigned w = ((x >> y) & 0xffffffffULL) << (z & 0x1f); *p |= (w & 0xffffffffULL) << z; } int main(void) { uint64 a = 0; g(0xdeadbeef01234567ULL, 0, 0, &a); return (a == 0x01234567) ? 0 : 1; }