diff options
author | j_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-03-30 09:38:04 +0000 |
---|---|---|
committer | j_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-03-30 09:38:04 +0000 |
commit | 471035729088e3aa7f69140ac0ad0b248ff7ec07 (patch) | |
tree | fe468ba8c22505dcdc9c5f41d8a83f2cda77f8ad /vl.h | |
parent | de270b3c7c0c9b15e6c2f3d5e7f5c96673711dad (diff) | |
download | qemu-471035729088e3aa7f69140ac0ad0b248ff7ec07.zip qemu-471035729088e3aa7f69140ac0ad0b248ff7ec07.tar.gz qemu-471035729088e3aa7f69140ac0ad0b248ff7ec07.tar.bz2 |
New model for PowerPC CPU hardware interrupt events:
move all PowerPC specific code into target-ppc/helper.c to avoid polluting
the common code in cpu-exec.c. This makes implementation of new features
(ie embedded PowerPC timers, critical interrupts, ...) easier.
This also avoid hardcoding the IRQ callback in the OpenPIC controller,
making it more easily reusable and allowing cascading.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2542 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'vl.h')
-rw-r--r-- | vl.h | 15 |
1 files changed, 13 insertions, 2 deletions
@@ -852,9 +852,16 @@ int piix4_init(PCIBus *bus, int devfn); /* openpic.c */ typedef struct openpic_t openpic_t; +enum { + OPENPIC_EVT_INT = 0, /* IRQ */ + OPENPIC_EVT_CINT, /* critical IRQ */ + OPENPIC_EVT_MCK, /* Machine check event */ + OPENPIC_EVT_DEBUG, /* Inconditional debug event */ + OPENPIC_EVT_RESET, /* Core reset event */ +}; void openpic_set_irq(void *opaque, int n_IRQ, int level); -openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus, - CPUState **envp); +openpic_t *openpic_init (PCIBus *bus, SetIRQFunc *set_irq, + int *pmem_index, int nb_cpus, CPUPPCState **envp); /* heathrow_pic.c */ typedef struct HeathrowPICS HeathrowPICS; @@ -1115,6 +1122,10 @@ extern void cpu_mips_irqctrl_init (void); extern QEMUMachine shix_machine; #ifdef TARGET_PPC +/* PowerPC hardware exceptions management helpers */ +void ppc_set_irq (void *opaque, int n_IRQ, int level); +void ppc_openpic_irq (void *opaque, int n_IRQ, int level); +int ppc_hw_interrupt (CPUState *env); ppc_tb_t *cpu_ppc_tb_init (CPUState *env, uint32_t freq); #endif void PREP_debug_write (void *opaque, uint32_t addr, uint32_t val); |