On Sun, Dec 09, 2018 at 08:45:57PM +0100, Cédric Le Goater wrote: > The IVPE scans the O/S CAM line of the XIVE thread interrupt contexts > to find a matching Notification Virtual Target (NVT) among the NVTs > dispatched on the HW processor threads. > > On a real system, the thread interrupt contexts are updated by the > hypervisor when a Virtual Processor is scheduled to run on a HW > thread. Under QEMU, the model will emulate the same behavior by > hardwiring the NVT identifier in the thread context registers at > reset. > > The NVT identifier used by the sPAPRXive model is the VCPU id. The END > identifier is also derived from the VCPU id. A set of helpers doing > the conversion between identifiers are provided for the hcalls > configuring the sources and the ENDs. > > The model does not need a NVT table but the XiveRouter NVT operations > are provided to perform some extra checks in the routing algorithm. > > Signed-off-by: Cédric Le Goater <c...@kaod.org>
Applied. > --- > > Changes since v6: > > - simplified the prototypes of helpers > - introduced an assert in set_nvt() method > > hw/intc/spapr_xive.c | 56 +++++++++++++++++++++++++++++++++++++++++++- > 1 file changed, 55 insertions(+), 1 deletion(-) > > diff --git a/hw/intc/spapr_xive.c b/hw/intc/spapr_xive.c > index eef5830d45c6..3ade419fdbb1 100644 > --- a/hw/intc/spapr_xive.c > +++ b/hw/intc/spapr_xive.c > @@ -26,6 +26,26 @@ > #define SPAPR_XIVE_VC_BASE 0x0006010000000000ull > #define SPAPR_XIVE_TM_BASE 0x0006030203180000ull > > +/* > + * The allocation of VP blocks is a complex operation in OPAL and the > + * VP identifiers have a relation with the number of HW chips, the > + * size of the VP blocks, VP grouping, etc. The QEMU sPAPR XIVE > + * controller model does not have the same constraints and can use a > + * simple mapping scheme of the CPU vcpu_id > + * > + * These identifiers are never returned to the OS. > + */ > + > +#define SPAPR_XIVE_NVT_BASE 0x400 > + > +/* > + * sPAPR NVT and END indexing helpers > + */ > +static uint32_t spapr_xive_nvt_to_target(uint8_t nvt_blk, uint32_t nvt_idx) > +{ > + return nvt_idx - SPAPR_XIVE_NVT_BASE; > +} > + > /* > * On sPAPR machines, use a simplified output for the XIVE END > * structure dumping only the information related to the OS EQ. > @@ -40,7 +60,8 @@ static void spapr_xive_end_pic_print_info(sPAPRXive *xive, > XiveEND *end, > uint32_t nvt = GETFIELD_BE32(END_W6_NVT_INDEX, end->w6); > uint8_t priority = GETFIELD_BE32(END_W7_F0_PRIORITY, end->w7); > > - monitor_printf(mon, "%3d/%d % 6d/%5d ^%d", nvt, > + monitor_printf(mon, "%3d/%d % 6d/%5d ^%d", > + spapr_xive_nvt_to_target(0, nvt), > priority, qindex, qentries, qgen); > > xive_end_queue_pic_print_info(end, 6, mon); > @@ -246,6 +267,37 @@ static int spapr_xive_write_end(XiveRouter *xrtr, > uint8_t end_blk, > return 0; > } > > +static int spapr_xive_get_nvt(XiveRouter *xrtr, > + uint8_t nvt_blk, uint32_t nvt_idx, XiveNVT > *nvt) > +{ > + uint32_t vcpu_id = spapr_xive_nvt_to_target(nvt_blk, nvt_idx); > + PowerPCCPU *cpu = spapr_find_cpu(vcpu_id); > + > + if (!cpu) { > + /* TODO: should we assert() if we can find a NVT ? */ > + return -1; > + } > + > + /* > + * sPAPR does not maintain a NVT table. Return that the NVT is > + * valid if we have found a matching CPU > + */ > + nvt->w0 = cpu_to_be32(NVT_W0_VALID); > + return 0; > +} > + > +static int spapr_xive_write_nvt(XiveRouter *xrtr, uint8_t nvt_blk, > + uint32_t nvt_idx, XiveNVT *nvt, > + uint8_t word_number) > +{ > + /* > + * We don't need to write back to the NVTs because the sPAPR > + * machine should never hit a non-scheduled NVT. It should never > + * get called. > + */ > + g_assert_not_reached(); > +} > + > static const VMStateDescription vmstate_spapr_xive_end = { > .name = TYPE_SPAPR_XIVE "/end", > .version_id = 1, > @@ -308,6 +360,8 @@ static void spapr_xive_class_init(ObjectClass *klass, > void *data) > xrc->get_eas = spapr_xive_get_eas; > xrc->get_end = spapr_xive_get_end; > xrc->write_end = spapr_xive_write_end; > + xrc->get_nvt = spapr_xive_get_nvt; > + xrc->write_nvt = spapr_xive_write_nvt; > } > > static const TypeInfo spapr_xive_info = { -- David Gibson | I'll have my music baroque, and my code david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_ | _way_ _around_! http://www.ozlabs.org/~dgibson
signature.asc
Description: PGP signature