>On Thu, Oct 18, 2012 at 01:50:10PM -0700, Yinghai Lu wrote:

I am pretty sure I gave you some ideas of how to fix up the commit
description in earlier reviews, but it looks like you missed them.

Let me write them here once more.

> We are going to use buffer in BRK to pre-map page table buffer.

What buffer? Is buffer the same thing as page table?
> 
> Page table buffer could be only page aligned, but range around it are

.. ranges
> ram too, we could use bigger page to map it to avoid small pages.
> 
> We will adjust page_size_mask in next patch to use big page size for

Instead of saying "next patch" - include the title of the patch
so that one can search for it.

> small ram range.
> 
> Before that, this patch will make start address to be aligned down

s/will make/made/

> according to bigger page size, otherwise entry in page page will
> not have correct value.


I would structure this git commit description to first introduce
the problem.

Say at the start of the patch:

"Before this patch, the start address was aligned down according
to bigger a page size (1GB, 2MB). This is a problem b/c an
entry in the page table will not have correct value. "

Here can you explain why it does not have the correct value?

> 
> Signed-off-by: Yinghai Lu <[email protected]>
> ---
>  arch/x86/mm/init_32.c |    1 +
>  arch/x86/mm/init_64.c |    5 +++--
>  2 files changed, 4 insertions(+), 2 deletions(-)
> 
> diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c
> index 11a5800..27f7fc6 100644
> --- a/arch/x86/mm/init_32.c
> +++ b/arch/x86/mm/init_32.c
> @@ -310,6 +310,7 @@ repeat:
>                                       __pgprot(PTE_IDENT_ATTR |
>                                                _PAGE_PSE);
>  
> +                             pfn &= PMD_MASK >> PAGE_SHIFT;
>                               addr2 = (pfn + PTRS_PER_PTE-1) * PAGE_SIZE +
>                                       PAGE_OFFSET + PAGE_SIZE-1;
>  
> diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c
> index ab558eb..f40f383 100644
> --- a/arch/x86/mm/init_64.c
> +++ b/arch/x86/mm/init_64.c
> @@ -461,7 +461,7 @@ phys_pmd_init(pmd_t *pmd_page, unsigned long address, 
> unsigned long end,
>                       pages++;
>                       spin_lock(&init_mm.page_table_lock);
>                       set_pte((pte_t *)pmd,
> -                             pfn_pte(address >> PAGE_SHIFT,
> +                             pfn_pte((address & PMD_MASK) >> PAGE_SHIFT,
>                                       __pgprot(pgprot_val(prot) | 
> _PAGE_PSE)));
>                       spin_unlock(&init_mm.page_table_lock);
>                       last_map_addr = next;
> @@ -536,7 +536,8 @@ phys_pud_init(pud_t *pud_page, unsigned long addr, 
> unsigned long end,
>                       pages++;
>                       spin_lock(&init_mm.page_table_lock);
>                       set_pte((pte_t *)pud,
> -                             pfn_pte(addr >> PAGE_SHIFT, PAGE_KERNEL_LARGE));
> +                             pfn_pte((addr & PUD_MASK) >> PAGE_SHIFT,
> +                                     PAGE_KERNEL_LARGE));
>                       spin_unlock(&init_mm.page_table_lock);
>                       last_map_addr = next;
>                       continue;
> -- 
> 1.7.7
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to [email protected]
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to