From: Michael Neuling <mikey@neuling.org>
To: Nicholas Piggin <npiggin@gmail.com>, linuxppc-dev@lists.ozlabs.org
Subject: Re: [PATCH v2 2/2] powerpc/64s: idle skip POWER9 DD1 and DD2.0 specific workarounds on DD2.1
Date: Fri, 03 Nov 2017 12:13:19 +1100 [thread overview]
Message-ID: <1509671599.16627.53.camel@neuling.org> (raw)
In-Reply-To: <20171102015535.30843-3-npiggin@gmail.com>
On Thu, 2017-11-02 at 12:55 +1100, Nicholas Piggin wrote:
> DD2.1 does not have to flush the ERAT after a state-loss idle. It also
> does not have to save and restore MMCR0 (although it does have to save
> restore in deep idle states, like other PMU registers).
Minor nit, can we do this as two separate commits in case we discover one i=
s
broken.
> Performance testing was done on a DD2.1 using only the stop0 idle state
> (the shallowest state which supports state loss), using context_switch
> selftest configured to ping-poing between two threads on the same core
> and two different cores.
>=20
> Performance improvement for same core is 7.0%, different cores is 14.8%.
Noice!
> Reviewed-by: Vaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com>
> Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
> ---
> arch/powerpc/kernel/idle_book3s.S | 31 ++++++++++++++++++++-----------
> 1 file changed, 20 insertions(+), 11 deletions(-)
>=20
> diff --git a/arch/powerpc/kernel/idle_book3s.S
> b/arch/powerpc/kernel/idle_book3s.S
> index 175d49f468af..59657783d1d5 100644
> --- a/arch/powerpc/kernel/idle_book3s.S
> +++ b/arch/powerpc/kernel/idle_book3s.S
> @@ -112,12 +112,14 @@ power9_save_additional_sprs:
> std r4, STOP_HFSCR(r13)
> =20
> mfspr r3, SPRN_MMCRA
> - mfspr r4, SPRN_MMCR1
> + mfspr r4, SPRN_MMCR0
> std r3, STOP_MMCRA(r13)
> - std r4, STOP_MMCR1(r13)
> + std r4, _MMCR0(r1)
> =20
> - mfspr r3, SPRN_MMCR2
> - std r3, STOP_MMCR2(r13)
> + mfspr r3, SPRN_MMCR1
> + mfspr r4, SPRN_MMCR2
> + std r3, STOP_MMCR1(r13)
> + std r4, STOP_MMCR2(r13)
> blr
> =20
> power9_restore_additional_sprs:
> @@ -135,11 +137,14 @@ power9_restore_additional_sprs:
> ld r4, STOP_MMCRA(r13)
> mtspr SPRN_HFSCR, r3
> mtspr SPRN_MMCRA, r4
> - /* We have already restored PACA_MMCR0 */
> - ld r3, STOP_MMCR1(r13)
> - ld r4, STOP_MMCR2(r13)
> - mtspr SPRN_MMCR1, r3
> - mtspr SPRN_MMCR2, r4
> +
> + ld r3, _MMCR0(r1)
> + ld r4, STOP_MMCR1(r13)
> + mtspr SPRN_MMCR0, r3
> + mtspr SPRN_MMCR1, r4
> +
> + ld r3, STOP_MMCR2(r13)
> + mtspr SPRN_MMCR2, r3
> blr
> =20
> /*
> @@ -350,6 +355,7 @@ power_enter_stop:
> b pnv_wakeup_noloss
> =20
> .Lhandle_esl_ec_set:
> +BEGIN_FTR_SECTION
> /*
> * POWER9 DD2 can incorrectly set PMAO when waking up after a
> * state-loss idle. Saving and restoring MMCR0 over idle is a
> @@ -357,6 +363,7 @@ power_enter_stop:
> */
> mfspr r4,SPRN_MMCR0
> std r4,_MMCR0(r1)
> +END_FTR_SECTION_IFSET(CPU_FTR_POWER9_DD1 | CPU_FTR_POWER9_DD20)
> =20
> /*
> * Check if the requested state is a deep idle state.
> @@ -542,15 +549,17 @@ pnv_restore_hyp_resource_arch300:
> * then clear bit 60 in MMCRA to ensure the PMU starts running.
> */
> blt cr3,1f
> +BEGIN_FTR_SECTION
> PPC_INVALIDATE_ERAT
> ld r1,PACAR1(r13)
> + ld r4,_MMCR0(r1)
> + mtspr SPRN_MMCR0,r4
> +END_FTR_SECTION_IFSET(CPU_FTR_POWER9_DD1 | CPU_FTR_POWER9_DD20)
> mfspr r4,SPRN_MMCRA
> ori r4,r4,(1 << (63-60))
> mtspr SPRN_MMCRA,r4
> xori r4,r4,(1 << (63-60))
> mtspr SPRN_MMCRA,r4
> - ld r4,_MMCR0(r1)
> - mtspr SPRN_MMCR0,r4
> 1:
> /*
> * POWER ISA 3. Use PSSCR to determine if we
next prev parent reply other threads:[~2017-11-03 1:13 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-02 1:55 [PATCH v2 0/2] Add POWER9 DD2.0 feature, remove idle workarounds in DD2.1 Nicholas Piggin
2017-11-02 1:55 ` [PATCH v2 1/2] powerpc: add POWER9_DD20 feature Nicholas Piggin
2017-11-02 1:55 ` [PATCH v2 2/2] powerpc/64s: idle skip POWER9 DD1 and DD2.0 specific workarounds on DD2.1 Nicholas Piggin
2017-11-03 1:13 ` Michael Neuling [this message]
2017-11-03 4:22 ` Nicholas Piggin
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=1509671599.16627.53.camel@neuling.org \
--to=mikey@neuling.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=npiggin@gmail.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.