netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* igb: acknowledging time sync interrupts
@ 2013-05-26 10:39 Richard Cochran
  2013-05-28 15:20 ` Vick, Matthew
  0 siblings, 1 reply; 4+ messages in thread
From: Richard Cochran @ 2013-05-26 10:39 UTC (permalink / raw)
  To: Matthew Vick; +Cc: e1000-devel, netdev

Matt,

In igb_main.c you have ISR code like:

	if (icr & E1000_ICR_TS) {
		u32 tsicr = rd32(E1000_TSICR);

		if (tsicr & E1000_TSICR_TXTS) {
			/* acknowledge the interrupt */
			wr32(E1000_TSICR, E1000_TSICR_TXTS);
			/* retrieve hardware timestamp */
			schedule_work(&adapter->ptp_tx_work);
		}
	}

In the datasheet for the 82580 and the i210, for TSICR it says,

   Note: Once ICR.Time_Sync is set, the internal value of this
         register should be cleared by writing 1b to all bits
         or cleared by a read to enable receiving an additional
         ^^^^^^^^^^^^^^^^^^^^
         ICR.Time_Sync interrupt.

and that implies that your write to acknowledge the interrupt is
superfluous, since you already read the TSICR.

Is this an error in the datasheets, or is the code doing extra,
unneeded work?

Thanks,
Richard

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

end of thread, other threads:[~2013-05-29 17:43 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-05-26 10:39 igb: acknowledging time sync interrupts Richard Cochran
2013-05-28 15:20 ` Vick, Matthew
2013-05-28 16:06   ` Richard Cochran
2013-05-29 17:42     ` Vick, Matthew

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).