From: "Jürgen Groß" <jgross@suse.com>
To: Jan Beulich <jbeulich@suse.com>
Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>,
Thomas Gleixner <tglx@linutronix.de>,
Ingo Molnar <mingo@redhat.com>, Borislav Petkov <bp@alien8.de>,
Dave Hansen <dave.hansen@linux.intel.com>,
"H. Peter Anvin" <hpa@zytor.com>,
xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org,
x86@kernel.org
Subject: Re: [PATCH v3 5/7] xen: add capability to remap non-RAM pages to different PFNs
Date: Tue, 10 Sep 2024 14:51:20 +0200 [thread overview]
Message-ID: <7ce2eaaf-27a7-47a6-bf33-87176cd9cb26@suse.com> (raw)
In-Reply-To: <0c4f3e87-b138-407b-a271-7f86fef255f6@suse.com>
[-- Attachment #1.1.1: Type: text/plain, Size: 2523 bytes --]
On 10.09.24 14:26, Jan Beulich wrote:
> On 10.09.2024 12:39, Juergen Gross wrote:
>> When running as a Xen PV dom0 it can happen that the kernel is being
>> loaded to a guest physical address conflicting with the host memory
>> map.
>>
>> In order to be able to resolve this conflict, add the capability to
>> remap non-RAM areas to different guest PFNs. A function to use this
>> remapping information for other purposes than doing the remap will be
>> added when needed.
>>
>> As the number of conflicts should be rather low (currently only
>> machines with max. 1 conflict are known), save the remap data in a
>> small statically allocated array.
>>
>> Signed-off-by: Juergen Gross <jgross@suse.com>
>
> Reviewed-by: Jan Beulich <jbeulich@suse.com>
> with two cosmetic remarks:
>
>> @@ -792,6 +793,70 @@ int clear_foreign_p2m_mapping(struct gnttab_unmap_grant_ref *unmap_ops,
>> return ret;
>> }
>>
>> +/* Remapped non-RAM areas */
>> +#define NR_NONRAM_REMAP 4
>> +static struct nonram_remap {
>> + phys_addr_t maddr;
>> + phys_addr_t paddr;
>> + size_t size;
>> +} xen_nonram_remap[NR_NONRAM_REMAP] __ro_after_init;
>> +static unsigned int nr_nonram_remap __ro_after_init;
>
> I take it this is the canonical placement of section attributes in the
> kernel? (In Xen I'd ask for the attributes to be moved ahead of the
> identifiers being declared.)
I didn't find an explicit mentioning in the coding style, but most
examples I've found place the section attribute after the name of the
variable.
>
>> +/*
>> + * Do the real remapping of non-RAM regions as specified in the
>> + * xen_nonram_remap[] array.
>> + * In case of an error just crash the system.
>> + */
>> +void __init xen_do_remap_nonram(void)
>> +{
>> + unsigned int i;
>> + unsigned int remapped = 0;
>> + const struct nonram_remap *remap = xen_nonram_remap;
>> + unsigned long pfn, mfn, end_pfn;
>> +
>> + for (i = 0; i < nr_nonram_remap; i++) {
>> + end_pfn = PFN_UP(remap->paddr + remap->size);
>> + pfn = PFN_DOWN(remap->paddr);
>> + mfn = PFN_DOWN(remap->maddr);
>> + while (pfn < end_pfn) {
>> + if (!set_phys_to_machine(pfn, mfn)) {
>> + pr_err("Failed to set p2m mapping for pfn=%lx mfn=%lx\n",
>> + pfn, mfn);
>> + BUG();
>
> Wouldn't panic() get you both in one operation? Or do you expect the call
> trace / register state to be of immediate relevance for analysis?
You are right, in this case panic() is a better option.
Juergen
[-- Attachment #1.1.2: OpenPGP public key --]
[-- Type: application/pgp-keys, Size: 3743 bytes --]
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 495 bytes --]
next prev parent reply other threads:[~2024-09-10 12:51 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-10 10:39 [PATCH v3 0/7] xen: fix dom0 PV boot on some AMD machines Juergen Gross
2024-09-10 10:39 ` [PATCH v3 1/7] xen: use correct end address of kernel for conflict checking Juergen Gross
2024-09-10 10:39 ` [PATCH v3 2/7] xen: introduce generic helper checking for memory map conflicts Juergen Gross
2024-09-10 10:39 ` [PATCH v3 3/7] xen: move checks for e820 conflicts further up Juergen Gross
2024-09-10 10:39 ` [PATCH v3 4/7] xen: move max_pfn in xen_memory_setup() out of function scope Juergen Gross
2024-09-10 10:39 ` [PATCH v3 5/7] xen: add capability to remap non-RAM pages to different PFNs Juergen Gross
2024-09-10 12:26 ` Jan Beulich
2024-09-10 12:51 ` Jürgen Groß [this message]
2024-09-10 10:39 ` [PATCH v3 6/7] xen: allow mapping ACPI data using a different physical address Juergen Gross
2024-09-10 12:34 ` Jan Beulich
2024-09-10 12:52 ` Jürgen Groß
2024-09-10 10:39 ` [PATCH v3 7/7] xen: tolerate ACPI NVS memory overlapping with Xen allocated memory Juergen Gross
2024-09-10 12:36 ` Jan Beulich
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=7ce2eaaf-27a7-47a6-bf33-87176cd9cb26@suse.com \
--to=jgross@suse.com \
--cc=boris.ostrovsky@oracle.com \
--cc=bp@alien8.de \
--cc=dave.hansen@linux.intel.com \
--cc=hpa@zytor.com \
--cc=jbeulich@suse.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@redhat.com \
--cc=tglx@linutronix.de \
--cc=x86@kernel.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