[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150507115341.GA32271@lerouge>
Date: Thu, 7 May 2015 13:53:43 +0200
From: Frederic Weisbecker <fweisbec@...il.com>
To: Ingo Molnar <mingo@...nel.org>
Cc: LKML <linux-kernel@...r.kernel.org>,
"Rafael J . Wysocki" <rafael.j.wysocki@...el.com>,
Peter Zijlstra <peterz@...radead.org>,
Mike Galbraith <umgwanakikbuti@...il.com>,
Chris Metcalf <cmetcalf@...hip.com>,
Dave Jones <davej@...hat.com>,
Thomas Gleixner <tglx@...utronix.de>,
Oleg Nesterov <oleg@...hat.com>,
"Paul E . McKenney" <paulmck@...ux.vnet.ibm.com>,
Ingo Molnar <mingo@...hat.com>, Rik van Riel <riel@...hat.com>,
Martin Schwidefsky <schwidefsky@...ibm.com>
Subject: Re: [PATCH 1/4] context_tracking: Protect against recursion
On Thu, May 07, 2015 at 11:58:32AM +0200, Ingo Molnar wrote:
>
> * Frederic Weisbecker <fweisbec@...il.com> wrote:
>
> > @@ -75,6 +94,11 @@ void context_tracking_enter(enum ctx_state state)
> > WARN_ON_ONCE(!current->mm);
> >
> > local_irq_save(flags);
> > + if (!context_tracking_recursion_enter()) {
> > + local_irq_restore(flags);
> > + return;
> > + }
> > +
> > if ( __this_cpu_read(context_tracking.state) != state) {
> > if (__this_cpu_read(context_tracking.active)) {
> > /*
> > @@ -105,6 +129,7 @@ void context_tracking_enter(enum ctx_state state)
> > */
> > __this_cpu_write(context_tracking.state, state);
> > }
> > + context_tracking_recursion_exit();
>
> > local_irq_restore(flags);
> > }
>
> So why not add an 'out_irq_restore:' label and use goto instead of
> duplicating the return path in the recursion check?
Ah yeah. Sometimes people prefer that we just repeat the rollback code if
it's only one line. But I'm fine with the label as well.
>
> > NOKPROBE_SYMBOL(context_tracking_enter);
> > @@ -139,6 +164,10 @@ void context_tracking_exit(enum ctx_state state)
> > return;
> >
> > local_irq_save(flags);
> > + if (!context_tracking_recursion_enter()) {
> > + local_irq_restore(flags);
> > + return;
>
> Ditto.
>
> No need to resend, I fixed this up in the patch.
>
> Thanks,
>
> Ingo
Ah thanks a lot Ingo!
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists