提交 7668a27f 编写于 作者: B bellard

openpic SMP support (Jocelyn Mayer)


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1655 c046a42c-6fe2-441c-8c8c-71466251a162
上级 e5d13e2f
...@@ -159,7 +159,7 @@ typedef struct IRQ_dst_t { ...@@ -159,7 +159,7 @@ typedef struct IRQ_dst_t {
uint32_t pcsr; /* CPU sensitivity register */ uint32_t pcsr; /* CPU sensitivity register */
IRQ_queue_t raised; IRQ_queue_t raised;
IRQ_queue_t servicing; IRQ_queue_t servicing;
CPUState *env; /* Needed if we did SMP */ CPUState *env;
} IRQ_dst_t; } IRQ_dst_t;
struct openpic_t { struct openpic_t {
...@@ -265,8 +265,7 @@ static void IRQ_local_pipe (openpic_t *opp, int n_CPU, int n_IRQ) ...@@ -265,8 +265,7 @@ static void IRQ_local_pipe (openpic_t *opp, int n_CPU, int n_IRQ)
if (priority > dst->raised.priority) { if (priority > dst->raised.priority) {
IRQ_get_next(opp, &dst->raised); IRQ_get_next(opp, &dst->raised);
DPRINTF("Raise CPU IRQ\n"); DPRINTF("Raise CPU IRQ\n");
/* XXX: choose the correct cpu */ cpu_interrupt(dst->env, CPU_INTERRUPT_HARD);
cpu_interrupt(first_cpu, CPU_INTERRUPT_HARD);
} }
} }
...@@ -782,8 +781,7 @@ static void openpic_cpu_write (void *opaque, uint32_t addr, uint32_t val) ...@@ -782,8 +781,7 @@ static void openpic_cpu_write (void *opaque, uint32_t addr, uint32_t val)
src = &opp->src[n_IRQ]; src = &opp->src[n_IRQ];
if (IPVP_PRIORITY(src->ipvp) > dst->servicing.priority) { if (IPVP_PRIORITY(src->ipvp) > dst->servicing.priority) {
DPRINTF("Raise CPU IRQ\n"); DPRINTF("Raise CPU IRQ\n");
/* XXX: choose cpu */ cpu_interrupt(dst->env, CPU_INTERRUPT_HARD);
cpu_interrupt(first_cpu, CPU_INTERRUPT_HARD);
} }
} }
break; break;
...@@ -965,7 +963,8 @@ static void openpic_map(PCIDevice *pci_dev, int region_num, ...@@ -965,7 +963,8 @@ static void openpic_map(PCIDevice *pci_dev, int region_num,
#endif #endif
} }
openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus) openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus,
CPUPPCState **envp)
{ {
openpic_t *opp; openpic_t *opp;
uint8_t *pci_conf; uint8_t *pci_conf;
...@@ -1019,6 +1018,8 @@ openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus) ...@@ -1019,6 +1018,8 @@ openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus)
for (; i < MAX_IRQ; i++) { for (; i < MAX_IRQ; i++) {
opp->src[i].type = IRQ_INTERNAL; opp->src[i].type = IRQ_INTERNAL;
} }
for (i = 0; i < nb_cpus; i++)
opp->dst[i].env = envp[i];
openpic_reset(opp); openpic_reset(opp);
if (pmem_index) if (pmem_index)
*pmem_index = opp->mem_index; *pmem_index = opp->mem_index;
......
...@@ -474,7 +474,7 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, ...@@ -474,7 +474,7 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device,
vga_initialize(pci_bus, ds, phys_ram_base + ram_size, vga_initialize(pci_bus, ds, phys_ram_base + ram_size,
ram_size, vga_ram_size, ram_size, vga_ram_size,
vga_bios_offset, vga_bios_size); vga_bios_offset, vga_bios_size);
pic = openpic_init(NULL, &openpic_mem_index, 1); pic = openpic_init(NULL, &openpic_mem_index, 1, &env);
set_irq = openpic_set_irq; set_irq = openpic_set_irq;
pci_set_pic(pci_bus, set_irq, pic); pci_set_pic(pci_bus, set_irq, pic);
......
...@@ -613,7 +613,8 @@ PCIBus *pci_apb_init(target_ulong special_base, target_ulong mem_base); ...@@ -613,7 +613,8 @@ PCIBus *pci_apb_init(target_ulong special_base, target_ulong mem_base);
/* openpic.c */ /* openpic.c */
typedef struct openpic_t openpic_t; typedef struct openpic_t openpic_t;
void openpic_set_irq(void *opaque, int n_IRQ, int level); void openpic_set_irq(void *opaque, int n_IRQ, int level);
openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus); openpic_t *openpic_init (PCIBus *bus, int *pmem_index, int nb_cpus,
CPUState **envp);
/* heathrow_pic.c */ /* heathrow_pic.c */
typedef struct HeathrowPICS HeathrowPICS; typedef struct HeathrowPICS HeathrowPICS;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册