diff options
author | Avi Kivity <avi@redhat.com> | 2011-09-18 15:58:26 +0300 |
---|---|---|
committer | Anthony Liguori <aliguori@us.ibm.com> | 2011-09-23 11:51:05 -0500 |
commit | 22ec3283efba9ba0792790da786d6776d83f2a92 (patch) | |
tree | 79557ca07b0d21f73ff43c4b7258e47b5ec971dc /hw/irq.c | |
parent | e22517086bbdf8d09de2b9ba8b3dfa4c42ec0f6c (diff) | |
download | qemu-22ec3283efba9ba0792790da786d6776d83f2a92.zip qemu-22ec3283efba9ba0792790da786d6776d83f2a92.tar.gz qemu-22ec3283efba9ba0792790da786d6776d83f2a92.tar.bz2 |
irq: introduce qemu_irq_proxy()
In some cases we have a circular dependency involving irqs - the irq
controller depends on a bus, which in turn depends on the irq controller.
Add qemu_irq_proxy() which acts as a passthrough, except that the target
irq may be set later on.
Reviewed-by: Richard Henderson <rth@twiddle.net>
Signed-off-by: Avi Kivity <avi@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Diffstat (limited to 'hw/irq.c')
-rw-r--r-- | hw/irq.c | 14 |
1 files changed, 14 insertions, 0 deletions
@@ -90,3 +90,17 @@ qemu_irq qemu_irq_split(qemu_irq irq1, qemu_irq irq2) s[1] = irq2; return qemu_allocate_irqs(qemu_splitirq, s, 1)[0]; } + +static void proxy_irq_handler(void *opaque, int n, int level) +{ + qemu_irq **target = opaque; + + if (*target) { + qemu_set_irq((*target)[n], level); + } +} + +qemu_irq *qemu_irq_proxy(qemu_irq **target, int n) +{ + return qemu_allocate_irqs(proxy_irq_handler, target, n); +} |