aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/mips/include/asm/fpu.h8
-rw-r--r--arch/mips/kernel/signal.c46
-rw-r--r--arch/mips/kernel/signal32.c24
-rw-r--r--arch/mips/kernel/traps.c76
4 files changed, 70 insertions, 84 deletions
diff --git a/arch/mips/include/asm/fpu.h b/arch/mips/include/asm/fpu.h
index 8a3ef247659a..7fcef8ef3fab 100644
--- a/arch/mips/include/asm/fpu.h
+++ b/arch/mips/include/asm/fpu.h
@@ -28,15 +28,7 @@
28struct sigcontext; 28struct sigcontext;
29struct sigcontext32; 29struct sigcontext32;
30 30
31extern asmlinkage int (*save_fp_context)(struct sigcontext __user *sc);
32extern asmlinkage int (*restore_fp_context)(struct sigcontext __user *sc);
33
34extern asmlinkage int (*save_fp_context32)(struct sigcontext32 __user *sc);
35extern asmlinkage int (*restore_fp_context32)(struct sigcontext32 __user *sc);
36
37extern void fpu_emulator_init_fpu(void); 31extern void fpu_emulator_init_fpu(void);
38extern int fpu_emulator_save_context(struct sigcontext __user *sc);
39extern int fpu_emulator_restore_context(struct sigcontext __user *sc);
40extern void _init_fpu(void); 32extern void _init_fpu(void);
41extern void _save_fp(struct task_struct *); 33extern void _save_fp(struct task_struct *);
42extern void _restore_fp(struct task_struct *); 34extern void _restore_fp(struct task_struct *);
diff --git a/arch/mips/kernel/signal.c b/arch/mips/kernel/signal.c
index 6254041b942f..d0c68b5d717b 100644
--- a/arch/mips/kernel/signal.c
+++ b/arch/mips/kernel/signal.c
@@ -35,6 +35,15 @@
35 35
36#include "signal-common.h" 36#include "signal-common.h"
37 37
38static int (*save_fp_context)(struct sigcontext __user *sc);
39static int (*restore_fp_context)(struct sigcontext __user *sc);
40
41extern asmlinkage int _save_fp_context(struct sigcontext __user *sc);
42extern asmlinkage int _restore_fp_context(struct sigcontext __user *sc);
43
44extern asmlinkage int fpu_emulator_save_context(struct sigcontext __user *sc);
45extern asmlinkage int fpu_emulator_restore_context(struct sigcontext __user *sc);
46
38/* 47/*
39 * Horribly complicated - with the bloody RM9000 workarounds enabled 48 * Horribly complicated - with the bloody RM9000 workarounds enabled
40 * the signal trampolines is moving to the end of the structure so we can 49 * the signal trampolines is moving to the end of the structure so we can
@@ -709,3 +718,40 @@ asmlinkage void do_notify_resume(struct pt_regs *regs, void *unused,
709 key_replace_session_keyring(); 718 key_replace_session_keyring();
710 } 719 }
711} 720}
721
722#ifdef CONFIG_SMP
723static int smp_save_fp_context(struct sigcontext __user *sc)
724{
725 return raw_cpu_has_fpu
726 ? _save_fp_context(sc)
727 : fpu_emulator_save_context(sc);
728}
729
730static int smp_restore_fp_context(struct sigcontext __user *sc)
731{
732 return raw_cpu_has_fpu
733 ? _restore_fp_context(sc)
734 : fpu_emulator_restore_context(sc);
735}
736#endif
737
738static int signal_setup(void)
739{
740#ifdef CONFIG_SMP
741 /* For now just do the cpu_has_fpu check when the functions are invoked */
742 save_fp_context = smp_save_fp_context;
743 restore_fp_context = smp_restore_fp_context;
744#else
745 if (cpu_has_fpu) {
746 save_fp_context = _save_fp_context;
747 restore_fp_context = _restore_fp_context;
748 } else {
749 save_fp_context = fpu_emulator_save_context;
750 restore_fp_context = fpu_emulator_restore_context;
751 }
752#endif
753
754 return 0;
755}
756
757arch_initcall(signal_setup);
diff --git a/arch/mips/kernel/signal32.c b/arch/mips/kernel/signal32.c
index 2e74075ac0ca..03abaf048f09 100644
--- a/arch/mips/kernel/signal32.c
+++ b/arch/mips/kernel/signal32.c
@@ -35,6 +35,15 @@
35 35
36#include "signal-common.h" 36#include "signal-common.h"
37 37
38static int (*save_fp_context32)(struct sigcontext32 __user *sc);
39static int (*restore_fp_context32)(struct sigcontext32 __user *sc);
40
41extern asmlinkage int _save_fp_context32(struct sigcontext32 __user *sc);
42extern asmlinkage int _restore_fp_context32(struct sigcontext32 __user *sc);
43
44extern asmlinkage int fpu_emulator_save_context32(struct sigcontext32 __user *sc);
45extern asmlinkage int fpu_emulator_restore_context32(struct sigcontext32 __user *sc);
46
38/* 47/*
39 * Including <asm/unistd.h> would give use the 64-bit syscall numbers ... 48 * Including <asm/unistd.h> would give use the 64-bit syscall numbers ...
40 */ 49 */
@@ -828,3 +837,18 @@ SYSCALL_DEFINE5(32_waitid, int, which, compat_pid_t, pid,
828 info.si_code |= __SI_CHLD; 837 info.si_code |= __SI_CHLD;
829 return copy_siginfo_to_user32(uinfo, &info); 838 return copy_siginfo_to_user32(uinfo, &info);
830} 839}
840
841static int signal32_init(void)
842{
843 if (cpu_has_fpu) {
844 save_fp_context32 = _save_fp_context32;
845 restore_fp_context32 = _restore_fp_context32;
846 } else {
847 save_fp_context32 = fpu_emulator_save_context32;
848 restore_fp_context32 = fpu_emulator_restore_context32;
849 }
850
851 return 0;
852}
853
854arch_initcall(signal32_init);
diff --git a/arch/mips/kernel/traps.c b/arch/mips/kernel/traps.c
index 9fe21fb65305..308e43460864 100644
--- a/arch/mips/kernel/traps.c
+++ b/arch/mips/kernel/traps.c
@@ -1395,77 +1395,6 @@ void *set_vi_handler(int n, vi_handler_t addr)
1395 return set_vi_srs_handler(n, addr, 0); 1395 return set_vi_srs_handler(n, addr, 0);
1396} 1396}
1397 1397
1398/*
1399 * This is used by native signal handling
1400 */
1401asmlinkage int (*save_fp_context)(struct sigcontext __user *sc);
1402asmlinkage int (*restore_fp_context)(struct sigcontext __user *sc);
1403
1404extern asmlinkage int _save_fp_context(struct sigcontext __user *sc);
1405extern asmlinkage int _restore_fp_context(struct sigcontext __user *sc);
1406
1407extern asmlinkage int fpu_emulator_save_context(struct sigcontext __user *sc);
1408extern asmlinkage int fpu_emulator_restore_context(struct sigcontext __user *sc);
1409
1410#ifdef CONFIG_SMP
1411static int smp_save_fp_context(struct sigcontext __user *sc)
1412{
1413 return raw_cpu_has_fpu
1414 ? _save_fp_context(sc)
1415 : fpu_emulator_save_context(sc);
1416}
1417
1418static int smp_restore_fp_context(struct sigcontext __user *sc)
1419{
1420 return raw_cpu_has_fpu
1421 ? _restore_fp_context(sc)
1422 : fpu_emulator_restore_context(sc);
1423}
1424#endif
1425
1426static inline void signal_init(void)
1427{
1428#ifdef CONFIG_SMP
1429 /* For now just do the cpu_has_fpu check when the functions are invoked */
1430 save_fp_context = smp_save_fp_context;
1431 restore_fp_context = smp_restore_fp_context;
1432#else
1433 if (cpu_has_fpu) {
1434 save_fp_context = _save_fp_context;
1435 restore_fp_context = _restore_fp_context;
1436 } else {
1437 save_fp_context = fpu_emulator_save_context;
1438 restore_fp_context = fpu_emulator_restore_context;
1439 }
1440#endif
1441}
1442
1443#ifdef CONFIG_MIPS32_COMPAT
1444
1445/*
1446 * This is used by 32-bit signal stuff on the 64-bit kernel
1447 */
1448asmlinkage int (*save_fp_context32)(struct sigcontext32 __user *sc);
1449asmlinkage int (*restore_fp_context32)(struct sigcontext32 __user *sc);
1450
1451extern asmlinkage int _save_fp_context32(struct sigcontext32 __user *sc);
1452extern asmlinkage int _restore_fp_context32(struct sigcontext32 __user *sc);
1453
1454extern asmlinkage int fpu_emulator_save_context32(struct sigcontext32 __user *sc);
1455extern asmlinkage int fpu_emulator_restore_context32(struct sigcontext32 __user *sc);
1456
1457static inline void signal32_init(void)
1458{
1459 if (cpu_has_fpu) {
1460 save_fp_context32 = _save_fp_context32;
1461 restore_fp_context32 = _restore_fp_context32;
1462 } else {
1463 save_fp_context32 = fpu_emulator_save_context32;
1464 restore_fp_context32 = fpu_emulator_restore_context32;
1465 }
1466}
1467#endif
1468
1469extern void cpu_cache_init(void); 1398extern void cpu_cache_init(void);
1470extern void tlb_init(void); 1399extern void tlb_init(void);
1471extern void flush_tlb_handlers(void); 1400extern void flush_tlb_handlers(void);
@@ -1779,11 +1708,6 @@ void __init trap_init(void)
1779 else 1708 else
1780 memcpy((void *)(ebase + 0x080), &except_vec3_generic, 0x80); 1709 memcpy((void *)(ebase + 0x080), &except_vec3_generic, 0x80);
1781 1710
1782 signal_init();
1783#ifdef CONFIG_MIPS32_COMPAT
1784 signal32_init();
1785#endif
1786
1787 local_flush_icache_range(ebase, ebase + 0x400); 1711 local_flush_icache_range(ebase, ebase + 0x400);
1788 flush_tlb_handlers(); 1712 flush_tlb_handlers();
1789 1713