123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- struct task_struct;
- extern asmlinkage struct task_struct *resume(struct task_struct *prev,
- struct task_struct *next, struct thread_info *next_ti);
- extern unsigned int ll_bit;
- extern struct task_struct *ll_task;
- do { \
- struct thread_info *__prev_ti = task_thread_info(prev); \
- \
- if (cpu_has_fpu && \
- test_ti_thread_flag(__prev_ti, TIF_FPUBOUND) && \
- (!(KSTK_STATUS(prev) & ST0_CU1))) { \
- clear_ti_thread_flag(__prev_ti, TIF_FPUBOUND); \
- prev->cpus_allowed = prev->thread.user_cpus_allowed; \
- } \
- next->thread.emulated_fp = 0; \
- } while(0)
- do { if (cpu_has_rw_llb) { \
- write_c0_lladdr(0); \
- } else { \
- if (!__builtin_constant_p(cpu_has_llsc) || !cpu_has_llsc)\
- ll_bit = 0; \
- } \
- } while (0)
- do { \
- unsigned long fcr31 = mask_fcr31_x(next->thread.fpu.fcr31); \
- void __user *pc; \
- \
- if (unlikely(fcr31)) { \
- pc = (void __user *)task_pt_regs(next)->cp0_epc; \
- next->thread.fpu.fcr31 &= ~fcr31; \
- force_fcr31_sig(fcr31, pc, next); \
- } \
- } while (0)
- do { \
- __mips_mt_fpaff_switch_to(prev); \
- lose_fpu_inatomic(1, prev); \
- if (tsk_used_math(next)) \
- __sanitize_fcr31(next); \
- if (cpu_has_dsp) { \
- __save_dsp(prev); \
- __restore_dsp(next); \
- } \
- if (cop2_present) { \
- set_c0_status(ST0_CU2); \
- if ((KSTK_STATUS(prev) & ST0_CU2)) { \
- if (cop2_lazy_restore) \
- KSTK_STATUS(prev) &= ~ST0_CU2; \
- cop2_save(prev); \
- } \
- if (KSTK_STATUS(next) & ST0_CU2 && \
- !cop2_lazy_restore) { \
- cop2_restore(next); \
- } \
- clear_c0_status(ST0_CU2); \
- } \
- __clear_software_ll_bit(); \
- if (cpu_has_userlocal) \
- write_c0_userlocal(task_thread_info(next)->tp_value); \
- __restore_watch(next); \
- (last) = resume(prev, next, task_thread_info(next)); \
- } while (0)
- #endif /* _ASM_SWITCH_TO_H */
|