[ltt-dev] [BUG] [PATCH] LTTV - interrupt handler time calculation is wrong in case of nested interrupts
Mathieu Desnoyers
compudj at krystal.dyndns.org
Wed Oct 15 10:09:26 EDT 2008
Integrated in lttv-0.11.2-15102008. Thanks !
Mathieu
* Mathieu Desnoyers (compudj at krystal.dyndns.org) wrote:
> Hi Gaurav,
>
> Your fix seems appropriate, I'll merge it.
>
> Thanks !
>
> Mathieu
>
> * Gaurav Singh (gausinghnsit at gmail.com) wrote:
> > Hi all,
> >
> > I was using the interrupt handler plugin and noticed that sometimes
> > the timer interrupt handler was taking a lot of time. Specifically
> > the max time indicated by the plugin was wrong. This was because the
> > time calculated by the plugin in case of nested interrupts is wrong.
> >
> > Nested interrupt:
> > Interrupt 1 (entry) .... 1
> > Interrupt 2(entry).....2
> > Interrupt 2 (exit) ..... 3
> > Interrupt 3 (exit) ..... 4
> >
> > The plugin did the following calculation:
> > Time for 1st interrupt = timeat (3) - timeat (1)
> > Time for 2nd interrupt = timeat (4) - timeat (2)
> >
> >
> > The following patch corrects this anamoly. Basically it takes the up
> > the most recent interrupt and pairs the irq_exit with it. Please check
> > if this works for you.
> >
> > diff -uprN lttv-0.10.0-pre11-10032008/lttv/modules/gui/interrupts/interrupts.c
> > ../lttv-0.10.0-pre11-10032008/lttv/modules/gui/interrupts/interrupts.c
> > --- lttv-0.10.0-pre11-10032008/lttv/modules/gui/interrupts/interrupts.c
> > 2007-10-16 06:44:40.000000000 +0530
> > +++ ../lttv-0.10.0-pre11-10032008/lttv/modules/gui/interrupts/interrupts.c
> > 2008-09-29 15:13:02.000000000 +0530
> > @@ -583,7 +583,7 @@ static void CalculateData(LttTime time_e
> > LttTime duration;
> > GArray *FirstRequestIrqExit = event_data->FirstRequestIrqExit;
> > GArray *FirstRequestIrqEntry = event_data->FirstRequestIrqEntry;
> > - for(i = 0; i < FirstRequestIrqEntry->len; i++)
> > + for(i = FirstRequestIrqEntry->len-1; i >=0; i--)
> > {
> > element = &g_array_index(FirstRequestIrqEntry,irq_entry,i);
> > if(element->cpu_id == cpu_id)
> >
> >
> >
> > Regards,
> > Gaurav
> >
>
> --
> Mathieu Desnoyers
> OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
--
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
More information about the lttng-dev
mailing list