OpenCores
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();
}

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.