URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [g++.dg/] [opt/] [pr24665.C] - Rev 693
Compare with Previous | Blame | View Log
// { dg-do compile }
// { dg-options "-O2" }
typedef unsigned long T;
typedef volatile T* const hwreg_t;
struct RegisterLayout
{
T intmask;
};
struct Controller_t
{
Controller_t();
inline void
disableInterrupt()
{
*mpMaskRegister = 0;
};
static hwreg_t mpMaskRegister;
};
extern char SimulatedRegisters[];
hwreg_t Controller_t::mpMaskRegister
= &(reinterpret_cast<volatile RegisterLayout*>(SimulatedRegisters))->intmask;
Controller_t::Controller_t()
{
disableInterrupt();
}