From: Conor Dooley <conor@kernel.org>
To: panqinglin2020@iscas.ac.cn
Cc: palmer@dabbelt.com, linux-riscv@lists.infradead.org,
jeff@riscv.org, xuyinan@ict.ac.cn
Subject: Re: [PATCH v5 2/4] mm: support Svnapot in physical page linear-mapping
Date: Tue, 4 Oct 2022 19:40:33 +0100 [thread overview]
Message-ID: <Yzx+IbMifJ5xJpuq@spud> (raw)
In-Reply-To: <20221003134721.1772455-3-panqinglin2020@iscas.ac.cn>
Hey Qinglin Pan,
Other comments aside, it'd be good to add previous reviewers to the CC
list on follow-up versions.
On Mon, Oct 03, 2022 at 09:47:19PM +0800, panqinglin2020@iscas.ac.cn wrote:
> From: Qinglin Pan <panqinglin2020@iscas.ac.cn>
> mm: modify pte format for Svnapot
"riscv: mm: foo" please.
>
> Svnapot is powerful when a physical region is going to mapped to a
> virtual region. Kernel will do like this when mapping all allocable
> physical pages to kernel vm space. This commit modifies the
s/This commit modifies/Modify
> create_pte_mapping function used in linear-mapping procedure, so the
> kernel can be able to use Svnapot when both address and length of
> physical region are 64KB align. Code here will be executed only when
> other size huge page is not suitable, so it can be an addition of
> PMD_SIZE and PUD_SIZE mapping.
>
> This commit also modifies the best_map_size function to give map_size
s/This commit also modifies/Modify/
Although, with the "also" should this be two patches or is there a
compile time dependency?
> many times instead of only once, so a memory region can be mapped by
> both PMD_SIZE and 64KB napot size.
>
> It is tested by setting qemu's memory to a 262272k region, and the
> kernel can boot successfully.
>
> Currently, the modified create_pte_mapping will never take use of SVNAPOT,
> because this extension is detected in riscv_fill_hwcap and enabled in
> apply_boot_alternatives(called from setup_arch) which is called
> after setup_vm_final. We will need to support function like
Out of curiousity, why doesn't this series add the support?
Do you intend sending a follow up series?
> riscv_fill_hwcap_early to fill hardware capabilities more earlier, and
> try to enable SVNAPOT more earlier in apply_early_boot_alternatives,
> so that we can determine SVNAPOT's presence during setup_vm_final.
>
> Signed-off-by: Qinglin Pan <panqinglin2020@iscas.ac.cn>
>
> diff --git a/arch/riscv/mm/init.c b/arch/riscv/mm/init.c
> index b56a0a75533f..76317bb28f29 100644
> --- a/arch/riscv/mm/init.c
> +++ b/arch/riscv/mm/init.c
> @@ -373,9 +373,21 @@ static void __init create_pte_mapping(pte_t *ptep,
> phys_addr_t sz, pgprot_t prot)
> {
> uintptr_t pte_idx = pte_index(va);
> +#ifdef CONFIG_RISCV_ISA_SVNAPOT
Would using IS_ENBLED() cause problems here?
> + pte_t pte;
> +
> + if (has_svnapot() && sz == NAPOT_CONT64KB_SIZE) {
> + do {
> + pte = pfn_pte(PFN_DOWN(pa), prot);
> + ptep[pte_idx] = pte_mknapot(pte, NAPOT_CONT64KB_ORDER);
> + pte_idx++;
> + sz -= PAGE_SIZE;
> + } while (sz > 0);
> + return;
> + }
> +#endif
>
> BUG_ON(sz != PAGE_SIZE);
> -
> if (pte_none(ptep[pte_idx]))
> ptep[pte_idx] = pfn_pte(PFN_DOWN(pa), prot);
> }
> @@ -673,10 +685,18 @@ void __init create_pgd_mapping(pgd_t *pgdp,
> static uintptr_t __init best_map_size(phys_addr_t base, phys_addr_t size)
> {
> /* Upgrade to PMD_SIZE mappings whenever possible */
> - if ((base & (PMD_SIZE - 1)) || (size & (PMD_SIZE - 1)))
> + base &= PMD_SIZE - 1;
> + if (!base && size >= PMD_SIZE)
> + return PMD_SIZE;
> +
> + if (!has_svnapot())
> return PAGE_SIZE;
>
> - return PMD_SIZE;
> + base &= NAPOT_CONT64KB_SIZE - 1;
> + if (!base && size >= NAPOT_CONT64KB_SIZE)
> + return NAPOT_CONT64KB_SIZE;
> +
> + return PAGE_SIZE;
> }
>
> #ifdef CONFIG_XIP_KERNEL
> @@ -1111,9 +1131,9 @@ static void __init setup_vm_final(void)
> if (end >= __pa(PAGE_OFFSET) + memory_limit)
> end = __pa(PAGE_OFFSET) + memory_limit;
>
> - map_size = best_map_size(start, end - start);
> for (pa = start; pa < end; pa += map_size) {
> va = (uintptr_t)__va(pa);
> + map_size = best_map_size(pa, end - pa);
>
> create_pgd_mapping(swapper_pg_dir, va, pa, map_size,
> pgprot_from_va(va));
> --
> 2.35.1
>
>
> _______________________________________________
> linux-riscv mailing list
> linux-riscv@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-riscv
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
next prev parent reply other threads:[~2022-10-04 18:40 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-03 13:47 [PATCH v5 0/4] riscv, mm: detect svnapot cpu support at runtime panqinglin2020
2022-10-03 13:47 ` [PATCH v5 1/4] mm: modify pte format for Svnapot panqinglin2020
2022-10-04 17:00 ` Andrew Jones
2022-10-04 17:09 ` Conor Dooley
2022-10-04 18:33 ` Conor Dooley
2022-10-05 4:43 ` Qinglin Pan
2022-10-05 6:57 ` Conor Dooley
2022-10-05 7:15 ` Andrew Jones
2022-10-05 12:41 ` Qinglin Pan
2022-10-05 13:25 ` Andrew Jones
2022-10-05 14:50 ` Qinglin Pan
2022-10-05 9:52 ` Heiko Stübner
2022-10-03 13:47 ` [PATCH v5 2/4] mm: support Svnapot in physical page linear-mapping panqinglin2020
2022-10-04 18:40 ` Conor Dooley [this message]
2022-10-05 2:43 ` Qinglin Pan
2022-10-05 11:19 ` Andrew Jones
2022-10-05 12:45 ` Qinglin Pan
2022-10-03 13:47 ` [PATCH v5 3/4] mm: support Svnapot in hugetlb page panqinglin2020
2022-10-04 18:43 ` Conor Dooley
2022-10-05 2:31 ` Qinglin Pan
2022-10-05 13:11 ` Andrew Jones
2022-10-05 14:54 ` Qinglin Pan
2022-10-03 13:47 ` [PATCH v5 4/4] mm: support Svnapot in huge vmap panqinglin2020
2022-10-04 18:46 ` Conor Dooley
2022-10-05 4:44 ` Qinglin Pan
2022-10-03 13:53 ` [PATCH v5 0/4] riscv, mm: detect svnapot cpu support at runtime Qinglin Pan
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=Yzx+IbMifJ5xJpuq@spud \
--to=conor@kernel.org \
--cc=jeff@riscv.org \
--cc=linux-riscv@lists.infradead.org \
--cc=palmer@dabbelt.com \
--cc=panqinglin2020@iscas.ac.cn \
--cc=xuyinan@ict.ac.cn \
/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