From: "Roger Pau Monné" <roger.pau@citrix.com>
To: Andrew Cooper <andrew.cooper3@citrix.com>
Cc: xen-devel@lists.xenproject.org, "Jan Beulich" <jbeulich@suse.com>,
"Roger Pau Monné" <roger.pau@ctrix.com>
Subject: Re: [PATCH v2 3/4] x86/setup: remove bootstrap_map_addr() usage of destroy_xen_mappings()
Date: Fri, 8 Nov 2024 10:49:34 +0100 [thread overview]
Message-ID: <Zy3ernBVL8OplX0t@macbook> (raw)
In-Reply-To: <ac948cdc-8ae6-41f1-b7dd-35820e9c2193@citrix.com>
On Fri, Nov 08, 2024 at 09:41:35AM +0000, Andrew Cooper wrote:
> On 06/11/2024 12:29 pm, Roger Pau Monne wrote:
> > bootstrap_map_addr() top level comment states that it doesn't indented to
> > remove the L2 tables, as the same L2 will be re-used to create further 2MB
> > mappings. It's incorrect for the function to use destroy_xen_mappings() which
> > will free empty L2 tables.
> >
> > Fix this by using map_pages_to_xen(), which does zap the page-table entries,
> > but does not free page-table structures even when empty.
> >
> > Fixes: 4376c05c3113 ('x86-64: use 1GB pages in 1:1 mapping if available')
> > Signed-off-by: Roger Pau Monné <roger.pau@ctrix.com>
> > ---
> > The fixes tag reflects the fact that if 4376c05c3113 freed the L2 correctly
> > when empty, it would have become obvious that bootstrap_map_addr() shouldn't be
> > using it if it wants to keep the L2. 4376c05c3113 should have switched
> > bootstrap_map_addr() to not use destroy_xen_mappings().
> > ---
> > xen/arch/x86/setup.c | 4 +++-
> > 1 file changed, 3 insertions(+), 1 deletion(-)
> >
> > diff --git a/xen/arch/x86/setup.c b/xen/arch/x86/setup.c
> > index 177f4024abca..815b8651ba79 100644
> > --- a/xen/arch/x86/setup.c
> > +++ b/xen/arch/x86/setup.c
> > @@ -456,7 +456,9 @@ static void *__init bootstrap_map_addr(paddr_t start, paddr_t end)
> >
> > if ( !end )
> > {
> > - destroy_xen_mappings(BOOTSTRAP_MAP_BASE, BOOTSTRAP_MAP_LIMIT);
> > + map_pages_to_xen(BOOTSTRAP_MAP_BASE, INVALID_MFN,
> > + PFN_DOWN(map_cur - BOOTSTRAP_MAP_BASE),
> > + _PAGE_NONE);
> > map_cur = BOOTSTRAP_MAP_BASE;
>
> One option to consider is this.
>
> diff --git a/xen/arch/x86/setup.c b/xen/arch/x86/setup.c
> index eac8488c4ca5..b317a4d12f55 100644
> --- a/xen/arch/x86/setup.c
> +++ b/xen/arch/x86/setup.c
> @@ -461,8 +461,13 @@ static void *__init bootstrap_map_addr(paddr_t
> start, paddr_t end)
>
> if ( !end )
> {
> - destroy_xen_mappings(BOOTSTRAP_MAP_BASE, BOOTSTRAP_MAP_LIMIT);
> - map_cur = BOOTSTRAP_MAP_BASE;
> + if ( map_cur > BOOTSTRAP_MAP_BASE )
> + {
> + memset(&l2_bootmap[l2_table_offset(BOOTSTRAP_MAP_BASE)],
> + 0, (map_cur - BOOTSTRAP_MAP_BASE) >>
> L2_PAGETABLE_SHIFT);
> + flush_tlb_local();
> + map_cur = BOOTSTRAP_MAP_BASE;
> + }
> return NULL;
> }
>
> We know for certain there's nothing to free, and and this far less logic
> than either destroy_xen_mappings() or map_pages_to_xen().
Should we then also consider using l2_bootmap directly when creating
the mappings? So that we have symmetry between the map and unmap
logic.
I think it might be better do to this change as a followup patch, as I
would like to change both the map and unmap paths at the same time.
Thanks, Roger.
next prev parent reply other threads:[~2024-11-08 9:49 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-06 12:29 [PATCH v2 0/4] x86/mm: miscellaneous fixes Roger Pau Monne
2024-11-06 12:29 ` [PATCH v2 1/4] x86/mm: introduce helpers to detect super page alignment Roger Pau Monne
2024-11-07 10:42 ` Jan Beulich
2024-11-07 16:07 ` Roger Pau Monné
2024-11-07 17:19 ` Roger Pau Monné
2024-11-08 7:36 ` Jan Beulich
2024-11-06 12:29 ` [PATCH v2 2/4] x86/mm: special case super page alignment detection for INVALID_MFN Roger Pau Monne
2024-11-07 11:06 ` Jan Beulich
2024-11-07 15:52 ` Roger Pau Monné
2024-11-08 7:44 ` Jan Beulich
2024-11-06 12:29 ` [PATCH v2 3/4] x86/setup: remove bootstrap_map_addr() usage of destroy_xen_mappings() Roger Pau Monne
2024-11-07 11:23 ` Jan Beulich
2024-11-07 11:54 ` Roger Pau Monné
2024-11-07 11:59 ` Jan Beulich
2024-11-08 9:41 ` Andrew Cooper
2024-11-08 9:45 ` Jan Beulich
2024-11-08 9:49 ` Roger Pau Monné [this message]
2024-11-06 12:29 ` [PATCH v2 4/4] x86/mm: ensure L2 is always freed if empty Roger Pau Monne
2024-11-07 11:28 ` [PATCH v2 0/4] x86/mm: miscellaneous fixes Jan Beulich
2024-11-07 11:48 ` Roger Pau Monné
-- strict thread matches above, loose matches on Subject: below --
2024-11-08 11:31 Roger Pau Monne
2024-11-08 11:31 ` [PATCH v2 3/4] x86/setup: remove bootstrap_map_addr() usage of destroy_xen_mappings() Roger Pau Monne
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=Zy3ernBVL8OplX0t@macbook \
--to=roger.pau@citrix.com \
--cc=andrew.cooper3@citrix.com \
--cc=jbeulich@suse.com \
--cc=roger.pau@ctrix.com \
--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.