Skip to content

Commit

Permalink
armv7m: Move NVICState struct definition into header
Browse files Browse the repository at this point in the history
Move the NVICState struct definition into a header, so we can
embed it into other QOM objects like SoCs.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
Message-id: 1487604965-23220-3-git-send-email-peter.maydell@linaro.org
  • Loading branch information
pm215 committed Feb 28, 2017
1 parent 3651c28 commit 6bf436c
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 48 deletions.
49 changes: 1 addition & 48 deletions hw/intc/armv7m_nvic.c
Expand Up @@ -17,6 +17,7 @@
#include "hw/sysbus.h"
#include "qemu/timer.h"
#include "hw/arm/arm.h"
#include "hw/arm/armv7m_nvic.h"
#include "target/arm/cpu.h"
#include "exec/address-spaces.h"
#include "qemu/log.h"
Expand Down Expand Up @@ -47,61 +48,13 @@
* "exception" more or less interchangeably.
*/
#define NVIC_FIRST_IRQ 16
#define NVIC_MAX_VECTORS 512
#define NVIC_MAX_IRQ (NVIC_MAX_VECTORS - NVIC_FIRST_IRQ)

/* Effective running priority of the CPU when no exception is active
* (higher than the highest possible priority value)
*/
#define NVIC_NOEXC_PRIO 0x100

typedef struct VecInfo {
/* Exception priorities can range from -3 to 255; only the unmodifiable
* priority values for RESET, NMI and HardFault can be negative.
*/
int16_t prio;
uint8_t enabled;
uint8_t pending;
uint8_t active;
uint8_t level; /* exceptions <=15 never set level */
} VecInfo;

typedef struct NVICState {
/*< private >*/
SysBusDevice parent_obj;
/*< public >*/

ARMCPU *cpu;

VecInfo vectors[NVIC_MAX_VECTORS];
uint32_t prigroup;

/* vectpending and exception_prio are both cached state that can
* be recalculated from the vectors[] array and the prigroup field.
*/
unsigned int vectpending; /* highest prio pending enabled exception */
int exception_prio; /* group prio of the highest prio active exception */

struct {
uint32_t control;
uint32_t reload;
int64_t tick;
QEMUTimer *timer;
} systick;

MemoryRegion sysregmem;
MemoryRegion container;

uint32_t num_irq;
qemu_irq excpout;
qemu_irq sysresetreq;
} NVICState;

#define TYPE_NVIC "armv7m_nvic"

#define NVIC(obj) \
OBJECT_CHECK(NVICState, (obj), TYPE_NVIC)

static const uint8_t nvic_id[] = {
0x00, 0xb0, 0x1b, 0x00, 0x0d, 0xe0, 0x05, 0xb1
};
Expand Down
66 changes: 66 additions & 0 deletions include/hw/arm/armv7m_nvic.h
@@ -0,0 +1,66 @@
/*
* ARMv7M NVIC object
*
* Copyright (c) 2017 Linaro Ltd
* Written by Peter Maydell <peter.maydell@linaro.org>
*
* This code is licensed under the GPL version 2 or later.
*/

#ifndef HW_ARM_ARMV7M_NVIC_H
#define HW_ARM_ARMV7M_NVIC_H

#include "target/arm/cpu.h"
#include "hw/sysbus.h"

#define TYPE_NVIC "armv7m_nvic"

#define NVIC(obj) \
OBJECT_CHECK(NVICState, (obj), TYPE_NVIC)

/* Highest permitted number of exceptions (architectural limit) */
#define NVIC_MAX_VECTORS 512

typedef struct VecInfo {
/* Exception priorities can range from -3 to 255; only the unmodifiable
* priority values for RESET, NMI and HardFault can be negative.
*/
int16_t prio;
uint8_t enabled;
uint8_t pending;
uint8_t active;
uint8_t level; /* exceptions <=15 never set level */
} VecInfo;

typedef struct NVICState {
/*< private >*/
SysBusDevice parent_obj;
/*< public >*/

ARMCPU *cpu;

VecInfo vectors[NVIC_MAX_VECTORS];
uint32_t prigroup;

/* vectpending and exception_prio are both cached state that can
* be recalculated from the vectors[] array and the prigroup field.
*/
unsigned int vectpending; /* highest prio pending enabled exception */
int exception_prio; /* group prio of the highest prio active exception */

struct {
uint32_t control;
uint32_t reload;
int64_t tick;
QEMUTimer *timer;
} systick;

MemoryRegion sysregmem;
MemoryRegion container;

uint32_t num_irq;
qemu_irq excpout;
qemu_irq sysresetreq;
} NVICState;

#endif

0 comments on commit 6bf436c

Please sign in to comment.