[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.2.00.0903272307490.3397@localhost.localdomain>
Date: Fri, 27 Mar 2009 23:12:41 +0100 (CET)
From: Thomas Gleixner <tglx@...utronix.de>
To: Mathieu Desnoyers <mathieu.desnoyers@...ymtl.ca>
cc: akpm@...ux-foundation.org, Ingo Molnar <mingo@...e.hu>,
linux-kernel@...r.kernel.org, ltt-dev@...ts.casi.polymtl.ca,
Frederic Weisbecker <fweisbec@...il.com>,
Jason Baron <jbaron@...hat.com>,
Peter Zijlstra <peterz@...radead.org>,
Russell King <rmk+lkml@....linux.org.uk>,
Masami Hiramatsu <mhiramat@...hat.com>,
"Frank Ch. Eigler" <fche@...hat.com>,
Hideo AOKI <haoki@...hat.com>,
Takashi Nishiie <t-nishiie@...css.fujitsu.com>,
Steven Rostedt <rostedt@...dmis.org>,
Eduard - Gabriel Munteanu <eduard.munteanu@...ux360.ro>
Subject: Re: [patch 2/9] LTTng instrumentation - irq
On Tue, 24 Mar 2009, Mathieu Desnoyers wrote:
> * lockdep: we want to handle all irq_desc locks as a single lock-class:
> */
> struct lock_class_key irq_desc_lock_class;
> @@ -316,6 +324,19 @@ irqreturn_t no_action(int cpl, void *dev
> return IRQ_NONE;
> }
>
> +static irqreturn_t __handle_irq_next_handler(unsigned int irq,
> + struct irqaction **action, irqreturn_t *retval, unsigned int *status)
> +{
> + irqreturn_t ret;
> +
> + ret = (*action)->handler(irq, (*action)->dev_id);
> + if (ret == IRQ_HANDLED)
> + *status |= (*action)->flags;
> + *retval |= ret;
> + *action = (*action)->next;
> + return ret;
> +}
> +
> static irqreturn_t _handle_IRQ_event(unsigned int irq, struct irqaction *action)
> {
> irqreturn_t ret, retval = IRQ_NONE;
> @@ -324,13 +345,12 @@ static irqreturn_t _handle_IRQ_event(uns
> if (!(action->flags & IRQF_DISABLED))
> local_irq_enable_in_hardirq();
>
> - do {
> - ret = action->handler(irq, action->dev_id);
> - if (ret == IRQ_HANDLED)
> - status |= action->flags;
> - retval |= ret;
> - action = action->next;
> - } while (action);
> + ret = __handle_irq_next_handler(irq, &action, &retval, &status);
> +
> + while (action) {
> + trace_irq_next_handler(irq, action, ret);
> + ret = __handle_irq_next_handler(irq, &action, &retval, &status);
> + }
This one is the next candidate for the "ugly patch of the week contest".
It does not trace the return value of the first handler and just moves
code around for no good reason. Darn why can' t you simply do:
do {
ret = action->handler(irq, action->dev_id);
+ trace_action_handler(....);
}
and keep the rest of the code unchanged ?
>
> #ifndef CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ
This code is going away. No tracepoint needed here.
Thanks,
tglx
--
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