2019-06-03 07:44:50 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2013-02-06 19:40:29 +00:00
/*
* Copyright ( C ) 2012 , 2013 - ARM Ltd
* Author : Marc Zyngier < marc . zyngier @ arm . com >
*
* Derived from arch / arm / kvm / emulate . c :
* Copyright ( C ) 2012 - Virtual Open Systems and Columbia University
* Author : Christoffer Dall < c . dall @ virtualopensystems . com >
*/
# include <linux/mm.h>
# include <linux/kvm_host.h>
# include <asm/kvm_emulate.h>
# include <asm/ptrace.h>
# define VCPU_NR_MODES 6
# define REG_OFFSET(_reg) \
( offsetof ( struct user_pt_regs , _reg ) / sizeof ( unsigned long ) )
# define USR_REG_OFFSET(R) REG_OFFSET(compat_usr(R))
static const unsigned long vcpu_reg_offsets [ VCPU_NR_MODES ] [ 16 ] = {
/* USR Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) , USR_REG_OFFSET ( 8 ) ,
USR_REG_OFFSET ( 9 ) , USR_REG_OFFSET ( 10 ) , USR_REG_OFFSET ( 11 ) ,
USR_REG_OFFSET ( 12 ) , USR_REG_OFFSET ( 13 ) , USR_REG_OFFSET ( 14 ) ,
REG_OFFSET ( pc )
} ,
/* FIQ Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) ,
REG_OFFSET ( compat_r8_fiq ) , /* r8 */
REG_OFFSET ( compat_r9_fiq ) , /* r9 */
REG_OFFSET ( compat_r10_fiq ) , /* r10 */
REG_OFFSET ( compat_r11_fiq ) , /* r11 */
REG_OFFSET ( compat_r12_fiq ) , /* r12 */
REG_OFFSET ( compat_sp_fiq ) , /* r13 */
REG_OFFSET ( compat_lr_fiq ) , /* r14 */
REG_OFFSET ( pc )
} ,
/* IRQ Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) , USR_REG_OFFSET ( 8 ) ,
USR_REG_OFFSET ( 9 ) , USR_REG_OFFSET ( 10 ) , USR_REG_OFFSET ( 11 ) ,
USR_REG_OFFSET ( 12 ) ,
REG_OFFSET ( compat_sp_irq ) , /* r13 */
REG_OFFSET ( compat_lr_irq ) , /* r14 */
REG_OFFSET ( pc )
} ,
/* SVC Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) , USR_REG_OFFSET ( 8 ) ,
USR_REG_OFFSET ( 9 ) , USR_REG_OFFSET ( 10 ) , USR_REG_OFFSET ( 11 ) ,
USR_REG_OFFSET ( 12 ) ,
REG_OFFSET ( compat_sp_svc ) , /* r13 */
REG_OFFSET ( compat_lr_svc ) , /* r14 */
REG_OFFSET ( pc )
} ,
/* ABT Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) , USR_REG_OFFSET ( 8 ) ,
USR_REG_OFFSET ( 9 ) , USR_REG_OFFSET ( 10 ) , USR_REG_OFFSET ( 11 ) ,
USR_REG_OFFSET ( 12 ) ,
REG_OFFSET ( compat_sp_abt ) , /* r13 */
REG_OFFSET ( compat_lr_abt ) , /* r14 */
REG_OFFSET ( pc )
} ,
/* UND Registers */
{
USR_REG_OFFSET ( 0 ) , USR_REG_OFFSET ( 1 ) , USR_REG_OFFSET ( 2 ) ,
USR_REG_OFFSET ( 3 ) , USR_REG_OFFSET ( 4 ) , USR_REG_OFFSET ( 5 ) ,
USR_REG_OFFSET ( 6 ) , USR_REG_OFFSET ( 7 ) , USR_REG_OFFSET ( 8 ) ,
USR_REG_OFFSET ( 9 ) , USR_REG_OFFSET ( 10 ) , USR_REG_OFFSET ( 11 ) ,
USR_REG_OFFSET ( 12 ) ,
REG_OFFSET ( compat_sp_und ) , /* r13 */
REG_OFFSET ( compat_lr_und ) , /* r14 */
REG_OFFSET ( pc )
} ,
} ;
/*
* Return a pointer to the register number valid in the current mode of
* the virtual CPU .
*/
unsigned long * vcpu_reg32 ( const struct kvm_vcpu * vcpu , u8 reg_num )
{
unsigned long * reg_array = ( unsigned long * ) & vcpu - > arch . ctxt . gp_regs . regs ;
2018-07-05 15:16:53 +01:00
unsigned long mode = * vcpu_cpsr ( vcpu ) & PSR_AA32_MODE_MASK ;
2013-02-06 19:40:29 +00:00
switch ( mode ) {
2018-07-05 15:16:53 +01:00
case PSR_AA32_MODE_USR . . . PSR_AA32_MODE_SVC :
2013-02-06 19:40:29 +00:00
mode & = ~ PSR_MODE32_BIT ; /* 0 ... 3 */
break ;
2018-07-05 15:16:53 +01:00
case PSR_AA32_MODE_ABT :
2013-02-06 19:40:29 +00:00
mode = 4 ;
break ;
2018-07-05 15:16:53 +01:00
case PSR_AA32_MODE_UND :
2013-02-06 19:40:29 +00:00
mode = 5 ;
break ;
2018-07-05 15:16:53 +01:00
case PSR_AA32_MODE_SYS :
2013-02-06 19:40:29 +00:00
mode = 0 ; /* SYS maps to USR */
break ;
default :
BUG ( ) ;
}
return reg_array + vcpu_reg_offsets [ mode ] [ reg_num ] ;
}
/*
* Return the SPSR for the current mode of the virtual CPU .
*/
2017-12-27 21:59:09 +01:00
static int vcpu_spsr32_mode ( const struct kvm_vcpu * vcpu )
2013-02-06 19:40:29 +00:00
{
2018-07-05 15:16:53 +01:00
unsigned long mode = * vcpu_cpsr ( vcpu ) & PSR_AA32_MODE_MASK ;
2013-02-06 19:40:29 +00:00
switch ( mode ) {
2018-07-05 15:16:53 +01:00
case PSR_AA32_MODE_SVC : return KVM_SPSR_SVC ;
case PSR_AA32_MODE_ABT : return KVM_SPSR_ABT ;
case PSR_AA32_MODE_UND : return KVM_SPSR_UND ;
case PSR_AA32_MODE_IRQ : return KVM_SPSR_IRQ ;
case PSR_AA32_MODE_FIQ : return KVM_SPSR_FIQ ;
2017-12-27 21:59:09 +01:00
default : BUG ( ) ;
}
}
unsigned long vcpu_read_spsr32 ( const struct kvm_vcpu * vcpu )
{
int spsr_idx = vcpu_spsr32_mode ( vcpu ) ;
if ( ! vcpu - > arch . sysregs_loaded_on_cpu )
return vcpu_gp_regs ( vcpu ) - > spsr [ spsr_idx ] ;
switch ( spsr_idx ) {
case KVM_SPSR_SVC :
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 11:29:40 +01:00
return read_sysreg_el1 ( SYS_SPSR ) ;
2017-12-27 21:59:09 +01:00
case KVM_SPSR_ABT :
return read_sysreg ( spsr_abt ) ;
case KVM_SPSR_UND :
return read_sysreg ( spsr_und ) ;
case KVM_SPSR_IRQ :
return read_sysreg ( spsr_irq ) ;
case KVM_SPSR_FIQ :
return read_sysreg ( spsr_fiq ) ;
2013-02-06 19:40:29 +00:00
default :
BUG ( ) ;
}
2017-12-27 21:59:09 +01:00
}
void vcpu_write_spsr32 ( struct kvm_vcpu * vcpu , unsigned long v )
{
int spsr_idx = vcpu_spsr32_mode ( vcpu ) ;
if ( ! vcpu - > arch . sysregs_loaded_on_cpu ) {
vcpu_gp_regs ( vcpu ) - > spsr [ spsr_idx ] = v ;
return ;
}
2013-02-06 19:40:29 +00:00
2017-12-27 21:59:09 +01:00
switch ( spsr_idx ) {
case KVM_SPSR_SVC :
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 11:29:40 +01:00
write_sysreg_el1 ( v , SYS_SPSR ) ;
arm64: KVM: regmap: Fix unexpected switch fall-through
When fall-through warnings was enabled by default, commit d93512ef0f0e
("Makefile: Globally enable fall-through warning"), the following
warnings was starting to show up:
In file included from ../arch/arm64/include/asm/kvm_emulate.h:19,
from ../arch/arm64/kvm/regmap.c:13:
../arch/arm64/kvm/regmap.c: In function ‘vcpu_write_spsr32’:
../arch/arm64/include/asm/kvm_hyp.h:31:3: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile(ALTERNATIVE(__msr_s(r##nvh, "%x0"), \
^~~
../arch/arm64/include/asm/kvm_hyp.h:46:31: note: in expansion of macro ‘write_sysreg_elx’
#define write_sysreg_el1(v,r) write_sysreg_elx(v, r, _EL1, _EL12)
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:180:3: note: in expansion of macro ‘write_sysreg_el1’
write_sysreg_el1(v, SYS_SPSR);
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:181:2: note: here
case KVM_SPSR_ABT:
^~~~
In file included from ../arch/arm64/include/asm/cputype.h:132,
from ../arch/arm64/include/asm/cache.h:8,
from ../include/linux/cache.h:6,
from ../include/linux/printk.h:9,
from ../include/linux/kernel.h:15,
from ../include/asm-generic/bug.h:18,
from ../arch/arm64/include/asm/bug.h:26,
from ../include/linux/bug.h:5,
from ../include/linux/mmdebug.h:5,
from ../include/linux/mm.h:9,
from ../arch/arm64/kvm/regmap.c:11:
../arch/arm64/include/asm/sysreg.h:837:2: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile("msr " __stringify(r) ", %x0" \
^~~
../arch/arm64/kvm/regmap.c:182:3: note: in expansion of macro ‘write_sysreg’
write_sysreg(v, spsr_abt);
^~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:183:2: note: here
case KVM_SPSR_UND:
^~~~
Rework to add a 'break;' in the swich-case since it didn't have that,
leading to an interresting set of bugs.
Cc: stable@vger.kernel.org # v4.17+
Fixes: a892819560c4 ("KVM: arm64: Prepare to handle deferred save/restore of 32-bit registers")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[maz: reworked commit message, fixed stable range]
Signed-off-by: Marc Zyngier <maz@kernel.org>
2019-07-26 13:27:05 +02:00
break ;
2017-12-27 21:59:09 +01:00
case KVM_SPSR_ABT :
write_sysreg ( v , spsr_abt ) ;
arm64: KVM: regmap: Fix unexpected switch fall-through
When fall-through warnings was enabled by default, commit d93512ef0f0e
("Makefile: Globally enable fall-through warning"), the following
warnings was starting to show up:
In file included from ../arch/arm64/include/asm/kvm_emulate.h:19,
from ../arch/arm64/kvm/regmap.c:13:
../arch/arm64/kvm/regmap.c: In function ‘vcpu_write_spsr32’:
../arch/arm64/include/asm/kvm_hyp.h:31:3: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile(ALTERNATIVE(__msr_s(r##nvh, "%x0"), \
^~~
../arch/arm64/include/asm/kvm_hyp.h:46:31: note: in expansion of macro ‘write_sysreg_elx’
#define write_sysreg_el1(v,r) write_sysreg_elx(v, r, _EL1, _EL12)
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:180:3: note: in expansion of macro ‘write_sysreg_el1’
write_sysreg_el1(v, SYS_SPSR);
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:181:2: note: here
case KVM_SPSR_ABT:
^~~~
In file included from ../arch/arm64/include/asm/cputype.h:132,
from ../arch/arm64/include/asm/cache.h:8,
from ../include/linux/cache.h:6,
from ../include/linux/printk.h:9,
from ../include/linux/kernel.h:15,
from ../include/asm-generic/bug.h:18,
from ../arch/arm64/include/asm/bug.h:26,
from ../include/linux/bug.h:5,
from ../include/linux/mmdebug.h:5,
from ../include/linux/mm.h:9,
from ../arch/arm64/kvm/regmap.c:11:
../arch/arm64/include/asm/sysreg.h:837:2: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile("msr " __stringify(r) ", %x0" \
^~~
../arch/arm64/kvm/regmap.c:182:3: note: in expansion of macro ‘write_sysreg’
write_sysreg(v, spsr_abt);
^~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:183:2: note: here
case KVM_SPSR_UND:
^~~~
Rework to add a 'break;' in the swich-case since it didn't have that,
leading to an interresting set of bugs.
Cc: stable@vger.kernel.org # v4.17+
Fixes: a892819560c4 ("KVM: arm64: Prepare to handle deferred save/restore of 32-bit registers")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[maz: reworked commit message, fixed stable range]
Signed-off-by: Marc Zyngier <maz@kernel.org>
2019-07-26 13:27:05 +02:00
break ;
2017-12-27 21:59:09 +01:00
case KVM_SPSR_UND :
write_sysreg ( v , spsr_und ) ;
arm64: KVM: regmap: Fix unexpected switch fall-through
When fall-through warnings was enabled by default, commit d93512ef0f0e
("Makefile: Globally enable fall-through warning"), the following
warnings was starting to show up:
In file included from ../arch/arm64/include/asm/kvm_emulate.h:19,
from ../arch/arm64/kvm/regmap.c:13:
../arch/arm64/kvm/regmap.c: In function ‘vcpu_write_spsr32’:
../arch/arm64/include/asm/kvm_hyp.h:31:3: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile(ALTERNATIVE(__msr_s(r##nvh, "%x0"), \
^~~
../arch/arm64/include/asm/kvm_hyp.h:46:31: note: in expansion of macro ‘write_sysreg_elx’
#define write_sysreg_el1(v,r) write_sysreg_elx(v, r, _EL1, _EL12)
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:180:3: note: in expansion of macro ‘write_sysreg_el1’
write_sysreg_el1(v, SYS_SPSR);
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:181:2: note: here
case KVM_SPSR_ABT:
^~~~
In file included from ../arch/arm64/include/asm/cputype.h:132,
from ../arch/arm64/include/asm/cache.h:8,
from ../include/linux/cache.h:6,
from ../include/linux/printk.h:9,
from ../include/linux/kernel.h:15,
from ../include/asm-generic/bug.h:18,
from ../arch/arm64/include/asm/bug.h:26,
from ../include/linux/bug.h:5,
from ../include/linux/mmdebug.h:5,
from ../include/linux/mm.h:9,
from ../arch/arm64/kvm/regmap.c:11:
../arch/arm64/include/asm/sysreg.h:837:2: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile("msr " __stringify(r) ", %x0" \
^~~
../arch/arm64/kvm/regmap.c:182:3: note: in expansion of macro ‘write_sysreg’
write_sysreg(v, spsr_abt);
^~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:183:2: note: here
case KVM_SPSR_UND:
^~~~
Rework to add a 'break;' in the swich-case since it didn't have that,
leading to an interresting set of bugs.
Cc: stable@vger.kernel.org # v4.17+
Fixes: a892819560c4 ("KVM: arm64: Prepare to handle deferred save/restore of 32-bit registers")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[maz: reworked commit message, fixed stable range]
Signed-off-by: Marc Zyngier <maz@kernel.org>
2019-07-26 13:27:05 +02:00
break ;
2017-12-27 21:59:09 +01:00
case KVM_SPSR_IRQ :
write_sysreg ( v , spsr_irq ) ;
arm64: KVM: regmap: Fix unexpected switch fall-through
When fall-through warnings was enabled by default, commit d93512ef0f0e
("Makefile: Globally enable fall-through warning"), the following
warnings was starting to show up:
In file included from ../arch/arm64/include/asm/kvm_emulate.h:19,
from ../arch/arm64/kvm/regmap.c:13:
../arch/arm64/kvm/regmap.c: In function ‘vcpu_write_spsr32’:
../arch/arm64/include/asm/kvm_hyp.h:31:3: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile(ALTERNATIVE(__msr_s(r##nvh, "%x0"), \
^~~
../arch/arm64/include/asm/kvm_hyp.h:46:31: note: in expansion of macro ‘write_sysreg_elx’
#define write_sysreg_el1(v,r) write_sysreg_elx(v, r, _EL1, _EL12)
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:180:3: note: in expansion of macro ‘write_sysreg_el1’
write_sysreg_el1(v, SYS_SPSR);
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:181:2: note: here
case KVM_SPSR_ABT:
^~~~
In file included from ../arch/arm64/include/asm/cputype.h:132,
from ../arch/arm64/include/asm/cache.h:8,
from ../include/linux/cache.h:6,
from ../include/linux/printk.h:9,
from ../include/linux/kernel.h:15,
from ../include/asm-generic/bug.h:18,
from ../arch/arm64/include/asm/bug.h:26,
from ../include/linux/bug.h:5,
from ../include/linux/mmdebug.h:5,
from ../include/linux/mm.h:9,
from ../arch/arm64/kvm/regmap.c:11:
../arch/arm64/include/asm/sysreg.h:837:2: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile("msr " __stringify(r) ", %x0" \
^~~
../arch/arm64/kvm/regmap.c:182:3: note: in expansion of macro ‘write_sysreg’
write_sysreg(v, spsr_abt);
^~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:183:2: note: here
case KVM_SPSR_UND:
^~~~
Rework to add a 'break;' in the swich-case since it didn't have that,
leading to an interresting set of bugs.
Cc: stable@vger.kernel.org # v4.17+
Fixes: a892819560c4 ("KVM: arm64: Prepare to handle deferred save/restore of 32-bit registers")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[maz: reworked commit message, fixed stable range]
Signed-off-by: Marc Zyngier <maz@kernel.org>
2019-07-26 13:27:05 +02:00
break ;
2017-12-27 21:59:09 +01:00
case KVM_SPSR_FIQ :
write_sysreg ( v , spsr_fiq ) ;
arm64: KVM: regmap: Fix unexpected switch fall-through
When fall-through warnings was enabled by default, commit d93512ef0f0e
("Makefile: Globally enable fall-through warning"), the following
warnings was starting to show up:
In file included from ../arch/arm64/include/asm/kvm_emulate.h:19,
from ../arch/arm64/kvm/regmap.c:13:
../arch/arm64/kvm/regmap.c: In function ‘vcpu_write_spsr32’:
../arch/arm64/include/asm/kvm_hyp.h:31:3: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile(ALTERNATIVE(__msr_s(r##nvh, "%x0"), \
^~~
../arch/arm64/include/asm/kvm_hyp.h:46:31: note: in expansion of macro ‘write_sysreg_elx’
#define write_sysreg_el1(v,r) write_sysreg_elx(v, r, _EL1, _EL12)
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:180:3: note: in expansion of macro ‘write_sysreg_el1’
write_sysreg_el1(v, SYS_SPSR);
^~~~~~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:181:2: note: here
case KVM_SPSR_ABT:
^~~~
In file included from ../arch/arm64/include/asm/cputype.h:132,
from ../arch/arm64/include/asm/cache.h:8,
from ../include/linux/cache.h:6,
from ../include/linux/printk.h:9,
from ../include/linux/kernel.h:15,
from ../include/asm-generic/bug.h:18,
from ../arch/arm64/include/asm/bug.h:26,
from ../include/linux/bug.h:5,
from ../include/linux/mmdebug.h:5,
from ../include/linux/mm.h:9,
from ../arch/arm64/kvm/regmap.c:11:
../arch/arm64/include/asm/sysreg.h:837:2: warning: this statement may fall
through [-Wimplicit-fallthrough=]
asm volatile("msr " __stringify(r) ", %x0" \
^~~
../arch/arm64/kvm/regmap.c:182:3: note: in expansion of macro ‘write_sysreg’
write_sysreg(v, spsr_abt);
^~~~~~~~~~~~
../arch/arm64/kvm/regmap.c:183:2: note: here
case KVM_SPSR_UND:
^~~~
Rework to add a 'break;' in the swich-case since it didn't have that,
leading to an interresting set of bugs.
Cc: stable@vger.kernel.org # v4.17+
Fixes: a892819560c4 ("KVM: arm64: Prepare to handle deferred save/restore of 32-bit registers")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>
[maz: reworked commit message, fixed stable range]
Signed-off-by: Marc Zyngier <maz@kernel.org>
2019-07-26 13:27:05 +02:00
break ;
2017-12-27 21:59:09 +01:00
}
2013-02-06 19:40:29 +00:00
}