[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH 3/4] mm: Use put_old_guest_table for relinquish_pages
On 23.12.2019 17:43, George Dunlap wrote: > @@ -1967,42 +1971,32 @@ static int relinquish_memory( > } > > if ( test_and_clear_bit(_PGT_pinned, &page->u.inuse.type_info) ) > - ret = put_page_and_type_preemptible(page); > + { > + /* Always drop the page ref associated with PGT_pinned */ > + put_page(page); > + ret = put_page_type_preemptible(page); > + } > switch ( ret ) > { > case 0: > break; > - case -ERESTART: > case -EINTR: > - /* > - * -EINTR means PGT_validated has been re-set; re-set > - * PGT_pinned again so that it gets picked up next time > - * around. > - * > - * -ERESTART, OTOH, means PGT_partial is set instead. Put > - * it back on the list, but don't set PGT_pinned; the > - * section below will finish off de-validation. But we do > - * need to drop the general ref associated with > - * PGT_pinned, since put_page_and_type_preemptible() > - * didn't do it. > - * > - * NB we can do an ASSERT for PGT_validated, since we > - * "own" the type ref; but theoretically, the PGT_partial > - * could be cleared by someone else. > - */ > - if ( ret == -EINTR ) > - { > - ASSERT(page->u.inuse.type_info & PGT_validated); > - set_bit(_PGT_pinned, &page->u.inuse.type_info); > - } > - else > - put_page(page); > + ASSERT(page->u.inuse.type_info & PGT_validated); > + /* Fallthrough */ > + case -ERESTART: > + current->arch.old_guest_ptpg = NULL; > + current->arch.old_guest_table = page; > + current->arch.old_guest_table_partial = (ret == -ERESTART); > > ret = -ERESTART; > > - /* Put the page back on the list and drop the ref we grabbed > above */ > - page_list_add(page, list); > - put_page(page); > + /* Make sure we don't lose track of the page */ > + page_list_add_tail(page, &d->arch.relmem_list); Why at the tail? The prior page_list_add() made sure we'd encounter this page first on the subsequent continuation. No need to keep (perhaps very) many pages in partially destructed state. With this changed back (or the tail insertion suitably explained in the description) Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx> On top of this please consider latching current into a local variable. Jan _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |