URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 301 |
Rev 338 |
// PR c++/37146
|
// PR c++/37146
|
// { dg-do run }
|
// { dg-do run }
|
|
|
extern "C" void abort ();
|
extern "C" void abort ();
|
int a, b;
|
int a, b;
|
struct A { int i:8; int j:8; int k:16; int l:32; } c;
|
struct A { int i:8; int j:8; int k:16; int l:32; } c;
|
|
|
void
|
void
|
f1 (int x, int y)
|
f1 (int x, int y)
|
{
|
{
|
(x ? a : b) = y;
|
(x ? a : b) = y;
|
}
|
}
|
|
|
void
|
void
|
f2 (int x, int y)
|
f2 (int x, int y)
|
{
|
{
|
(x ? c.i : c.j) = y;
|
(x ? c.i : c.j) = y;
|
}
|
}
|
|
|
void
|
void
|
f3 (int x, int y)
|
f3 (int x, int y)
|
{
|
{
|
(x ? c.i : a) = y;
|
(x ? c.i : a) = y;
|
}
|
}
|
|
|
void
|
void
|
f4 (int x, int y)
|
f4 (int x, int y)
|
{
|
{
|
(x ? c.i : c.k) = y;
|
(x ? c.i : c.k) = y;
|
}
|
}
|
|
|
void
|
void
|
f5 (int x, int y)
|
f5 (int x, int y)
|
{
|
{
|
(x ? c.l : b) = y;
|
(x ? c.l : b) = y;
|
}
|
}
|
|
|
#define CHECK(var, exp) \
|
#define CHECK(var, exp) \
|
do \
|
do \
|
{ \
|
{ \
|
if (var != exp) \
|
if (var != exp) \
|
abort (); \
|
abort (); \
|
var = -1; \
|
var = -1; \
|
if (a != -1 \
|
if (a != -1 \
|
|| b != -1 \
|
|| b != -1 \
|
|| c.i != -1 \
|
|| c.i != -1 \
|
|| c.j != -1 \
|
|| c.j != -1 \
|
|| c.k != -1 \
|
|| c.k != -1 \
|
|| c.l != -1) \
|
|| c.l != -1) \
|
abort (); \
|
abort (); \
|
} \
|
} \
|
while (0)
|
while (0)
|
|
|
int
|
int
|
main ()
|
main ()
|
{
|
{
|
a = -1;
|
a = -1;
|
b = -1;
|
b = -1;
|
c.i = -1;
|
c.i = -1;
|
c.j = -1;
|
c.j = -1;
|
c.k = -1;
|
c.k = -1;
|
c.l = -1;
|
c.l = -1;
|
f1 (1, 264);
|
f1 (1, 264);
|
CHECK (a, 264);
|
CHECK (a, 264);
|
f1 (0, 264);
|
f1 (0, 264);
|
CHECK (b, 264);
|
CHECK (b, 264);
|
f2 (1, 112);
|
f2 (1, 112);
|
CHECK (c.i, 112);
|
CHECK (c.i, 112);
|
f2 (0, 112);
|
f2 (0, 112);
|
CHECK (c.j, 112);
|
CHECK (c.j, 112);
|
f3 (1, 26);
|
f3 (1, 26);
|
CHECK (c.i, 26);
|
CHECK (c.i, 26);
|
f3 (0, 26);
|
f3 (0, 26);
|
CHECK (a, 26);
|
CHECK (a, 26);
|
f4 (1, 107);
|
f4 (1, 107);
|
CHECK (c.i, 107);
|
CHECK (c.i, 107);
|
f4 (0, 107);
|
f4 (0, 107);
|
CHECK (c.k, 107);
|
CHECK (c.k, 107);
|
f5 (1, 95);
|
f5 (1, 95);
|
CHECK (c.l, 95);
|
CHECK (c.l, 95);
|
f5 (0, 95);
|
f5 (0, 95);
|
CHECK (b, 95);
|
CHECK (b, 95);
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.