linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Re: RE: [PATCH] qe_ic: Do a sync when masking interrupts.
@ 2006-10-23 15:30 Michael R. Zucca
  2006-10-23 16:49 ` Segher Boessenkool
  0 siblings, 1 reply; 8+ messages in thread
From: Michael R. Zucca @ 2006-10-23 15:30 UTC (permalink / raw)
  To: Li Yang-r58472, Paul Mackerras, Wood Scott-B07421; +Cc: linuxppc-dev

>From: Li Yang-r58472 <LeoLi@freescale.com>
>
>But an i/o read will be considerably slower than a sync, and it is in
>the critical path of interrupt.  I have tested the patch under
>relatively heavy Ethernet load, and there is no spurious interrupt.
>Maybe it is because the device is an SOC device and MMIO store completes
>faster.  I'm wondering if there is a standard test method to show if the
>faster approach is sufficient or not.

All a sync tells you is that an I/O made it out of the CPU. The problem is, there may be other places a write could get hung up. For instance, sometimes devices sit behind a bridge with a write FIFO. In such a scenario, you can't be sure a write has made it to the device until you do a read to flush the FIFO.

If you're trying to figure out the minimum thing to do (eieio, sync, read-back, etc.) you have to understand what your system is doing between the store and the bits going into the register.

It may be that a sync is enough, but you won't know until you fully understand the system's bus/bridge topolgy between the CPU and the device.

^ permalink raw reply	[flat|nested] 8+ messages in thread
* Re: RE: [PATCH] qe_ic: Do a sync when masking interrupts.
@ 2006-10-23 15:32 Michael R. Zucca
  0 siblings, 0 replies; 8+ messages in thread
From: Michael R. Zucca @ 2006-10-23 15:32 UTC (permalink / raw)
  To: Li Yang-r58472, Paul Mackerras, Wood Scott-B07421; +Cc: linuxppc-dev

>From: Li Yang-r58472 <LeoLi@freescale.com>
>
>But an i/o read will be considerably slower than a sync, and it is in
>the critical path of interrupt.  I have tested the patch under
>relatively heavy Ethernet load, and there is no spurious interrupt.
>Maybe it is because the device is an SOC device and MMIO store completes
>faster.  I'm wondering if there is a standard test method to show if the
>faster approach is sufficient or not.

All a sync tells you is that an I/O made it out of the CPU. The problem is, there may be other places a write could get hung up. For instance, sometimes devices sit behind a bridge with a write FIFO. In such a scenario, you can't be sure a write has made it to the device until you do a read to flush the FIFO.

If you're trying to figure out the minimum thing to do (eieio, sync, read-back, etc.) you have to understand what your system is doing between the store and the bits going into the register.

It may be that a sync is enough, but you won't know until you fully understand the system's bus/bridge topolgy between the CPU and the device.

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2006-10-25  4:47 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-10-23 15:30 RE: [PATCH] qe_ic: Do a sync when masking interrupts Michael R. Zucca
2006-10-23 16:49 ` Segher Boessenkool
2006-10-23 18:27   ` Scott Wood
2006-10-23 18:46     ` Segher Boessenkool
2006-10-24  7:17     ` Li Yang-r58472
2006-10-25  3:51       ` Benjamin Herrenschmidt
2006-10-25  4:47         ` Liu Dave-r63238
  -- strict thread matches above, loose matches on Subject: below --
2006-10-23 15:32 Michael R. Zucca

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).