diff --git a/[refs] b/[refs] index 15d15929ad66..c71e37a4a2c4 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 2ce5da17570771330f44ac993b77749debf7954b +refs/heads/master: 5a1b98d3096f1d780045f9be812335ad77aed93d diff --git a/trunk/include/linux/sched.h b/trunk/include/linux/sched.h index 6fc8f45de4e9..8f983293b403 100644 --- a/trunk/include/linux/sched.h +++ b/trunk/include/linux/sched.h @@ -2305,6 +2305,17 @@ static inline int sas_ss_flags(unsigned long sp) : on_sig_stack(sp) ? SS_ONSTACK : 0); } +static inline unsigned long sigsp(unsigned long sp, struct ksignal *ksig) +{ + if (unlikely((ksig->ka.sa.sa_flags & SA_ONSTACK)) && ! sas_ss_flags(sp)) +#ifdef CONFIG_STACK_GROWSUP + return current->sas_ss_sp; +#else + return current->sas_ss_sp + current->sas_ss_size; +#endif + return sp; +} + /* * Routines for handling mm_structs */