@@ -151,6 +151,12 @@ static void xics_common_reset(DeviceState *d)
}
}
+void xics_insert_ics(XICSState *xics, ICSState *ics)
+{
+ ics->xics = xics;
+ QLIST_INSERT_HEAD(&xics->ics, ics, list);
+}
+
static void xics_prop_get_nr_irqs(Object *obj, Visitor *v, const char *name,
void *opaque, Error **errp)
{
@@ -474,13 +474,11 @@ fail:
static void xics_kvm_initfn(Object *obj)
{
- XICSState *xics = XICS_COMMON(obj);
ICSState *ics;
ics = ICS_SIMPLE(object_new(TYPE_ICS_KVM));
object_property_add_child(obj, "ics", OBJECT(ics), NULL);
- ics->xics = xics;
- QLIST_INSERT_HEAD(&xics->ics, ics, list);
+ xics_insert_ics(XICS_COMMON(obj), ics);
}
static void xics_kvm_class_init(ObjectClass *oc, void *data)
@@ -302,13 +302,11 @@ static void xics_spapr_realize(DeviceState *dev, Error **errp)
static void xics_spapr_initfn(Object *obj)
{
- XICSState *xics = XICS_SPAPR(obj);
ICSState *ics;
ics = ICS_SIMPLE(object_new(TYPE_ICS_SIMPLE));
object_property_add_child(obj, "ics", OBJECT(ics), NULL);
- ics->xics = xics;
- QLIST_INSERT_HEAD(&xics->ics, ics, list);
+ xics_insert_ics(XICS_COMMON(obj), ics);
}
static void xics_spapr_class_init(ObjectClass *oc, void *data)
@@ -209,5 +209,6 @@ void ics_simple_write_xive(ICSState *ics, int nr, int server,
void ics_set_irq_type(ICSState *ics, int srcno, bool lsi);
ICSState *xics_find_source(XICSState *icp, int irq);
+void xics_insert_ics(XICSState *xics, ICSState *ics);
#endif /* XICS_H */