From: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com>
To: Paul Mackerras <paulus@ozlabs.org>, linuxppc-dev@lists.ozlabs.org
Cc: kvm-ppc@vger.kernel.org, kvm@vger.kernel.org
Subject: Re: [PATCH 3/3] powerpc/mm: Speed up computation of base and actual page size for a HPTE
Date: Sun, 04 Sep 2016 16:46:36 +0530 [thread overview]
Message-ID: <87mvjnrk2z.fsf@linux.vnet.ibm.com> (raw)
In-Reply-To: <20160902115055.GC12433@fergus.ozlabs.ibm.com>
Paul Mackerras <paulus@ozlabs.org> writes:
> +/*
> + * Fill in the hpte_page_sizes[] array.
> + * We go through the mmu_psize_defs[] array looking for all the
> + * supported base/actual page size combinations. Each combination
> + * has a unique pagesize encoding (penc) value in the low bits of
> + * the LP field of the HPTE. For actual page sizes less than 1MB,
> + * some of the upper LP bits are used for RPN bits, meaning that
> + * we need to fill in several entries in hpte_page_sizes[].
> + */
May be can put the details of upper LP bits used for RPN here. ie, add
the below in the comment ?
/*
* encoding bits per actual page size
* PTE LP actual page size
* rrrr rrrz >=8KB
* rrrr rrzz >=16KB
* rrrr rzzz >=32KB
* rrrr zzzz >=64KB
* .......
*/
> +static void init_hpte_page_sizes(void)
> +{
> + long int ap, bp;
> + long int shift, penc;
> +
> + for (bp = 0; bp < MMU_PAGE_COUNT; ++bp) {
> + if (!mmu_psize_defs[bp].shift)
> + continue; /* not a supported page size */
> + for (ap = bp; ap < MMU_PAGE_COUNT; ++ap) {
> + penc = mmu_psize_defs[bp].penc[ap];
> + if (penc == -1)
> + continue;
> + shift = mmu_psize_defs[ap].shift - LP_SHIFT;
> + if (shift <= 0)
> + continue; /* should never happen */
> + while (penc < (1 << LP_BITS)) {
> + hpte_page_sizes[penc] = (ap << 4) | bp;
> + penc += 1 << shift;
> + }
Can you add a comment around that while loop ? ie something like.
/*
* if we are using all LP_BITs in penc, fill the array such that we
* replicate the ap and bp information, ignoring those bits. They will
* be filled by rpn bits in hpte.
*/
> + }
> + }
> +}
> +
> static void __init htab_init_page_sizes(void)
> {
> + init_hpte_page_sizes();
> +
> if (!debug_pagealloc_enabled()) {
> /*
> * Pick a size for the linear mapping. Currently, we only
> --
Reviewed-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
-aneesh
next prev parent reply other threads:[~2016-09-04 11:16 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20160902114759.GA12433@fergus.ozlabs.ibm.com>
2016-09-02 11:50 ` [PATCH 3/3] powerpc/mm: Speed up computation of base and actual page size for a HPTE Paul Mackerras
2016-09-04 11:16 ` Aneesh Kumar K.V [this message]
2016-09-05 5:04 ` Aneesh Kumar K.V
2016-09-07 5:07 ` Paul Mackerras
[not found] ` <20160907061709.GD21443@fergus.ozlabs.ibm.com>
2016-09-08 10:08 ` [PATCH v2 " Paul Mackerras
2016-09-08 10:16 ` Paolo Bonzini
2016-09-12 0:58 ` Paul Mackerras
2016-09-12 3:03 ` Michael Ellerman
2016-09-12 9:45 ` Paolo Bonzini
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=87mvjnrk2z.fsf@linux.vnet.ibm.com \
--to=aneesh.kumar@linux.vnet.ibm.com \
--cc=kvm-ppc@vger.kernel.org \
--cc=kvm@vger.kernel.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=paulus@ozlabs.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