[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v10 6/6] x86/ioreq server: Synchronously reset outstanding p2m_ioreq_server entries when an ioreq server unmaps.
>>> On 05.04.17 at 11:11, <yu.c.zhang@xxxxxxxxxxxxxxx> wrote: > > On 4/3/2017 11:23 PM, Jan Beulich wrote: >>>>> On 02.04.17 at 14:24, <yu.c.zhang@xxxxxxxxxxxxxxx> wrote: >>> After an ioreq server has unmapped, the remaining p2m_ioreq_server >>> entries need to be reset back to p2m_ram_rw. This patch does this >>> synchronously by iterating the p2m table. >>> >>> The synchronous resetting is necessary because we need to guarantee >>> the p2m table is clean before another ioreq server is mapped. And >>> since the sweeping of p2m table could be time consuming, it is done >>> with hypercall continuation. >>> >>> Signed-off-by: Yu Zhang <yu.c.zhang@xxxxxxxxxxxxxxx> >> Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx> >> albeit I think ... >> >>> --- a/xen/arch/x86/mm/p2m.c >>> +++ b/xen/arch/x86/mm/p2m.c >>> @@ -1031,6 +1031,35 @@ void p2m_change_type_range(struct domain *d, >>> p2m_unlock(p2m); >>> } >>> >>> +/* Synchronously modify the p2m type for a range of gfns from ot to nt. */ >>> +void p2m_finish_type_change(struct domain *d, >>> + gfn_t first_gfn, unsigned long max_nr, >>> + p2m_type_t ot, p2m_type_t nt) >>> +{ >>> + struct p2m_domain *p2m = p2m_get_hostp2m(d); >>> + p2m_type_t t; >>> + unsigned long gfn = gfn_x(first_gfn); >>> + unsigned long last_gfn = gfn + max_nr - 1; >>> + >>> + ASSERT(ot != nt); >>> + ASSERT(p2m_is_changeable(ot) && p2m_is_changeable(nt)); >>> + >>> + p2m_lock(p2m); >>> + >>> + last_gfn = min(last_gfn, p2m->max_mapped_pfn); >>> + while ( gfn <= last_gfn ) >>> + { >>> + get_gfn_query_unlocked(d, gfn, &t); >>> + >>> + if ( t == ot ) >>> + p2m_change_type_one(d, gfn, t, nt); >>> + >>> + gfn++; >>> + } >>> + >>> + p2m_unlock(p2m); >>> +} >> ... this could be improved for reduction of overall latency: A fixed >> limit as input if not very useful, as it does matter quite a bit whether >> need to call p2m_change_type_one(). Doing 256 iteration with no >> single call is going to be pretty fast I think, so it would be desirable >> to weigh differently iterations with and without call to that function. > > Oh, thanks for your advice, very enlightening. > With code freeze date approaching, how about we solve this in a separate > patch? :) Well, that's what I've tried to express by giving my R-b with the rest simply being a remark. Jan _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |