mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 16:53:55 -06:00
hw: Move declaration of IRQState to header and add init function
To allow embedding a qemu_irq in a struct move its definition to the header and add a function to init it in place without allocating it. Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu> Message-Id: <e3ffd0f6ef8845d0f7247c9b6ff33f7ee8b432cf.1719690591.git.balaton@eik.bme.hu> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
This commit is contained in:
parent
2688e8df60
commit
e72a7f65c1
2 changed files with 29 additions and 14 deletions
|
@ -26,16 +26,6 @@
|
|||
#include "hw/irq.h"
|
||||
#include "qom/object.h"
|
||||
|
||||
OBJECT_DECLARE_SIMPLE_TYPE(IRQState, IRQ)
|
||||
|
||||
struct IRQState {
|
||||
Object parent_obj;
|
||||
|
||||
qemu_irq_handler handler;
|
||||
void *opaque;
|
||||
int n;
|
||||
};
|
||||
|
||||
void qemu_set_irq(qemu_irq irq, int level)
|
||||
{
|
||||
if (!irq)
|
||||
|
@ -44,6 +34,15 @@ void qemu_set_irq(qemu_irq irq, int level)
|
|||
irq->handler(irq->opaque, irq->n, level);
|
||||
}
|
||||
|
||||
void qemu_init_irq(IRQState *irq, qemu_irq_handler handler, void *opaque,
|
||||
int n)
|
||||
{
|
||||
object_initialize(irq, sizeof(*irq), TYPE_IRQ);
|
||||
irq->handler = handler;
|
||||
irq->opaque = opaque;
|
||||
irq->n = n;
|
||||
}
|
||||
|
||||
qemu_irq *qemu_extend_irqs(qemu_irq *old, int n_old, qemu_irq_handler handler,
|
||||
void *opaque, int n)
|
||||
{
|
||||
|
@ -69,10 +68,8 @@ qemu_irq qemu_allocate_irq(qemu_irq_handler handler, void *opaque, int n)
|
|||
{
|
||||
IRQState *irq;
|
||||
|
||||
irq = IRQ(object_new(TYPE_IRQ));
|
||||
irq->handler = handler;
|
||||
irq->opaque = opaque;
|
||||
irq->n = n;
|
||||
irq = g_new(IRQState, 1);
|
||||
qemu_init_irq(irq, handler, opaque, n);
|
||||
|
||||
return irq;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue