57e72f2a19
Add the global timer to A9 MPCore. Signed-off-by: François LEGAL <devel@thom.fr.eu.org> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Message-id: ff92f35f438ac671b57d99d823723dd3e62d2c49.1385969450.git.peter.crosthwaite@xilinx.com [PC Changes: * new commit message * split off original version as a separate patch * Rebased against new mpcore implementation (with struct embedding) ] Signed-off-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
40 lines
864 B
C
40 lines
864 B
C
/*
|
|
* Cortex-A9MPCore internal peripheral emulation.
|
|
*
|
|
* Copyright (c) 2009 CodeSourcery.
|
|
* Copyright (c) 2011 Linaro Limited.
|
|
* Written by Paul Brook, Peter Maydell.
|
|
*
|
|
* This code is licensed under the GPL.
|
|
*/
|
|
#ifndef HW_CPU_A9MPCORE_H
|
|
#define HW_CPU_A9MPCORE_H
|
|
|
|
#include "hw/sysbus.h"
|
|
#include "hw/intc/arm_gic.h"
|
|
#include "hw/misc/a9scu.h"
|
|
#include "hw/timer/arm_mptimer.h"
|
|
#include "hw/timer/a9gtimer.h"
|
|
|
|
#define TYPE_A9MPCORE_PRIV "a9mpcore_priv"
|
|
#define A9MPCORE_PRIV(obj) \
|
|
OBJECT_CHECK(A9MPPrivState, (obj), TYPE_A9MPCORE_PRIV)
|
|
|
|
typedef struct A9MPPrivState {
|
|
/*< private >*/
|
|
SysBusDevice parent_obj;
|
|
/*< public >*/
|
|
|
|
uint32_t num_cpu;
|
|
MemoryRegion container;
|
|
uint32_t num_irq;
|
|
|
|
A9SCUState scu;
|
|
GICState gic;
|
|
A9GTimerState gtimer;
|
|
ARMMPTimerState mptimer;
|
|
ARMMPTimerState wdt;
|
|
} A9MPPrivState;
|
|
|
|
#endif
|