From: marc.zyngier@arm.com (Marc Zyngier)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v7 06/16] arm64/sve: Refactor user SVE trap maintenance for external use
Date: Wed, 9 May 2018 17:36:30 +0100 [thread overview]
Message-ID: <dad74a47-26f4-d38f-a9c4-e60fc9d1a07a@arm.com> (raw)
In-Reply-To: <1525882385-29181-7-git-send-email-Dave.Martin@arm.com>
On 09/05/18 17:12, Dave Martin wrote:
> In preparation for optimising the way KVM manages switching the
> guest and host FPSIMD state, it is necessary to provide a means for
> code outside arch/arm64/kernel/fpsimd.c to restore the user trap
> configuration for SVE correctly for the current task.
>
> Rather than requiring external code to duplicate the maintenance
> explicitly, this patch wraps moves the trap maintenenace to
> fpsimd_bind_to_cpu(), since it is logically part of the work of
> associating the current task with the cpu.
>
> Because fpsimd_bind_to_cpu() is rather a cryptic name to publish
> alongside fpsimd_bind_state_to_cpu(), the former function is
> renamed to fpsimd_bind_task_to_cpu() to make its purpose more
> explicit.
>
> This patch makes appropriate changes to ensure that
> fpsimd_bind_task_to_cpu() is always called alongside
> task_fpsimd_load(), so that the trap maintenance continues to be
> done in every situation where it was done prior to this patch.
>
> As a side-effect, the metadata updates done by
> fpsimd_bind_task_to_cpu() now change from conditional to
> unconditional in the "already bound" case of sigreturn. This is
> harmless, and a couple of extra stores on this slow path will not
> impact performance. I consider this a reasonable price to pay for
> a slightly cleaner interface.
>
> Signed-off-by: Dave Martin <Dave.Martin@arm.com>
> ---
> arch/arm64/kernel/fpsimd.c | 28 ++++++++++++++--------------
> 1 file changed, 14 insertions(+), 14 deletions(-)
>
> diff --git a/arch/arm64/kernel/fpsimd.c b/arch/arm64/kernel/fpsimd.c
> index 5fc0595..60404eb 100644
> --- a/arch/arm64/kernel/fpsimd.c
> +++ b/arch/arm64/kernel/fpsimd.c
> @@ -257,16 +257,6 @@ static void task_fpsimd_load(void)
> sve_vq_from_vl(current->thread.sve_vl) - 1);
> else
> fpsimd_load_state(¤t->thread.uw.fpsimd_state);
> -
> - if (system_supports_sve()) {
> - /* Toggle SVE trapping for userspace if needed */
> - if (test_thread_flag(TIF_SVE))
> - sve_user_enable();
> - else
> - sve_user_disable();
> -
> - /* Serialised by exception return to user */
> - }
> }
>
> /*
> @@ -998,7 +988,7 @@ void fpsimd_signal_preserve_current_state(void)
> * Associate current's FPSIMD context with this cpu
> * Preemption must be disabled when calling this function.
> */
> -static void fpsimd_bind_to_cpu(void)
> +static void fpsimd_bind_task_to_cpu(void)
> {
> struct fpsimd_last_state_struct *last =
> this_cpu_ptr(&fpsimd_last_state);
> @@ -1006,6 +996,16 @@ static void fpsimd_bind_to_cpu(void)
> last->st = ¤t->thread.uw.fpsimd_state;
> last->sve_in_use = test_thread_flag(TIF_SVE);
> current->thread.fpsimd_cpu = smp_processor_id();
> +
> + if (system_supports_sve()) {
Is it worth moving the last->sve_in_use assignment here? If the system
doesn't have SVE, the assignment is always 0, and we probably don't need
to do it at all. It could avoid the double call to test_thread_flag.
> + /* Toggle SVE trapping for userspace if needed */
> + if (test_thread_flag(TIF_SVE))
> + sve_user_enable();
> + else
> + sve_user_disable();
> +
> + /* Serialised by exception return to user */
> + }
> }
>
> /*
> @@ -1022,7 +1022,7 @@ void fpsimd_restore_current_state(void)
>
> if (test_and_clear_thread_flag(TIF_FOREIGN_FPSTATE)) {
> task_fpsimd_load();
> - fpsimd_bind_to_cpu();
> + fpsimd_bind_task_to_cpu();
> }
>
> local_bh_enable();
> @@ -1045,9 +1045,9 @@ void fpsimd_update_current_state(struct user_fpsimd_state const *state)
> fpsimd_to_sve(current);
>
> task_fpsimd_load();
> + fpsimd_bind_task_to_cpu();
>
> - if (test_and_clear_thread_flag(TIF_FOREIGN_FPSTATE))
> - fpsimd_bind_to_cpu();
> + clear_thread_flag(TIF_FOREIGN_FPSTATE);
>
> local_bh_enable();
> }
>
Thanks,
M.
--
Jazz is not dead. It just smells funny...
next prev parent reply other threads:[~2018-05-09 16:36 UTC|newest]
Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-05-09 16:12 [PATCH v7 00/16] KVM: arm64: Optimise FPSIMD context switching Dave Martin
2018-05-09 16:12 ` [PATCH v7 01/16] thread_info: Add update_thread_flag() helpers Dave Martin
2018-05-10 16:15 ` Catalin Marinas
2018-05-09 16:12 ` [PATCH v7 02/16] arm64: Use update{,_tsk}_thread_flag() Dave Martin
2018-05-09 16:17 ` Will Deacon
2018-05-09 16:27 ` Dave Martin
2018-05-09 16:55 ` Marc Zyngier
2018-05-09 17:08 ` Dave Martin
2018-05-10 16:16 ` Catalin Marinas
2018-05-09 16:12 ` [PATCH v7 03/16] KVM: arm/arm64: Introduce kvm_arch_vcpu_run_pid_change Dave Martin
2018-05-09 16:12 ` [PATCH v7 04/16] KVM: arm64: Convert lazy FPSIMD context switch trap to C Dave Martin
2018-05-09 16:12 ` [PATCH v7 05/16] arm64: fpsimd: Generalise context saving for non-task contexts Dave Martin
2018-05-10 16:17 ` Catalin Marinas
2018-05-09 16:12 ` [PATCH v7 06/16] arm64/sve: Refactor user SVE trap maintenance for external use Dave Martin
2018-05-09 16:36 ` Marc Zyngier [this message]
2018-05-09 16:41 ` Dave Martin
2018-05-09 16:47 ` Marc Zyngier
2018-05-10 16:41 ` Catalin Marinas
2018-05-09 16:12 ` [PATCH v7 07/16] KVM: arm64: Repurpose vcpu_arch.debug_flags for general-purpose flags Dave Martin
2018-05-15 10:55 ` Christoffer Dall
2018-05-09 16:12 ` [PATCH v7 08/16] KVM: arm64: Optimise FPSIMD handling to reduce guest/host thrashing Dave Martin
2018-05-09 16:54 ` Marc Zyngier
2018-05-09 17:00 ` Dave Martin
2018-05-10 16:44 ` Catalin Marinas
2018-05-15 10:55 ` Christoffer Dall
2018-05-15 12:48 ` Dave Martin
2018-05-09 16:12 ` [PATCH v7 09/16] arm64/sve: Move read_zcr_features() out of cpufeature.h Dave Martin
2018-05-09 16:12 ` [PATCH v7 10/16] arm64/sve: Switch sve_pffr() argument from task to thread Dave Martin
2018-05-09 16:13 ` [PATCH v7 11/16] arm64/sve: Move sve_pffr() to fpsimd.h and make inline Dave Martin
2018-05-09 16:13 ` [PATCH v7 12/16] KVM: arm64: Save host SVE context as appropriate Dave Martin
2018-05-10 16:52 ` Catalin Marinas
2018-05-09 16:13 ` [PATCH v7 13/16] KVM: arm64: Remove eager host SVE state saving Dave Martin
2018-05-10 16:53 ` Catalin Marinas
2018-05-09 16:13 ` [PATCH v7 14/16] KVM: arm64: Remove redundant *exit_code changes in fpsimd_guest_exit() Dave Martin
2018-05-15 10:46 ` Christoffer Dall
2018-05-09 16:13 ` [PATCH v7 15/16] KVM: arm64: Fold redundant exit code checks out of fixup_guest_exit() Dave Martin
2018-05-09 16:13 ` [PATCH v7 16/16] KVM: arm64: Invoke FPSIMD context switch trap from C Dave Martin
2018-05-15 10:57 ` Christoffer Dall
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=dad74a47-26f4-d38f-a9c4-e60fc9d1a07a@arm.com \
--to=marc.zyngier@arm.com \
--cc=linux-arm-kernel@lists.infradead.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;
as well as URLs for NNTP newsgroup(s).