Commit 0b624956 authored by Chris Dearman's avatar Chris Dearman Committed by Ralf Baechle

[MIPS] FPU hazard handling

Move FPU hazard handling to hazards.h and provide proper support for
MIPSR2 processors
Signed-off-by: default avatarChris Dearman <chris@mips.com>
Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent d725cf38
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
#include <asm/mipsregs.h> #include <asm/mipsregs.h>
#include <asm/cpu.h> #include <asm/cpu.h>
#include <asm/cpu-features.h> #include <asm/cpu-features.h>
#include <asm/hazards.h>
#include <asm/bitops.h> #include <asm/bitops.h>
#include <asm/processor.h> #include <asm/processor.h>
#include <asm/current.h> #include <asm/current.h>
...@@ -38,34 +39,16 @@ extern void _init_fpu(void); ...@@ -38,34 +39,16 @@ extern void _init_fpu(void);
extern void _save_fp(struct task_struct *); extern void _save_fp(struct task_struct *);
extern void _restore_fp(struct task_struct *); extern void _restore_fp(struct task_struct *);
#if defined(CONFIG_CPU_SB1)
#define __enable_fpu_hazard() \
do { \
asm(".set push \n\t" \
".set mips64 \n\t" \
".set noreorder \n\t" \
"ssnop \n\t" \
"bnezl $0, .+4 \n\t" \
"ssnop \n\t" \
".set pop"); \
} while (0)
#else
#define __enable_fpu_hazard() \
do { \
asm("nop;nop;nop;nop"); /* max. hazard */ \
} while (0)
#endif
#define __enable_fpu() \ #define __enable_fpu() \
do { \ do { \
set_c0_status(ST0_CU1); \ set_c0_status(ST0_CU1); \
__enable_fpu_hazard(); \ enable_fpu_hazard(); \
} while (0) } while (0)
#define __disable_fpu() \ #define __disable_fpu() \
do { \ do { \
clear_c0_status(ST0_CU1); \ clear_c0_status(ST0_CU1); \
/* We don't care about the c0 hazard here */ \ disable_fpu_hazard(); \
} while (0) } while (0)
#define enable_fpu() \ #define enable_fpu() \
......
...@@ -178,4 +178,36 @@ ASMMACRO(back_to_back_c0_hazard, ...@@ -178,4 +178,36 @@ ASMMACRO(back_to_back_c0_hazard,
#endif #endif
/* FPU hazards */
#if defined(CONFIG_CPU_SB1)
ASMMACRO(enable_fpu_hazard,
.set push;
.set mips64;
.set noreorder;
_ssnop;
bnezl $0,.+4;
_ssnop
.set pop
)
ASMMACRO(disable_fpu_hazard,
)
#elif defined(CONFIG_CPU_MIPSR2)
ASMMACRO(enable_fpu_hazard,
_ehb
)
ASMMACRO(disable_fpu_hazard,
_ehb
)
#else
ASMMACRO(enable_fpu_hazard,
nop; nop; nop; nop
)
ASMMACRO(disable_fpu_hazard,
_ehb
)
#endif
#endif /* _ASM_HAZARDS_H */ #endif /* _ASM_HAZARDS_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment