public inbox for linux-arm-kernel@lists.infradead.org 
 help / color / mirror / Atom feed
From: Vladimir Murzin <vladimir.murzin@arm•com>
To: Mark Rutland <mark.rutland@arm•com>,
	linux-arm-kernel@lists•infradead.org, kvmarm@lists•linux.dev
Cc: broonie@kernel•org, catalin.marinas@arm•com, james.morse@arm•com,
	maz@kernel•org, oupton@kernel•org, tabba@google•com,
	will@kernel•org
Subject: Re: [PATCH 13/18] arm64: fpsimd: Use opaque type for SVE state
Date: Thu, 28 May 2026 10:45:25 +0100	[thread overview]
Message-ID: <362fe07b-70d5-4933-96d3-6445242f9077@arm.com> (raw)
In-Reply-To: <20260521132556.584676-14-mark.rutland@arm.com>

On 5/21/26 14:25, Mark Rutland wrote:
> As the SVE state size can vary at runtime, we don't have a concrete type
> for the in-memory SVE state, and pass this around using a pointer to
> void. The functions which save/restore the SVE state have a very unusual
> calling convention, expecting a pointer to the FFR *in the middle of*
> the in-memory SVE state, which is also passed as a pointer to void.
> Passing a pointer to the FFR also requires that callers find the live VL
> and perform some arithmetic, which callers implement differently.
> 
> Using pointer to void means that it's very easy to introduce errors that
> cannot be caught by the compiler (e.g. as 'void **' can be assigned to
> 'void *'). In general this is unnecessarily confusing and fragile.
> 
> Improve this by adding an opaque 'struct sve_state', and consistently
> passing a pointer to this, performing the necessary offsetting *within*
> the save/restore functions.
> 
> For the moment, the offsetting is performed in a new '_sve_pffr'
> assembly macro, using the ADDVL and ADDPL instructions. These add a
> multiple of the live vector length and predicate length respectively.
> The ADDVL immediate range cannot encode 32, so this is split into two
> increments of 16.
> 
> Signed-off-by: Mark Rutland <mark.rutland@arm•com>
> Cc: Catalin Marinas <catalin.marinas@arm•com>
> Cc: Fuad Tabba <tabba@google•com>
> Cc: James Morse <james.morse@arm•com>
> Cc: Marc Zyngier <maz@kernel•org>
> Cc: Mark Brown <broonie@kernel•org>
> Cc: Oliver Upton <oupton@kernel•org>
> Cc: Will Deacon <will@kernel•org>
> ---
>  arch/arm64/include/asm/fpsimd.h         | 24 +++---------------------
>  arch/arm64/include/asm/fpsimdmacros.h   |  9 +++++++++
>  arch/arm64/include/asm/kvm_host.h       |  8 ++------
>  arch/arm64/include/asm/kvm_hyp.h        |  4 ++--
>  arch/arm64/include/asm/processor.h      |  4 +++-
>  arch/arm64/kernel/fpsimd.c              | 21 ++++++++++-----------
>  arch/arm64/kvm/arm.c                    |  4 ++--
>  arch/arm64/kvm/guest.c                  |  4 ++--
>  arch/arm64/kvm/hyp/include/hyp/switch.h |  8 +++-----
>  arch/arm64/kvm/hyp/nvhe/hyp-main.c      |  7 +++----
>  arch/arm64/kvm/hyp/nvhe/setup.c         |  2 +-
>  11 files changed, 40 insertions(+), 55 deletions(-)
> 
> diff --git a/arch/arm64/include/asm/fpsimd.h b/arch/arm64/include/asm/fpsimd.h
> index 19b373ad0ebf7..19e670ae67598 100644
> --- a/arch/arm64/include/asm/fpsimd.h
> +++ b/arch/arm64/include/asm/fpsimd.h
> @@ -162,7 +162,7 @@ extern void fpsimd_update_current_state(struct user_fpsimd_state const *state);
>  
>  struct cpu_fp_state {
>  	struct user_fpsimd_state *st;
> -	void *sve_state;
> +	struct sve_state *sve_state;
>  	void *sme_state;
>  	u64 *svcr;
>  	u64 *fpmr;
> @@ -195,24 +195,6 @@ extern void task_smstop_sm(struct task_struct *task);
>  /* Maximum VL that SVE/SME VL-agnostic software can transparently support */
>  #define VL_ARCH_MAX 0x100
>  
> -/* Offset of FFR in the SVE register dump */
> -static inline size_t sve_ffr_offset(int vl)
> -{
> -	return SVE_SIG_FFR_OFFSET(sve_vq_from_vl(vl)) - SVE_SIG_REGS_OFFSET;
> -}
> -

If my math is correct it would expand into 

  __SVE_ZREGS_OFFSET + __SVE_ZREG_SIZE(vq) * 32 + __SVE_PREG_SIZE(vq) * 16

or, given __SVE_ZREGS_OFFSET is 0, just

  __SVE_ZREG_SIZE(vq) * 32 + __SVE_PREG_SIZE(vq) * 16


> -static inline void *sve_pffr(struct thread_struct *thread)
> -{
> -	unsigned int vl;
> -
> -	if (system_supports_sme() && thread_sm_enabled(thread))
> -		vl = thread_get_sme_vl(thread);
> -	else
> -		vl = thread_get_sve_vl(thread);
> -
> -	return (char *)thread->sve_state + sve_ffr_offset(vl);
> -}
> -
>  static inline void *thread_zt_state(struct thread_struct *thread)
>  {
>  	/* The ZT register state is stored immediately after the ZA state */
> @@ -233,8 +215,8 @@ static inline unsigned int sve_get_vl(void)
>  	return vl;
>  }
>  
> -extern void sve_save_state(void *state, int save_ffr);
> -extern void sve_load_state(void const *state, int restore_ffr);
> +extern void sve_save_state(struct sve_state *state, int save_ffr);
> +extern void sve_load_state(const struct sve_state *state, int restore_ffr);
>  extern void sve_flush_live(bool flush_ffr, unsigned long vq_minus_1);
>  extern void sme_save_state(void *state, int zt);
>  extern void sme_load_state(void const *state, int zt);
> diff --git a/arch/arm64/include/asm/fpsimdmacros.h b/arch/arm64/include/asm/fpsimdmacros.h
> index 01b5e6d51ba79..08f4863e67715 100644
> --- a/arch/arm64/include/asm/fpsimdmacros.h
> +++ b/arch/arm64/include/asm/fpsimdmacros.h
> @@ -176,7 +176,15 @@
>  		_sve_wrffr	0
>  .endm
>  
> +.macro _sve_pffr ptr
> +	.arch_extension sve
> +	addvl	\ptr, \ptr, #16
> +	addvl	\ptr, \ptr, #16
> +	addpl	\ptr, \ptr, #16
> +.endm
> +

This matches to the end result of sve_ffr_offset()

>  .macro sve_save nxbase, save_ffr
> +		_sve_pffr	x\nxbase
>   _for n, 0, 31,	_sve_str_v	\n, \nxbase, \n - 34
>   _for n, 0, 15,	_sve_str_p	\n, \nxbase, \n - 16
>  		cbz		\save_ffr, 921f
> @@ -190,6 +198,7 @@
>  .endm
>  
>  .macro sve_load nxbase, restore_ffr
> +		_sve_pffr	x\nxbase
>   _for n, 0, 31,	_sve_ldr_v	\n, \nxbase, \n - 34
>  		cbz		\restore_ffr, 921f
>  		_sve_ldr_p	0, \nxbase
> diff --git a/arch/arm64/include/asm/kvm_host.h b/arch/arm64/include/asm/kvm_host.h
> index ae24617380b8f..a366509c5944e 100644
> --- a/arch/arm64/include/asm/kvm_host.h
> +++ b/arch/arm64/include/asm/kvm_host.h
> @@ -759,7 +759,7 @@ struct kvm_host_data {
>  	 * Hyp VA.
>  	 * sve_regs is only used in pKVM and if system_supports_sve().
>  	 */
> -	u8	*sve_regs;
> +	struct sve_state *sve_regs;
>  
>  	/* Ownership of the FP regs */
>  	enum {
> @@ -853,7 +853,7 @@ struct kvm_vcpu_arch {
>  	 * floating point code saves the register state of a task it
>  	 * records which view it saved in fp_type.
>  	 */
> -	void *sve_state;
> +	struct sve_state *sve_state;
>  	enum fp_type fp_type;
>  	unsigned int sve_max_vl;
>  
> @@ -1097,10 +1097,6 @@ struct kvm_vcpu_arch {
>  #define NESTED_SERROR_PENDING	__vcpu_single_flag(sflags, BIT(8))
>  
>  
> -/* Pointer to the vcpu's SVE FFR for sve_{save,load}_state() */
> -#define vcpu_sve_pffr(vcpu) (kern_hyp_va((vcpu)->arch.sve_state) +	\
> -			     sve_ffr_offset((vcpu)->arch.sve_max_vl))
> -
>  #define vcpu_sve_max_vq(vcpu)	sve_vq_from_vl((vcpu)->arch.sve_max_vl)
>  
>  #define vcpu_sve_zcr_elx(vcpu)						\
> diff --git a/arch/arm64/include/asm/kvm_hyp.h b/arch/arm64/include/asm/kvm_hyp.h
> index 8c4602c8f4356..38356eee592ad 100644
> --- a/arch/arm64/include/asm/kvm_hyp.h
> +++ b/arch/arm64/include/asm/kvm_hyp.h
> @@ -121,8 +121,8 @@ void __debug_save_host_buffers_nvhe(struct kvm_vcpu *vcpu);
>  void __debug_restore_host_buffers_nvhe(struct kvm_vcpu *vcpu);
>  #endif
>  
> -void __sve_save_state(void *sve, int save_ffr);
> -void __sve_restore_state(void *sve, int restore_ffr);
> +void __sve_save_state(struct sve_state *sve, int save_ffr);
> +void __sve_restore_state(struct sve_state *sve, int restore_ffr);
>  
>  u64 __guest_enter(struct kvm_vcpu *vcpu);
>  
> diff --git a/arch/arm64/include/asm/processor.h b/arch/arm64/include/asm/processor.h
> index e30c4c8e3a7a7..1c2ffd063baa8 100644
> --- a/arch/arm64/include/asm/processor.h
> +++ b/arch/arm64/include/asm/processor.h
> @@ -130,6 +130,8 @@ enum fp_type {
>  	FP_STATE_SVE,
>  };
>  
> +struct sve_state;		/* Opaque type */
> +
>  struct cpu_context {
>  	unsigned long x19;
>  	unsigned long x20;
> @@ -164,7 +166,7 @@ struct thread_struct {
>  
>  	enum fp_type		fp_type;	/* registers FPSIMD or SVE? */
>  	unsigned int		fpsimd_cpu;
> -	void			*sve_state;	/* SVE registers, if any */
> +	struct sve_state	*sve_state;	/* SVE registers, if any */
>  	void			*sme_state;	/* ZA and ZT state, if any */
>  	unsigned int		vl[ARM64_VEC_MAX];	/* vector length */
>  	unsigned int		vl_onexec[ARM64_VEC_MAX]; /* vl after next exec */
> diff --git a/arch/arm64/kernel/fpsimd.c b/arch/arm64/kernel/fpsimd.c
> index 9806fea8fea7c..66d880d081671 100644
> --- a/arch/arm64/kernel/fpsimd.c
> +++ b/arch/arm64/kernel/fpsimd.c
> @@ -425,8 +425,7 @@ static void task_fpsimd_load(void)
>  
>  	if (restore_sve_regs) {
>  		WARN_ON_ONCE(current->thread.fp_type != FP_STATE_SVE);
> -		sve_load_state(sve_pffr(&current->thread),
> -			       restore_ffr);
> +		sve_load_state(current->thread.sve_state, restore_ffr);

I do not know much about this code, I assume that live VL matches to current
but having some logic to check that assumption would be handy...

>  		fpsimd_load_common(&current->thread.uw.fpsimd_state);
>  	} else {
>  		WARN_ON_ONCE(current->thread.fp_type != FP_STATE_FPSIMD);
> @@ -507,9 +506,7 @@ static void fpsimd_save_user_state(void)
>  			return;
>  		}
>  
> -		sve_save_state((char *)last->sve_state +
> -					sve_ffr_offset(vl),
> -			       save_ffr);
> +		sve_save_state(last->sve_state, save_ffr);

Few lines above we check that live VL matches our expectations 

  WARN_ON(sve_get_vl() != vl)

so we can rely on live VL value

>  		fpsimd_save_common(last->st);
>  		*last->fp_type = FP_STATE_SVE;
>  	} else {
> @@ -641,7 +638,8 @@ static __uint128_t arm64_cpu_to_le128(__uint128_t x)
>  
>  #define arm64_le128_to_cpu(x) arm64_cpu_to_le128(x)
>  
> -static void __fpsimd_to_sve(void *sst, struct user_fpsimd_state const *fst,
> +static void __fpsimd_to_sve(struct sve_state *sst,
> +			    struct user_fpsimd_state const *fst,
>  			    unsigned int vq)
>  {
>  	unsigned int i;
> @@ -668,7 +666,7 @@ static void __fpsimd_to_sve(void *sst, struct user_fpsimd_state const *fst,
>  static inline void fpsimd_to_sve(struct task_struct *task)
>  {
>  	unsigned int vq;
> -	void *sst = task->thread.sve_state;
> +	struct sve_state *sst = task->thread.sve_state;
>  	struct user_fpsimd_state const *fst = &task->thread.uw.fpsimd_state;
>  
>  	if (!system_supports_sve() && !system_supports_sme())
> @@ -692,7 +690,7 @@ static inline void fpsimd_to_sve(struct task_struct *task)
>  static inline void sve_to_fpsimd(struct task_struct *task)
>  {
>  	unsigned int vq, vl;
> -	void const *sst = task->thread.sve_state;
> +	const struct sve_state *sst = task->thread.sve_state;
>  	struct user_fpsimd_state *fst = &task->thread.uw.fpsimd_state;
>  	unsigned int i;
>  	__uint128_t const *p;
> @@ -791,7 +789,7 @@ void fpsimd_sync_from_effective_state(struct task_struct *task)
>  void fpsimd_sync_to_effective_state_zeropad(struct task_struct *task)
>  {
>  	unsigned int vq;
> -	void *sst = task->thread.sve_state;
> +	struct sve_state *sst = task->thread.sve_state;
>  	struct user_fpsimd_state const *fst = &task->thread.uw.fpsimd_state;
>  
>  	if (task->thread.fp_type != FP_STATE_SVE)
> @@ -809,7 +807,8 @@ static int change_live_vector_length(struct task_struct *task,
>  {
>  	unsigned int sve_vl = task_get_sve_vl(task);
>  	unsigned int sme_vl = task_get_sme_vl(task);
> -	void *sve_state = NULL, *sme_state = NULL;
> +	struct sve_state *sve_state = NULL;
> +	void *sme_state = NULL;
>  
>  	if (type == ARM64_VEC_SME)
>  		sme_vl = vl;
> @@ -1645,7 +1644,7 @@ static void fpsimd_flush_thread_vl(enum vec_type type)
>  
>  void fpsimd_flush_thread(void)
>  {
> -	void *sve_state = NULL;
> +	struct sve_state *sve_state = NULL;
>  	void *sme_state = NULL;
>  
>  	if (!system_supports_fpsimd())
> diff --git a/arch/arm64/kvm/arm.c b/arch/arm64/kvm/arm.c
> index f9fc85a0344e1..7a3db4d7dcdef 100644
> --- a/arch/arm64/kvm/arm.c
> +++ b/arch/arm64/kvm/arm.c
> @@ -2499,7 +2499,7 @@ static void __init teardown_hyp_mode(void)
>  			continue;
>  
>  		if (free_sve) {
> -			u8 *sve_regs;
> +			struct sve_state *sve_regs;
>  
>  			sve_regs = per_cpu_ptr_nvhe_sym(kvm_host_data, cpu)->sve_regs;
>  			free_pages((unsigned long) sve_regs, pkvm_host_sve_state_order());
> @@ -2648,7 +2648,7 @@ static void finalize_init_hyp_mode(void)
>  
>  	if (system_supports_sve() && is_protected_kvm_enabled()) {
>  		for_each_possible_cpu(cpu) {
> -			u8 *sve_regs;
> +			struct sve_state *sve_regs;
>  
>  			sve_regs = per_cpu_ptr_nvhe_sym(kvm_host_data, cpu)->sve_regs;
>  			per_cpu_ptr_nvhe_sym(kvm_host_data, cpu)->sve_regs =
> diff --git a/arch/arm64/kvm/guest.c b/arch/arm64/kvm/guest.c
> index 332c453b87cf8..b01d6622b8720 100644
> --- a/arch/arm64/kvm/guest.c
> +++ b/arch/arm64/kvm/guest.c
> @@ -500,7 +500,7 @@ static int get_sve_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg)
>  	if (!kvm_arm_vcpu_sve_finalized(vcpu))
>  		return -EPERM;
>  
> -	if (copy_to_user(uptr, vcpu->arch.sve_state + region.koffset,
> +	if (copy_to_user(uptr, (void *)vcpu->arch.sve_state + region.koffset,
>  			 region.klen) ||
>  	    clear_user(uptr + region.klen, region.upad))
>  		return -EFAULT;
> @@ -526,7 +526,7 @@ static int set_sve_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg)
>  	if (!kvm_arm_vcpu_sve_finalized(vcpu))
>  		return -EPERM;
>  
> -	if (copy_from_user(vcpu->arch.sve_state + region.koffset, uptr,
> +	if (copy_from_user((void *)vcpu->arch.sve_state + region.koffset, uptr,
>  			   region.klen))
>  		return -EFAULT;
>  
> diff --git a/arch/arm64/kvm/hyp/include/hyp/switch.h b/arch/arm64/kvm/hyp/include/hyp/switch.h
> index aaa43554fd8e6..72e658255cda7 100644
> --- a/arch/arm64/kvm/hyp/include/hyp/switch.h
> +++ b/arch/arm64/kvm/hyp/include/hyp/switch.h
> @@ -467,8 +467,7 @@ static inline void __hyp_sve_restore_guest(struct kvm_vcpu *vcpu)
>  	 * vCPU. Start off with the max VL so we can load the SVE state.
>  	 */
>  	sve_cond_update_zcr_vq(vcpu_sve_max_vq(vcpu) - 1, SYS_ZCR_EL2);
> -	__sve_restore_state(vcpu_sve_pffr(vcpu),
> -			    true);
> +	__sve_restore_state(kern_hyp_va(vcpu->arch.sve_state), true);

We've just set live VL, so can rely on it

>  	fpsimd_load_common(&vcpu->arch.ctxt.fp_regs);
>  
>  	/*
> @@ -485,12 +484,11 @@ static inline void __hyp_sve_restore_guest(struct kvm_vcpu *vcpu)
>  static inline void __hyp_sve_save_host(void)
>  {
>  	struct kvm_cpu_context *hctxt = host_data_ptr(host_ctxt);
> -	u8 *sve_regs = *host_data_ptr(sve_regs);
> +	struct sve_state *sve_regs = *host_data_ptr(sve_regs);
>  
>  	ctxt_sys_reg(hctxt, ZCR_EL1) = read_sysreg_el1(SYS_ZCR);
>  	write_sysreg_s(sve_vq_from_vl(kvm_host_sve_max_vl) - 1, SYS_ZCR_EL2);
> -	__sve_save_state(sve_regs + sve_ffr_offset(kvm_host_sve_max_vl),
> -			 true);
> +	__sve_save_state(sve_regs, true);

We've just set live VL, so can rely on it

>  	fpsimd_save_common(&hctxt->fp_regs);
>  }
>  
> diff --git a/arch/arm64/kvm/hyp/nvhe/hyp-main.c b/arch/arm64/kvm/hyp/nvhe/hyp-main.c
> index 627762ed7327f..72d025b2178a7 100644
> --- a/arch/arm64/kvm/hyp/nvhe/hyp-main.c
> +++ b/arch/arm64/kvm/hyp/nvhe/hyp-main.c
> @@ -35,7 +35,7 @@ static void __hyp_sve_save_guest(struct kvm_vcpu *vcpu)
>  	 * on the VL, so use a consistent (i.e., the maximum) guest VL.
>  	 */
>  	sve_cond_update_zcr_vq(vcpu_sve_max_vq(vcpu) - 1, SYS_ZCR_EL2);
> -	__sve_save_state(vcpu_sve_pffr(vcpu), true);
> +	__sve_save_state(kern_hyp_va(vcpu->arch.sve_state), true);

We've just set live VL, so can rely on it

>  	fpsimd_save_common(&vcpu->arch.ctxt.fp_regs);
>  	write_sysreg_s(sve_vq_from_vl(kvm_host_sve_max_vl) - 1, SYS_ZCR_EL2);
>  }
> @@ -43,7 +43,7 @@ static void __hyp_sve_save_guest(struct kvm_vcpu *vcpu)
>  static void __hyp_sve_restore_host(void)
>  {
>  	struct kvm_cpu_context *hctxt = host_data_ptr(host_ctxt);
> -	u8 *sve_regs = *host_data_ptr(sve_regs);
> +	struct sve_state *sve_regs = *host_data_ptr(sve_regs);
>  
>  	/*
>  	 * On saving/restoring host sve state, always use the maximum VL for
> @@ -55,8 +55,7 @@ static void __hyp_sve_restore_host(void)
>  	 * need to be revisited.
>  	 */
>  	write_sysreg_s(sve_vq_from_vl(kvm_host_sve_max_vl) - 1, SYS_ZCR_EL2);
> -	__sve_restore_state(sve_regs + sve_ffr_offset(kvm_host_sve_max_vl),
> -			    true);
> +	__sve_restore_state(sve_regs, true);

We've just set live VL, so can rely on it

>  	fpsimd_load_common(&hctxt->fp_regs);
>  	write_sysreg_el1(ctxt_sys_reg(hctxt, ZCR_EL1), SYS_ZCR);
>  }
> diff --git a/arch/arm64/kvm/hyp/nvhe/setup.c b/arch/arm64/kvm/hyp/nvhe/setup.c
> index cdaf53c833409..77dbcfed05486 100644
> --- a/arch/arm64/kvm/hyp/nvhe/setup.c
> +++ b/arch/arm64/kvm/hyp/nvhe/setup.c
> @@ -82,7 +82,7 @@ static int pkvm_create_host_sve_mappings(void)
>  
>  	for (i = 0; i < hyp_nr_cpus; i++) {
>  		struct kvm_host_data *host_data = per_cpu_ptr(&kvm_host_data, i);
> -		u8 *sve_regs = host_data->sve_regs;
> +		struct sve_state *sve_regs = host_data->sve_regs;
>  
>  		start = kern_hyp_va(sve_regs);
>  		end = start + PAGE_ALIGN(pkvm_host_sve_state_size());
> -- 2.30.2
> 

FWIW,

Reviewed-by: Vladimir Murzin <vladimir.murzin@arm•com>



  parent reply	other threads:[~2026-05-28  9:45 UTC|newest]

Thread overview: 78+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-05-21 13:25 [PATCH 00/18] arm64+KVM: FPSIMD/SVE/SME cleanups Mark Rutland
2026-05-21 13:25 ` [PATCH 01/18] KVM: arm64: Don't include <asm/fpsimdmacros.h> Mark Rutland
2026-05-26 14:18   ` Mark Brown
2026-05-27 10:10   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 02/18] KVM: arm64: Don't override FFR save/restore argument Mark Rutland
2026-05-26 14:27   ` Mark Brown
2026-05-27 10:16   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 03/18] KVM: arm64: pkvm: Save host FPMR in host cpu context Mark Rutland
2026-05-27 10:29   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 04/18] KVM: arm64: pkvm: Remove struct cpu_sve_state Mark Rutland
2026-05-27 11:58   ` Vladimir Murzin
2026-05-27 16:02     ` Mark Rutland
2026-05-27 16:11       ` Vladimir Murzin
2026-05-28 15:09         ` Mark Rutland
2026-05-28 15:12           ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 05/18] arm64: fpsimd: Fold sve_init_regs() into do_sve_acc() Mark Rutland
2026-05-26 15:28   ` Mark Brown
2026-05-27 12:05   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 06/18] arm64: fpsimd: Remove sve_set_vq() and sme_set_vq() Mark Rutland
2026-05-26 15:42   ` Mark Brown
2026-05-27 12:50   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 07/18] arm64: fpsimd: Use assembler for SVE instructions Mark Rutland
2026-05-26 15:43   ` Mark Brown
2026-05-27 12:58   ` Vladimir Murzin
2026-05-27 16:10     ` Mark Rutland
2026-05-21 13:25 ` [PATCH 08/18] arm64: fpsimd: Use assembler for baseline SME instructions Mark Rutland
2026-05-26 15:45   ` Mark Brown
2026-05-27 13:06   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 09/18] arm64: fpsimd: Move sve_get_vl() and sme_get_vl() inline Mark Rutland
2026-05-26 15:47   ` Mark Brown
2026-05-27 13:18   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 10/18] arm64: sysreg: Add FPCR and FPSR Mark Rutland
2026-05-26 15:55   ` Mark Brown
2026-05-26 16:51     ` Mark Rutland
2026-05-26 16:54       ` Mark Brown
2026-05-21 13:25 ` [PATCH 11/18] arm64: fpsimd: Split FPSR/FPCR from SVE save/restore Mark Rutland
2026-05-26 16:28   ` Mark Brown
2026-05-27 13:51     ` Mark Rutland
2026-05-27 14:13       ` Mark Brown
2026-05-27 16:13         ` Mark Rutland
2026-05-27 13:44   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 12/18] arm64: fpsimd: Move fpsimd save/restore inline Mark Rutland
2026-05-26 16:44   ` Mark Brown
2026-05-28 16:15     ` Mark Rutland
2026-05-28 16:39       ` Mark Brown
2026-05-27 14:49   ` Vladimir Murzin
2026-05-27 15:34     ` Mark Rutland
2026-05-27 16:13       ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 13/18] arm64: fpsimd: Use opaque type for SVE state Mark Rutland
2026-05-26 16:53   ` Mark Brown
2026-05-28  9:45   ` Vladimir Murzin [this message]
2026-05-28 16:25     ` Mark Rutland
2026-05-21 13:25 ` [PATCH 14/18] arm64: fpsimd: Use opaque type for SME state Mark Rutland
2026-05-26 16:56   ` Mark Brown
2026-05-28  9:51   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 15/18] arm64: fpsimd: Move SVE save/restore inline Mark Rutland
2026-05-27 12:29   ` Mark Brown
2026-05-28 10:39   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 16/18] arm64: fpsimd: Move sve_flush_live() inline Mark Rutland
2026-05-27 12:54   ` Mark Brown
2026-05-27 16:23     ` Mark Rutland
2026-05-28 10:49   ` Vladimir Murzin
2026-05-21 13:25 ` [PATCH 17/18] arm64: fpsimd: Move SME save/restore inline Mark Rutland
2026-05-26 14:08   ` Mark Rutland
2026-05-26 14:39     ` Vladimir Murzin
2026-05-26 15:28       ` Mark Rutland
2026-05-26 16:38         ` Mark Rutland
2026-05-27  9:00           ` Vladimir Murzin
2026-05-29  9:10           ` Mark Rutland
2026-05-28 12:30   ` Vladimir Murzin
2026-05-28 14:39     ` Mark Rutland
2026-05-21 13:25 ` [PATCH 18/18] arm64: fpsimd: Remove <asm/fpsimdmacros.h> Mark Rutland
2026-05-28 13:10   ` Vladimir Murzin
2026-05-27  8:07 ` [PATCH 00/18] arm64+KVM: FPSIMD/SVE/SME cleanups Marc Zyngier
2026-05-27 10:32   ` Mark Rutland
2026-05-27 14:36     ` Will Deacon
2026-05-28 13:21 ` Vladimir Murzin
2026-05-28 16:28   ` Mark Rutland

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=362fe07b-70d5-4933-96d3-6445242f9077@arm.com \
    --to=vladimir.murzin@arm$(echo .)com \
    --cc=broonie@kernel$(echo .)org \
    --cc=catalin.marinas@arm$(echo .)com \
    --cc=james.morse@arm$(echo .)com \
    --cc=kvmarm@lists$(echo .)linux.dev \
    --cc=linux-arm-kernel@lists$(echo .)infradead.org \
    --cc=mark.rutland@arm$(echo .)com \
    --cc=maz@kernel$(echo .)org \
    --cc=oupton@kernel$(echo .)org \
    --cc=tabba@google$(echo .)com \
    --cc=will@kernel$(echo .)org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html
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