On Fri, Dec 05, 2014 at 08:21:06PM +0530, Anand Moon wrote:
> @@ -574,12 +574,14 @@ asmlinkage int
>  do_work_pending(struct pt_regs *regs, unsigned int thread_flags, int syscall)
>  {
>       do {
> +             if (unlikely(!user_mode(regs)))
> +                     return 0;
> +             /* Enable interrupts; they are disabled again on return to
> +              * caller. */
> +             local_irq_enable();
>               if (likely(thread_flags & _TIF_NEED_RESCHED)) {
>                       schedule();
>               } else {
> -                     if (unlikely(!user_mode(regs)))
> -                             return 0;
> -                     local_irq_enable();
>                       if (thread_flags & _TIF_SIGPENDING) {
>                               int restart = do_signal(regs, syscall);
>                               if (unlikely(restart)) {

I'm happy with the hunk above, but:

> @@ -588,6 +590,7 @@ do_work_pending(struct pt_regs *regs, unsigned int 
> thread_flags, int syscall)
>                                        * Deal with it without leaving
>                                        * the kernel space.
>                                        */
> +                                     local_irq_disable();
>                                       return restart;

not this one.  The code expects in the non-zero return case, that
interrupts will be enabled, otherwise we will be restarting the syscall
with IRQs disabled, and calling into the syscall function with IRQs
disabled.

-- 
FTTC broadband for 0.8mile line: currently at 9.5Mbps down 400kbps up
according to speedtest.net.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to