All of lore.kernel.org
 help / color / mirror / Atom feed
From: Andrew Cooper <andrew.cooper3@citrix.com>
To: Gianluca Guida <glguida@gmail.com>
Cc: Keir Fraser <keir@xen.org>,
	Ian Campbell <ian.campbell@citrix.com>,
	Ian Jackson <ian.jackson@eu.citrix.com>, Tim Deegan <tim@xen.org>,
	Jan Beulich <JBeulich@suse.com>,
	"Aravindh Puthiyaparambil (aravindp)" <aravindp@cisco.com>,
	"xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>
Subject: Re: [PATCH RFC v2 1/4] x86/mm: Shadow and p2m changes for PV mem_access
Date: Mon, 25 Aug 2014 14:02:37 +0100	[thread overview]
Message-ID: <53FB33ED.7060107@citrix.com> (raw)
In-Reply-To: <CAKpvNa0BOL8=A64Z4L=jGyLhYDPM_uXyc2zTDqhYU8-AKvNMZQ@mail.gmail.com>


[-- Attachment #1.1: Type: text/plain, Size: 1892 bytes --]

On 25/08/14 13:45, Gianluca Guida wrote:
> On Fri, Aug 22, 2014 at 10:34 AM, Andrew Cooper
> <andrew.cooper3@citrix.com <mailto:andrew.cooper3@citrix.com>> wrote:
>
>     I am concerned with the addition of a the vcpu specifics to
>     shadow_write_entries().  Most of the shadow code is already vcpu
>     centric
>     where it should be domain centric, and steps are being made to
>     alleviate
>     these problems.
>
>
> The historical reason the code is set up this way, if you are
> referring to the fact that every shadow operation is vcpu-specific
> while the interface to it is domain specific, is due to the design
> choice of leaving the door open to experiment with per-vcpu shadows.
> That always looked like a nice feature, I am not sure anybody ever
> implemented it. I would advocate -- for the sake of code consistency
> -- to keep the current shadow internal interfaces per-vcpu in upcoming
> patches, and change it when you propose your domain-centric patch,
> effectively killing this probably never-exploited opportunity.
>
> Honestly, haven't been following shadow code in a while, so probably
> consistency has already been lost, in which case you should feel free
> to ignore this comment.
>
> Gianluca

I appreciate that it was done with vcpus to experiment with per-vcpu
shadows, but it is fundamentally wrong (even in a per-vcpu shadows case)
for certain paths to arbitrarily use d->vcpu[0] when calling into the
shadow code.  At the very least, it adversely messes with the heuristics.

There are fundamentally two separate entry paths into the shadow code. 
First from the pagefault handler, which certainly is vcpu-centric, but
also from toolstack operations, which is very much domain centric.  A
per-vcpu shadow setup would need to use for_each_vcpu() under the hood,
as it certainly couldn't trust that the caller has handed an appropriate
vcpu.

~Andrew

[-- Attachment #1.2: Type: text/html, Size: 3203 bytes --]

[-- Attachment #2: Type: text/plain, Size: 126 bytes --]

_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xen.org
http://lists.xen.org/xen-devel

  parent reply	other threads:[~2014-08-25 13:03 UTC|newest]

Thread overview: 85+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-07-08  2:50 [PATCH RFC v2 0/4] Add mem_access support for PV domains Aravindh Puthiyaparambil
2014-07-08  2:50 ` [PATCH RFC v2 1/4] x86/mm: Shadow and p2m changes for PV mem_access Aravindh Puthiyaparambil
2014-07-24 14:29   ` Jan Beulich
2014-07-24 23:34     ` Aravindh Puthiyaparambil (aravindp)
2014-07-25  7:19       ` Jan Beulich
2014-07-25 21:39         ` Aravindh Puthiyaparambil (aravindp)
2014-07-28  6:49           ` Jan Beulich
2014-07-28 21:14             ` Aravindh Puthiyaparambil (aravindp)
2014-07-30  4:05             ` Aravindh Puthiyaparambil (aravindp)
2014-07-30  7:11               ` Jan Beulich
2014-07-30 18:35                 ` Aravindh Puthiyaparambil (aravindp)
2014-08-01  6:39                   ` Jan Beulich
2014-08-01 18:08                     ` Aravindh Puthiyaparambil (aravindp)
2014-08-04  7:03                       ` Jan Beulich
2014-08-05  0:14                         ` Aravindh Puthiyaparambil (aravindp)
2014-08-05  6:33                           ` Jan Beulich
2014-08-13 22:14                             ` Aravindh Puthiyaparambil (aravindp)
2014-08-22  2:29                             ` Aravindh Puthiyaparambil (aravindp)
2014-08-22  9:34                               ` Andrew Cooper
2014-08-22 10:02                                 ` Jan Beulich
2014-08-22 10:14                                   ` Andrew Cooper
2014-08-22 18:28                                 ` Aravindh Puthiyaparambil (aravindp)
2014-08-22 18:52                                   ` Andrew Cooper
2014-08-25 12:45                                 ` Gianluca Guida
2014-08-25 13:01                                   ` Jan Beulich
2014-08-25 13:02                                   ` Andrew Cooper [this message]
2014-08-25 13:59                                     ` Gianluca Guida
2014-08-22 15:33                               ` Jan Beulich
2014-08-22 19:07                                 ` Aravindh Puthiyaparambil (aravindp)
2014-08-22 19:24                                   ` Andrew Cooper
2014-08-22 19:48                                     ` Aravindh Puthiyaparambil (aravindp)
2014-08-22 20:02                                       ` Andrew Cooper
2014-08-22 20:13                                         ` Aravindh Puthiyaparambil (aravindp)
2014-08-25  7:34                                           ` Jan Beulich
2014-08-25  7:33                                         ` Jan Beulich
2014-08-25 12:49                                           ` Andrew Cooper
2014-08-25 13:09                                             ` Jan Beulich
2014-08-25 16:56                                               ` Aravindh Puthiyaparambil (aravindp)
2014-08-26  7:08                                                 ` Jan Beulich
2014-08-26 22:27                                                   ` Aravindh Puthiyaparambil (aravindp)
2014-08-26 23:30                                                     ` Andrew Cooper
2014-08-28  9:34                                                       ` Tim Deegan
2014-08-28 18:33                                                         ` Aravindh Puthiyaparambil (aravindp)
2014-08-27  6:33                                                     ` Jan Beulich
2014-08-27  7:49                                                       ` Tim Deegan
2014-08-27 17:29                                                       ` Aravindh Puthiyaparambil (aravindp)
2014-08-25 17:44                                               ` Andrew Cooper
2014-08-26  7:12                                                 ` Jan Beulich
2014-08-25  7:29                                       ` Jan Beulich
2014-08-25 16:40                                         ` Aravindh Puthiyaparambil (aravindp)
2014-08-28  9:14           ` Tim Deegan
2014-08-28 18:31             ` Aravindh Puthiyaparambil (aravindp)
2014-08-28 19:00               ` Tim Deegan
2014-08-28 19:23                 ` Aravindh Puthiyaparambil (aravindp)
2014-08-28 20:37                   ` Tim Deegan
2014-08-28 21:35                     ` Aravindh Puthiyaparambil (aravindp)
2014-08-28 22:20                     ` Aravindh Puthiyaparambil (aravindp)
2014-08-29  9:52                       ` Tim Deegan
2014-08-29 17:52                         ` Aravindh Puthiyaparambil (aravindp)
2014-08-29 19:03                         ` Aravindh Puthiyaparambil (aravindp)
2014-09-01 10:38                           ` Jan Beulich
2014-09-02 21:57                             ` Aravindh Puthiyaparambil (aravindp)
2014-09-03  8:31                               ` Jan Beulich
2014-09-03 18:50                                 ` Aravindh Puthiyaparambil (aravindp)
2014-09-04  6:39                                   ` Jan Beulich
2014-09-04 18:24                                     ` Aravindh Puthiyaparambil (aravindp)
2014-09-05  8:11                                       ` Jan Beulich
2014-09-05 22:49                                         ` Aravindh Puthiyaparambil (aravindp)
     [not found]                                   ` <20140904083906.GA86555@deinos.phlegethon.org>
     [not found]                                     ` <540849430200007800030C47@mail.emea.novell.com>
2014-09-11 19:40                                       ` Aravindh Puthiyaparambil (aravindp)
2014-09-12  7:21                                         ` Jan Beulich
2014-09-12 18:01                                           ` Aravindh Puthiyaparambil (aravindp)
2014-08-28  9:09       ` Tim Deegan
2014-08-28 18:23         ` Aravindh Puthiyaparambil (aravindp)
2014-07-08  2:50 ` [PATCH RFC v2 2/4] x86/mem_access: mem_access and mem_event changes to support PV domains Aravindh Puthiyaparambil
2014-07-24 14:38   ` Jan Beulich
2014-07-24 23:52     ` Aravindh Puthiyaparambil (aravindp)
2014-07-25  7:23       ` Jan Beulich
2014-07-25 21:47         ` Aravindh Puthiyaparambil (aravindp)
2014-07-28  6:56           ` Jan Beulich
2014-07-28 21:16             ` Aravindh Puthiyaparambil (aravindp)
2014-07-08  2:50 ` [PATCH RFC v2 3/4] tools/libxc: Add APIs for PV mem_access Aravindh Puthiyaparambil
2014-07-08  2:50 ` [PATCH RFC v2 4/4] tool/xen-access: Add support for PV domains Aravindh Puthiyaparambil
2014-07-08 16:27 ` [PATCH RFC v2 0/4] Add mem_access " Konrad Rzeszutek Wilk
2014-07-08 17:57   ` Aravindh Puthiyaparambil (aravindp)
2014-07-09  0:31   ` Aravindh Puthiyaparambil (aravindp)

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=53FB33ED.7060107@citrix.com \
    --to=andrew.cooper3@citrix.com \
    --cc=JBeulich@suse.com \
    --cc=aravindp@cisco.com \
    --cc=glguida@gmail.com \
    --cc=ian.campbell@citrix.com \
    --cc=ian.jackson@eu.citrix.com \
    --cc=keir@xen.org \
    --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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.