diff options
Diffstat (limited to 'hw/integratorcp.c')
-rw-r--r-- | hw/integratorcp.c | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/hw/integratorcp.c b/hw/integratorcp.c index 957a94389c..1979c39439 100644 --- a/hw/integratorcp.c +++ b/hw/integratorcp.c @@ -305,8 +305,6 @@ typedef struct icp_pic_state int parent_irq; } icp_pic_state; -static void icp_pic_set_level(icp_pic_state *, int, int); - static void icp_pic_update(icp_pic_state *s) { CPUState *env; @@ -314,8 +312,8 @@ static void icp_pic_update(icp_pic_state *s) uint32_t flags; flags = (s->level & s->irq_enabled); - icp_pic_set_level((icp_pic_state *)s->parent, s->parent_irq, - flags != 0); + pic_set_irq_new(s->parent, s->parent_irq, + flags != 0); return; } /* Raise CPU interrupt. */ @@ -332,12 +330,13 @@ static void icp_pic_update(icp_pic_state *s) } } -static void icp_pic_set_level(icp_pic_state *s, int n, int level) +void pic_set_irq_new(void *opaque, int irq, int level) { + icp_pic_state *s = (icp_pic_state *)opaque; if (level) - s->level |= 1 << n; + s->level |= 1 << irq; else - s->level &= ~(1 << n); + s->level &= ~(1 << irq); icp_pic_update(s); } @@ -385,11 +384,11 @@ static void icp_pic_write(void *opaque, target_phys_addr_t offset, break; case 4: /* INT_SOFTSET */ if (value & 1) - icp_pic_set_level(s, 0, 1); + pic_set_irq_new(s, 0, 1); break; case 5: /* INT_SOFTCLR */ if (value & 1) - icp_pic_set_level(s, 0, 0); + pic_set_irq_new(s, 0, 0); break; case 10: /* FRQ_ENABLESET */ s->fiq_enabled |= value; @@ -513,9 +512,9 @@ static void icp_pit_update(icp_pit_state *s, int64_t now) /* Update interrupts. */ for (n = 0; n < 3; n++) { if (s->int_level[n] && (s->control[n] & 0x20)) { - icp_pic_set_level(s->pic, 5 + n, 1); + pic_set_irq_new(s->pic, 5 + n, 1); } else { - icp_pic_set_level(s->pic, 5 + n, 0); + pic_set_irq_new(s->pic, 5 + n, 0); } if (next - s->expires[n] < 0) next = s->expires[n]; @@ -731,7 +730,7 @@ static void pl011_update(pl011_state *s) uint32_t flags; flags = s->int_level & s->int_enabled; - icp_pic_set_level(s->pic, s->irq, flags != 0); + pic_set_irq_new(s->pic, s->irq, flags != 0); } static uint32_t pl011_read(void *opaque, target_phys_addr_t offset) @@ -1020,7 +1019,7 @@ static void icp_kmi_update(void *opaque, int level) s->pending = level; raise = (s->pending && (s->cr & 0x10) != 0) || (s->cr & 0x08) != 0; - icp_pic_set_level(s->pic, s->irq, raise); + pic_set_irq_new(s->pic, s->irq, raise); } static uint32_t icp_kmi_read(void *opaque, target_phys_addr_t offset) @@ -1196,6 +1195,8 @@ static void integratorcp_init(int ram_size, int vga_ram_size, int boot_device, icp_control_init(0xcb000000); icp_kmi_init(0x18000000, pic, 3, 0); icp_kmi_init(0x19000000, pic, 4, 1); + if (nd_table[0].vlan) + smc91c111_init(&nd_table[0], 0xc8000000, pic, 27); /* Load the kernel. */ if (!kernel_filename) { |