From: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
To: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Cc: Konrad Rzeszutek Wilk <konrad@kernel.org>,
xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org,
george.dunlap@eu.citrix.com, ian.jackson@eu.citrix.com,
mukesh.rathor@oracle.com, tim@xen.org, jbeulich@suse.com,
boris.ostrovsky@oracle.com, david.vrabel@citrix.com
Subject: Re: [PATCH V10 05/14] xen/pvh: balloon and grant changes.
Date: Fri, 13 Dec 2013 09:59:37 -0500 [thread overview]
Message-ID: <20131213145937.GB4770@phenom.dumpdata.com> (raw)
In-Reply-To: <alpine.DEB.2.02.1312131448340.8667@kaball.uk.xensource.com>
On Fri, Dec 13, 2013 at 02:49:15PM +0000, Stefano Stabellini wrote:
> On Fri, 13 Dec 2013, Konrad Rzeszutek Wilk wrote:
> > On Fri, Dec 13, 2013 at 11:56:31AM +0000, Stefano Stabellini wrote:
> > > On Thu, 12 Dec 2013, Konrad Rzeszutek Wilk wrote:
> > > > From: Mukesh Rathor <mukesh.rathor@oracle.com>
> > > >
> > > > For balloon changes we skip setting of local P2M as it's updated
> > > > in Xen. For grant, the shared grant frame is the PFN and not MFN,
> > > > hence its mapped via the same code path as HVM.
> > > >
> > > > Signed-off-by: Mukesh Rathor <mukesh.rathor@oracle.com>
> > > > [v1: Rebase on v3.7-rc3]
> > > > Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
> > > > CC: <stefano.stabellini@eu.citrix.com>
> > > > Conflicts:
> > > > drivers/xen/balloon.c
> > > > [v2: Rebase on v3.13-rc3 has lot of ARM changes.]
> > > > ---
> > > > drivers/xen/balloon.c | 37 ++++++++++++++++++++-----------------
> > > > drivers/xen/gntdev.c | 3 ++-
> > > > drivers/xen/grant-table.c | 25 ++++++++++++++++++++++---
> > > > 3 files changed, 44 insertions(+), 21 deletions(-)
> > > >
> > > > diff --git a/drivers/xen/balloon.c b/drivers/xen/balloon.c
> > > > index 55ea73f..0e9875a 100644
> > > > --- a/drivers/xen/balloon.c
> > > > +++ b/drivers/xen/balloon.c
> > > > @@ -354,7 +354,9 @@ static enum bp_state increase_reservation(unsigned long nr_pages)
> > > >
> > > > #ifdef CONFIG_XEN_HAVE_PVMMU
> > > > /* Link back into the page tables if not highmem. */
> > > > - if (xen_pv_domain() && !PageHighMem(page)) {
> > > > + if (xen_pv_domain() && !PageHighMem(page) &&
> > > > + !xen_feature(XENFEAT_auto_translated_physmap)) {
> > > > +
> > > > int ret;
> > > > ret = HYPERVISOR_update_va_mapping(
> > > > (unsigned long)__va(pfn << PAGE_SHIFT),
> > > > @@ -411,28 +413,29 @@ static enum bp_state decrease_reservation(unsigned long nr_pages, gfp_t gfp)
> > > >
> > > > scrub_page(page);
> > > >
> > > > - /*
> > > > - * Ballooned out frames are effectively replaced with
> > > > - * a scratch frame. Ensure direct mappings and the
> > > > - * p2m are consistent.
> > > > - */
> > > > - scratch_page = get_balloon_scratch_page();
> > > > + if (!xen_feature(XENFEAT_auto_translated_physmap)) {
> > > > + unsigned long p;
> > > > +
> > > > + /*
> > > > + * Ballooned out frames are effectively replaced with
> > > > + * a scratch frame. Ensure direct mappings and the
> > > > + * p2m are consistent.
> > > > + */
> > > > + scratch_page = get_balloon_scratch_page();
> > > > #ifdef CONFIG_XEN_HAVE_PVMMU
> > > > - if (xen_pv_domain() && !PageHighMem(page)) {
> > > > - ret = HYPERVISOR_update_va_mapping(
> > > > - (unsigned long)__va(pfn << PAGE_SHIFT),
> > > > - pfn_pte(page_to_pfn(scratch_page),
> > > > + if (xen_pv_domain() && !PageHighMem(page)) {
> > > > + ret = HYPERVISOR_update_va_mapping(
> > > > + (unsigned long)__va(pfn << PAGE_SHIFT),
> > > > + pfn_pte(page_to_pfn(scratch_page),
> > > > PAGE_KERNEL_RO), 0);
> > > > - BUG_ON(ret);
> > > > - }
> > > > + BUG_ON(ret);
> > > > + }
> > > > #endif
> > > > - if (!xen_feature(XENFEAT_auto_translated_physmap)) {
> > > > - unsigned long p;
> > > > p = page_to_pfn(scratch_page);
> > > > __set_phys_to_machine(pfn, pfn_to_mfn(p));
> > > > - }
> > > > - put_balloon_scratch_page();
> > > >
> > > > + put_balloon_scratch_page();
> > > > + }
> > > > balloon_append(pfn_to_page(pfn));
> > > > }
> > >
> > > These changes to balloon.c are similar to my patch but:
> > >
> > > - they don't prevent set_phys_to_machine from being called by
> > > increase_reservation for auto_translated guests
> >
> > <nods>
> > >
> > > - they don't prevent wasteful balloon_scratch_page from being allocated
> > > for auto_translated guests
> >
> > <nods>
> > >
> > > I think that it would be best to take my patch instead.
> >
> > Lets focus the review on your patch then and have it part of this
> > series.
>
> OK, but keep in mind that Xen on ARMv8 is currently broken without that
> patch.
Hm. We could have another patch to just disable BALLOON on ARMv8 :-)
The question you have to ask - if your patch causes regression are you
OK tracking/fixing it over the holidays :-) If yes, then yes - we can
put that in v3.13-rc3 to make it work properly on ARMv8.
next prev parent reply other threads:[~2013-12-13 15:00 UTC|newest]
Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-12-13 2:10 [PATCH v10] Repost of PVH patches for Linux Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 01/14] xen/pvh: Support ParaVirtualized Hardware extensions Konrad Rzeszutek Wilk
2013-12-13 10:44 ` David Vrabel
2013-12-13 14:32 ` Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 02/14] xen/pvh: Extend vcpu_guest_context, p2m, event, and XenBus Konrad Rzeszutek Wilk
2013-12-13 10:56 ` David Vrabel
2013-12-13 14:26 ` Konrad Rzeszutek Wilk
2013-12-13 14:59 ` Stefano Stabellini
2013-12-13 2:10 ` [PATCH V10 03/14] xen/pvh: Implement MMU changes for PVH Konrad Rzeszutek Wilk
2013-12-13 16:54 ` Boris Ostrovsky
2013-12-13 2:10 ` [PATCH V10 04/14] xen/pvh: bootup and setup (E820) related changes Konrad Rzeszutek Wilk
2013-12-13 17:55 ` Boris Ostrovsky
2013-12-17 21:39 ` Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 05/14] xen/pvh: balloon and grant changes Konrad Rzeszutek Wilk
2013-12-13 11:02 ` David Vrabel
2013-12-13 11:56 ` Stefano Stabellini
2013-12-13 14:36 ` Konrad Rzeszutek Wilk
2013-12-13 14:49 ` Stefano Stabellini
2013-12-13 14:59 ` Konrad Rzeszutek Wilk [this message]
2013-12-13 15:34 ` Stefano Stabellini
2013-12-13 15:47 ` Konrad Rzeszutek Wilk
2013-12-13 15:51 ` Stefano Stabellini
2013-12-13 2:10 ` [PATCH V10 06/14] xen: x86 pvh: use XENMEM_add_to_physmap_range for foreign gmfn mappings Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 07/14] xen/x86: remove duplicated include from enlighten.c Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 08/14] x86/xen: Use __pa_symbol instead of __pa on C visible symbols Konrad Rzeszutek Wilk
2013-12-13 11:04 ` David Vrabel
2013-12-13 14:24 ` Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 09/14] xen: implement updated XENMEM_add_to_physmap_range ABI Konrad Rzeszutek Wilk
2013-12-13 11:35 ` David Vrabel
2013-12-13 14:27 ` Konrad Rzeszutek Wilk
2013-12-13 14:30 ` David Vrabel
2013-12-13 2:10 ` [PATCH V10 10/14] xen/pvh: specify xen features strings cleanly for PVH Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 11/14] xen/pvh: remove code to map iomem from guest Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 12/14] xen/pvh: Use ballooning to allocate grant table pages [v2] Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 13/14] x86/xen: remove depends on CONFIG_EXPERIMENTAL Konrad Rzeszutek Wilk
2013-12-13 2:10 ` [PATCH V10 14/14] xen/pvh: vcpu info placement, load CS selector, and remove debug printk Konrad Rzeszutek Wilk
2013-12-13 11:34 ` David Vrabel
2013-12-13 11:37 ` [PATCH v10] Repost of PVH patches for Linux David Vrabel
2013-12-13 14:30 ` [Xen-devel] " Konrad Rzeszutek Wilk
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20131213145937.GB4770@phenom.dumpdata.com \
--to=konrad.wilk@oracle.com \
--cc=boris.ostrovsky@oracle.com \
--cc=david.vrabel@citrix.com \
--cc=george.dunlap@eu.citrix.com \
--cc=ian.jackson@eu.citrix.com \
--cc=jbeulich@suse.com \
--cc=konrad@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mukesh.rathor@oracle.com \
--cc=stefano.stabellini@eu.citrix.com \
--cc=tim@xen.org \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox