cvs commit: src/sys/netinet in_var.h ip_fastfwd.c ip_flow.c
 ip_flow.h ip_input.c ip_output.c src/sys/sys mbuf.h src/sys/conf files
 src/sys/net if_arcsubr.c if_ef.c if_ethersubr.c if_fddisubr.c if_
    Jeff Roberson 
    jroberson at chesapeake.net
       
    Sun Nov 16 11:52:03 PST 2003
    
    
  
On Sun, 16 Nov 2003, Luigi Rizzo wrote:
> On Sun, Nov 16, 2003 at 07:19:53AM -0500, Jeff Roberson wrote:
> ...
> > > might result in the second timing call being executed before
> > > the section of code in the middle is complete. There is
> > > some nonintuitive instruction (which i now forget) to flush the
> > > execution pipeline which can be used around the section of
> > > code you want to time.
> >
> > Reading the tsc is also a serializing instruction.  I often use it to
> > accurately measure things that take as few as 20 cycles
>
> no, according to the intel documentation it is not, and i
> myself have seen bogus results which clearly indicate that it
> is not. There was a thread on the freebsd mailing lists a few
> months ago.
>
I double checked, you're right.  It probably works out for me because
clobbering two registers is enough of a hazard to prevent too much
serialization.
Cheers,
Jeff
> 	cheers
> 	luigi
>
    
    
More information about the cvs-src
mailing list