virtualization.lists.linux-foundation.org archive mirror
 help / color / mirror / Atom feed
From: David Vrabel <david.vrabel@citrix.com>
To: Daniel Kiper <daniel.kiper@oracle.com>
Cc: konrad.wilk@oracle.com, andrew.cooper3@citrix.com,
	maxim.uvarov@oracle.com, x86@kernel.org,
	kexec@lists.infradead.org, linux-kernel@vger.kernel.org,
	xen-devel <xen-devel@lists.xen.org>,
	mingo@redhat.com, ebiederm@xmission.com,
	Jan Beulich <JBeulich@suse.com>,
	hpa@zytor.com, tglx@linutronix.de,
	virtualization@lists.linux-foundation.org, vgoyal@redhat.com
Subject: Re: [Xen-devel] [PATCH v3 02/11] x86/kexec: Add extra pointers to transition page table PGD, PUD, PMD and PTE
Date: Thu, 10 Jan 2013 14:07:31 +0000	[thread overview]
Message-ID: <50EECB23.4090603@citrix.com> (raw)
In-Reply-To: <20130104151542.GD3346@host-192-168-1-59.local.net-space.pl>

On 04/01/13 15:15, Daniel Kiper wrote:
> On Thu, Jan 03, 2013 at 09:34:55AM +0000, Jan Beulich wrote:
>>>>> On 27.12.12 at 03:18, Daniel Kiper <daniel.kiper@oracle.com> wrote:
>>> Some implementations (e.g. Xen PVOPS) could not use part of identity page table
>>> to construct transition page table. It means that they require separate PUDs,
>>> PMDs and PTEs for virtual and physical (identity) mapping. To satisfy that
>>> requirement add extra pointer to PGD, PUD, PMD and PTE and align existing
>>> code.
>>
>> So you keep posting this despite it having got pointed out on each
>> earlier submission that this is unnecessary, proven by the fact that
>> the non-pvops Xen kernels can get away without it. Why?
> 
> Sorry but I forgot to reply for your email last time.
> 
> I am still not convinced. I have tested SUSE kernel itself and it does not work.
> Maybe I missed something but... Please check arch/x86/kernel/machine_kexec_64.c:init_transition_pgtable()
> 
> I can see:
> 
> vaddr = (unsigned long)relocate_kernel;
> 
> and later:
> 
> pgd += pgd_index(vaddr);
> ...
> 
> It is wrong. relocate_kernel() virtual address in Xen is different
> than its virtual address in Linux Kernel. That is why transition
> page table could not be established in Linux Kernel and so on...
> How does this work in SUSE? I do not have an idea.

The real problem here is attempting to transition from the Xen page
tables to an identity mapping set of page tables by using some
trampoline code and page tables provided by the dom0 kernel.

This works[*] with PV because the page tables from the PV dom0 have
machine addresses and get mapped into the fixmap on kexec load, but it's
completely broken for a PVH dom0.

I shall be ditching this (bizarre) method and putting the trampoline and
transition/identity map page tables into Xen.

David

[*] Works for us in our old classic kernels, YMMV.

  parent reply	other threads:[~2013-01-10 14:07 UTC|newest]

Thread overview: 62+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <1356574740-6806-1-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18 ` [PATCH v3 01/11] kexec: introduce kexec firmware support Daniel Kiper
2012-12-27  4:02 ` [PATCH v3 00/11] xen: Initial kexec/kdump implementation H. Peter Anvin
2012-12-27  7:53   ` Eric W. Biederman
2012-12-27 14:18     ` Andrew Cooper
2012-12-27 18:02       ` Eric W. Biederman
2013-01-02 11:26         ` [Xen-devel] " Andrew Cooper
2013-01-02 11:47           ` Eric W. Biederman
2013-01-03  9:31           ` Jan Beulich
2013-01-04 14:22           ` Daniel Kiper
2013-01-04 14:34             ` Konrad Rzeszutek Wilk
2013-01-04 14:34             ` Ian Campbell
2013-01-04 14:38             ` David Vrabel
2013-01-04 14:41             ` Jan Beulich
2013-01-04 17:07               ` Daniel Kiper
     [not found]               ` <20130104170751.GB3472@host-192-168-1-59.local.net-space.pl>
2013-01-04 19:11                 ` Konrad Rzeszutek Wilk
2013-01-07 10:25                   ` Ian Campbell
     [not found]                   ` <1357554350.14291.134.camel@zakaz.uk.xensource.com>
2013-01-07 10:46                     ` Andrew Cooper
2013-01-07 10:54                       ` Ian Campbell
2013-01-07 12:34                   ` Daniel Kiper
2013-01-07 13:49                     ` Ian Campbell
2013-01-07 16:20                     ` Konrad Rzeszutek Wilk
2013-01-11  4:16                       ` Eric W. Biederman
2013-01-11 16:55                         ` Konrad Rzeszutek Wilk
2013-01-11 20:26                           ` H. Peter Anvin
2013-01-11 20:43                             ` Vivek Goyal
2013-01-11 20:26                           ` Eric W. Biederman
2013-01-11 20:52                             ` Vivek Goyal
2013-01-11 21:03                               ` H. Peter Anvin
     [not found]                               ` <50F07E2D.6010602@zytor.com>
2013-01-11 21:08                                 ` Vivek Goyal
     [not found]                                 ` <20130111210801.GC12019@redhat.com>
2013-01-11 21:14                                   ` H. Peter Anvin
     [not found]                     ` <1357566584.7989.73.camel@zakaz.uk.xensource.com>
2013-01-11 13:47                       ` Daniel Kiper
     [not found]             ` <50E6E974.5090805@citrix.com>
2013-01-04 17:01               ` Daniel Kiper
2013-01-10 14:19                 ` David Vrabel
2013-01-11 13:22                   ` Daniel Kiper
2013-01-11 15:22                     ` David Vrabel
2013-01-11 17:34                       ` Daniel Kiper
2013-01-11 20:05                       ` Eric W. Biederman
2013-01-02 15:27       ` Ian Campbell
     [not found] ` <1356574740-6806-2-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18   ` [PATCH v3 02/11] x86/kexec: Add extra pointers to transition page table PGD, PUD, PMD and PTE Daniel Kiper
2012-12-27  4:46   ` [PATCH v3 01/11] kexec: introduce kexec firmware support Eric W. Biederman
     [not found]   ` <1356574740-6806-3-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18     ` [PATCH v3 03/11] xen: Introduce architecture independent data for kexec/kdump Daniel Kiper
     [not found]     ` <1356574740-6806-4-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18       ` [PATCH v3 04/11] x86/xen: Introduce architecture dependent " Daniel Kiper
     [not found]       ` <1356574740-6806-5-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18         ` [PATCH v3 05/11] x86/xen: Register resources required by kexec-tools Daniel Kiper
     [not found]         ` <1356574740-6806-6-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18           ` [PATCH v3 06/11] x86/xen: Add i386 kexec/kdump implementation Daniel Kiper
     [not found]           ` <1356574740-6806-7-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18             ` [PATCH v3 07/11] x86/xen: Add x86_64 " Daniel Kiper
     [not found]             ` <1356574740-6806-8-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18               ` [PATCH v3 08/11] x86/xen: Add kexec/kdump Kconfig and makefile rules Daniel Kiper
     [not found]               ` <1356574740-6806-9-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18                 ` [PATCH v3 09/11] x86/xen/enlighten: Add init and crash kexec/kdump hooks Daniel Kiper
     [not found]                 ` <1356574740-6806-10-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:18                   ` [PATCH v3 10/11] drivers/xen: Export vmcoreinfo through sysfs Daniel Kiper
     [not found]                   ` <1356574740-6806-11-git-send-email-daniel.kiper@oracle.com>
2012-12-27  2:19                     ` [PATCH v3 11/11] x86: Add Xen kexec control code size check to linker script Daniel Kiper
2012-12-27 18:53                   ` [PATCH v3 09/11] x86/xen/enlighten: Add init and crash kexec/kdump hooks H. Peter Anvin
2012-12-27  4:00             ` [PATCH v3 06/11] x86/xen: Add i386 kexec/kdump implementation H. Peter Anvin
2012-12-27  3:33     ` [PATCH v3 02/11] x86/kexec: Add extra pointers to transition page table PGD, PUD, PMD and PTE H. Peter Anvin
2013-01-03  9:34     ` Jan Beulich
2013-01-04 15:15       ` Daniel Kiper
2013-01-04 16:12         ` Jan Beulich
2013-01-04 17:25           ` Daniel Kiper
2013-01-07  9:48             ` Jan Beulich
     [not found]             ` <50EAA7F402000078000B34C3@nat28.tlf.novell.com>
2013-01-07 12:52               ` Daniel Kiper
2013-01-07 13:05                 ` Jan Beulich
2013-01-09 18:42                   ` Daniel Kiper
2013-01-10 14:07         ` David Vrabel [this message]
2013-01-11 13:36           ` [Xen-devel] " Daniel Kiper

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=50EECB23.4090603@citrix.com \
    --to=david.vrabel@citrix.com \
    --cc=JBeulich@suse.com \
    --cc=andrew.cooper3@citrix.com \
    --cc=daniel.kiper@oracle.com \
    --cc=ebiederm@xmission.com \
    --cc=hpa@zytor.com \
    --cc=kexec@lists.infradead.org \
    --cc=konrad.wilk@oracle.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=maxim.uvarov@oracle.com \
    --cc=mingo@redhat.com \
    --cc=tglx@linutronix.de \
    --cc=vgoyal@redhat.com \
    --cc=virtualization@lists.linux-foundation.org \
    --cc=x86@kernel.org \
    --cc=xen-devel@lists.xen.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;
as well as URLs for NNTP newsgroup(s).