[PATCH v5 2/4] mm: support Svnapot in physical page linear-mapping
Qinglin Pan
panqinglin2020 at iscas.ac.cn
Tue Oct 4 19:43:38 PDT 2022
Hi Conor,
On 10/5/22 2:40 AM, Conor Dooley wrote:
>
> Hey Qinglin Pan,
>
> Other comments aside, it'd be good to add previous reviewers to the CC
> list on follow-up versions.
>
Will do it in the next version:)
> On Mon, Oct 03, 2022 at 09:47:19PM +0800, panqinglin2020 at iscas.ac.cn wrote:
>> From: Qinglin Pan <panqinglin2020 at 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?
>
The above typo will be repaired in the next version.
>> 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?
Because I am not familiar with parsing fdt without memory alloction:(
It may delay this merging of this patchset. I will try to do this in
a follow up series:)
> 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 at 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?
Yes, will do it in next version.
Qinglin
More information about the linux-riscv
mailing list