All of lore.kernel.org
 help / color / mirror / Atom feed
From: Alexey Kardashevskiy <aik@ozlabs.ru>
To: David Gibson <david@gibson.dropbear.id.au>
Cc: lvivier@redhat.com, thuth@redhat.com, qemu-devel@nongnu.org,
	mdroth@linux.vnet.ibm.com, agraf@suse.de, qemu-ppc@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 2/2] ppc: Allow 64kiB pages for POWER8 in TCG
Date: Tue, 12 Jan 2016 15:30:33 +1100	[thread overview]
Message-ID: <56948169.1000702@ozlabs.ru> (raw)
In-Reply-To: <20160112002609.GF22925@voom.redhat.com>

On 01/12/2016 11:26 AM, David Gibson wrote:
> On Fri, Jan 08, 2016 at 02:56:02PM +1100, Alexey Kardashevskiy wrote:
>> On 12/21/2015 01:41 PM, David Gibson wrote:
>>> Now that the spapr code has been extended to support 64kiB pages, we can
>>> allow guests to use 64kiB pages on an emulated POWER8 by adding it to the
>>> "segment_page_sizes" structure which is advertised via the device tree.
>>>
>>> For now we just add support for 64kiB pages in 64kiB page segments.  Real
>>> POWER8 also supports 64kiB pages in 4kiB page segments, but that will
>>> require more work to implement.
>>>
>>> Real POWER7s (and maybe some other CPU models) also support 64kiB pages,
>>> however, I don't want to add support there without double checking if they
>>> use the same HPTE and SLB encodings (in principle these are implementation
>>> dependent).
>>>
>>> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
>>> ---
>>>   target-ppc/translate_init.c | 17 +++++++++++++++++
>>>   1 file changed, 17 insertions(+)
>>>
>>> diff --git a/target-ppc/translate_init.c b/target-ppc/translate_init.c
>>> index e88dc7f..ae5a269 100644
>>> --- a/target-ppc/translate_init.c
>>> +++ b/target-ppc/translate_init.c
>>> @@ -8200,6 +8200,22 @@ POWERPC_FAMILY(POWER8)(ObjectClass *oc, void *data)
>>>   {
>>>       DeviceClass *dc = DEVICE_CLASS(oc);
>>>       PowerPCCPUClass *pcc = POWERPC_CPU_CLASS(oc);
>>> +    static const struct ppc_segment_page_sizes POWER8_sps = {
>>> +        .sps = {
>>> +            { .page_shift = 12, /* 4K */
>>> +              .slb_enc = 0,
>>> +              .enc = { { .page_shift = 12, .pte_enc = 0 } }
>>> +            },
>>> +            { .page_shift = 16, /* 64K */
>>> +              .slb_enc = 0x110,
>>> +              .enc = { { .page_shift = 16, .pte_enc = 0x1 } }
>>> +            },
>>> +            { .page_shift = 24, /* 16M */
>>> +              .slb_enc = 0x100,
>>> +              .enc = { { .page_shift = 24, .pte_enc = 0 } }
>>> +            },
>>> +        }
>>> +    };
>>
>>
>> In order to educate myself - where did 0x110/0x100 come from?
>
> These are the L and LP bit encodings used by actual POWER8 hardware -
> IIRC I took the information from the kernel's mmu_psize_defs table.


I found this in p8-book4. Paul suggested there is a public POWER8 user 
manual but I cannot neither google it nor find on 
http://openpowerfoundation.org/.


>> Is not 0x110
>> SLB_VSID_64K (which does not use SLB_VSID_L by accident?)?
>
> Yes, it is
>
>> And is 0x100
>> SLB_VSID_L?
>
> Yes.

Cool, thanks.

btw why not to use those definitions then...


>
>> I just wanted to double check if POWER7 uses the same encoding and it is not
>> that simple to trace what came from where...
>>
>>
>>
>>>
>>>       dc->fw_name = "PowerPC,POWER8";
>>>       dc->desc = "POWER8";
>>> @@ -8258,6 +8274,7 @@ POWERPC_FAMILY(POWER8)(ObjectClass *oc, void *data)
>>>       pcc->l1_dcache_size = 0x8000;
>>>       pcc->l1_icache_size = 0x8000;
>>>       pcc->interrupts_big_endian = ppc_cpu_interrupts_big_endian_lpcr;
>>> +    pcc->sps = &POWER8_sps;
>>>   }
>>>   #endif /* defined (TARGET_PPC64) */
>>>
>>>
>>
>>
>


-- 
Alexey

  reply	other threads:[~2016-01-12  4:30 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-12-21  2:41 [Qemu-devel] [PATCH 0/2] 64kiB page support for TCG guests with POWER8 CPU David Gibson
2015-12-21  2:41 ` [Qemu-devel] [PATCH 1/2] ppc: Move HPTE size parsing code to target-ppc helper (and add 64kiB pages) David Gibson
2016-01-08  3:31   ` Alexey Kardashevskiy
2015-12-21  2:41 ` [Qemu-devel] [PATCH 2/2] ppc: Allow 64kiB pages for POWER8 in TCG David Gibson
2015-12-21  2:49   ` Benjamin Herrenschmidt
2016-01-08  3:56   ` Alexey Kardashevskiy
2016-01-12  0:26     ` David Gibson
2016-01-12  4:30       ` Alexey Kardashevskiy [this message]
2016-01-12  4:33         ` David Gibson
2016-01-12  5:39           ` Alexey Kardashevskiy

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=56948169.1000702@ozlabs.ru \
    --to=aik@ozlabs.ru \
    --cc=agraf@suse.de \
    --cc=david@gibson.dropbear.id.au \
    --cc=lvivier@redhat.com \
    --cc=mdroth@linux.vnet.ibm.com \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-ppc@nongnu.org \
    --cc=thuth@redhat.com \
    /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.