summaryrefslogtreecommitdiff
path: root/arch/s390/kernel
diff options
context:
space:
mode:
authorHeiko Carstens <hca@linux.ibm.com>2024-02-03 11:45:06 +0100
committerHeiko Carstens <hca@linux.ibm.com>2024-02-16 14:30:15 +0100
commitf4e3de75d0c4ebe9bbbfef19d7845ee70cb017bd (patch)
tree0a2fde7fc7d1943631784242226ce9ba5019705f /arch/s390/kernel
parent88d8136a0896e32fc39f90788eaa5c7bdccc9fb0 (diff)
s390/fpu: provide and use lfpc, sfpc, and stfpc inline assemblies
Instead of open-coding lfpc, sfpc, and stfpc inline assemblies at several locations, provide an fpu_* function for each instruction and use the function instead. Reviewed-by: Claudio Imbrenda <imbrenda@linux.ibm.com> Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
Diffstat (limited to 'arch/s390/kernel')
-rw-r--r--arch/s390/kernel/fpu.c14
-rw-r--r--arch/s390/kernel/process.c2
2 files changed, 6 insertions, 10 deletions
diff --git a/arch/s390/kernel/fpu.c b/arch/s390/kernel/fpu.c
index f25c54caf32b..6bfd4d0f33e1 100644
--- a/arch/s390/kernel/fpu.c
+++ b/arch/s390/kernel/fpu.c
@@ -17,10 +17,8 @@ void __kernel_fpu_begin(struct kernel_fpu *state, u32 flags)
* in use by the previous context.
*/
flags &= state->mask;
- if (flags & KERNEL_FPC) {
- /* Save floating point control */
- asm volatile("stfpc %0" : "=Q" (state->fpc));
- }
+ if (flags & KERNEL_FPC)
+ fpu_stfpc(&state->fpc);
if (!cpu_has_vx()) {
if (flags & KERNEL_VXR_LOW)
save_fp_regs(state->fprs);
@@ -80,10 +78,8 @@ void __kernel_fpu_end(struct kernel_fpu *state, u32 flags)
* current context.
*/
flags &= state->mask;
- if (flags & KERNEL_FPC) {
- /* Restore floating-point controls */
- asm volatile("lfpc %0" : : "Q" (state->fpc));
- }
+ if (flags & KERNEL_FPC)
+ fpu_lfpc(&state->fpc);
if (!cpu_has_vx()) {
if (flags & KERNEL_VXR_LOW)
load_fp_regs(state->fprs);
@@ -176,7 +172,7 @@ void save_fpu_regs(void)
state = &current->thread.fpu;
regs = current->thread.fpu.regs;
- asm volatile("stfpc %0" : "=Q" (state->fpc));
+ fpu_stfpc(&state->fpc);
if (likely(cpu_has_vx())) {
asm volatile("lgr 1,%0\n"
"VSTM 0,15,0,1\n"
diff --git a/arch/s390/kernel/process.c b/arch/s390/kernel/process.c
index e502192da5f7..b0578ea230e7 100644
--- a/arch/s390/kernel/process.c
+++ b/arch/s390/kernel/process.c
@@ -191,7 +191,7 @@ int copy_thread(struct task_struct *p, const struct kernel_clone_args *args)
void execve_tail(void)
{
current->thread.fpu.fpc = 0;
- asm volatile("sfpc %0" : : "d" (0));
+ fpu_sfpc(0);
}
struct task_struct *__switch_to(struct task_struct *prev, struct task_struct *next)