aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/kernel/traps.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mips/kernel/traps.c')
-rw-r--r--arch/mips/kernel/traps.c76
1 files changed, 0 insertions, 76 deletions
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