public inbox for linux-acpi@vger.kernel.org
 help / color / mirror / Atom feed
From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: "Tian, Kevin" <kevin.tian@intel.com>
Cc: 'Jeremy Fitzhardinge' <jeremy@goop.org>,
	"Brown, Len" <len.brown@intel.com>,
	Xen-devel <xen-devel@lists.xensource.com>,
	the arch/x86 maintainers <x86@kernel.org>,
	"linux-acpi@vger.kernel.org" <linux-acpi@vger.kernel.org>,
	"Cihula, Joseph" <joseph.cihula@intel.com>
Subject: Re: [Xen-devel] Re: Paravirtualizing bits of acpi access
Date: Mon, 23 Mar 2009 19:20:12 +0100	[thread overview]
Message-ID: <200903231920.12991.rjw@sisk.pl> (raw)
In-Reply-To: <0A882F4D99BBF6449D58E61AAFD7EDD60E5E8766@pdsmsx502.ccr.corp.intel.com>

On Monday 23 March 2009, Tian, Kevin wrote:
> >From: Jeremy Fitzhardinge
> >Sent: Monday, March 23, 2009 1:08 AM
> >
> >Rafael J. Wysocki wrote:
> >> On Sunday 22 March 2009, Jeremy Fitzhardinge wrote:
> >>   
> >>> Rafael J. Wysocki wrote:
> >>>     
> >>>> Well, why don't you implement the platform suspend 
> >operations for Xen?
> >>>> I guess you don't want ACPI _PTS to be executed during 
> >suspend as well.
> >>>>   
> >>>>       
> >>> I don't know.  What's _PTS?
> >>>     
> >>
> >> It's an ACPI method called to prepare the platform to enter 
> >the sleep state
> >> (the name stands for "prepare to sleep").  Executing it may 
> >affect the
> >> hardware.
> >>   
> >
> >OK, that's what we want.  Dom0 is the control domain which is 
> >responsible for the bulk of the hardware; Xen itself has very little 
> >hardware knowledge.
> 
> yes, Xen only takes care of several core system devices (pic, 
> ioapic, serial, timer sources) and cpus, and let dom0 control all
> the rest. _PTS, imo, will not affect Xen controlled devices as 
> even on native those devices are suspended after _PTS. Also
> Xen doesn't incorporate ACPI parser and thus can't evaluate any
> ACPI method on its own.
> 
> >
> >> I think you really should not execute any global ACPI 
> >methods to suspend a
> >> guest, because that may affect the host.  That's why I think 
> >it's better to
> >> regard Xen as a platform and implement a separate set of 
> >suspend operations for
> >> it.
> >>   
> >
> >In this case we're talking about the special privileged domain 
> >which can 
> >be considered to be on the "host" side of the line. 
> >
> >That said, I'd be interested in looking at a suspend operations-based 
> >approach if you think its the right way to go.  But I'm concerned that 
> >we'd end up with a big set of very similar-looking parallel functions 
> >just to deal with some difference in detail near the bottom.  Can you 
> >give me a pointer to where this gets put together for acpi?
> >
> 
> As Jeremy pointed out, dom0 is a special domain which cooperate
> with Xen to fulfill the whole S3 sequence, i.e. dom0 still carries 99%
> existing ACPI S3 flow, with several exceptions as below:
> 
> a) No need to prepare wakeup stub (since it's Xen to be first waken
> up after resume), and no expectation that execution flow will be 
> resumed from its wakeup stub (context is resumed at hypercall
> return)
> 
> b) No need to save/restore bsp context and gear to Xen by hypercall
> at last step where originally hardware reg bits are written
> 
> And then Xen jumps in to finish remaining steps. From this angle,
> Xen is not a completely new platform and, well, S3 is more like a
> 'S1' type from dom0's p.o.v with a different trigger method. Then is
> it overkilled to introduce a new set of ops with 99% content 
> duplicated?

IMO, no, it isn't.

Thanks,
Rafael

  reply	other threads:[~2009-03-23 18:19 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-03-21  6:09 Paravirtualizing bits of acpi access Jeremy Fitzhardinge
2009-03-21 17:10 ` Rafael J. Wysocki
2009-03-22  4:26   ` Jeremy Fitzhardinge
2009-03-22 11:28     ` Rafael J. Wysocki
2009-03-22 13:14       ` Ingo Molnar
2009-03-22 13:17         ` Rafael J. Wysocki
2009-03-22 17:07       ` Jeremy Fitzhardinge
2009-03-22 18:00         ` Rafael J. Wysocki
2009-03-23  3:29         ` Tian, Kevin
2009-03-23 18:20           ` Rafael J. Wysocki [this message]
2009-03-23 19:07             ` [Xen-devel] " Jeremy Fitzhardinge
2009-03-23 20:27               ` Rafael J. Wysocki
2009-03-23 20:42                 ` Jeremy Fitzhardinge
2009-03-24  5:14                 ` Jeremy Fitzhardinge
2009-03-24  5:33                   ` Tian, Kevin
2009-03-24  5:42                     ` Jeremy Fitzhardinge
2009-03-24  5:45                       ` Tian, Kevin
2009-03-24  7:05                         ` Jeremy Fitzhardinge
2009-03-24 16:45                           ` Bjorn Helgaas
2009-03-24 17:28                             ` Jeremy Fitzhardinge
2009-03-24 17:51                               ` [Xen-devel] " Cihula, Joseph
2009-03-27 21:57                                 ` Len Brown
2009-03-27 23:20                                   ` Jeremy Fitzhardinge
2009-03-28  1:01                                     ` Len Brown
2009-03-28  2:19                                       ` Tian, Kevin
2009-03-28  3:19                                       ` Jeremy Fitzhardinge
2009-03-28 13:56                                         ` Rafael J. Wysocki
2009-03-24 23:40                               ` Tian, Kevin
2009-03-24 23:51                               ` Tian, Kevin
2009-03-25  0:45                                 ` Jeremy Fitzhardinge
2009-03-23 19:52             ` [Xen-devel] " Matthew Garrett
2009-03-23 20:22               ` Rafael J. Wysocki

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=200903231920.12991.rjw@sisk.pl \
    --to=rjw@sisk.pl \
    --cc=jeremy@goop.org \
    --cc=joseph.cihula@intel.com \
    --cc=kevin.tian@intel.com \
    --cc=len.brown@intel.com \
    --cc=linux-acpi@vger.kernel.org \
    --cc=x86@kernel.org \
    --cc=xen-devel@lists.xensource.com \
    /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