On Mon, 28 Mar 2005, Chris Friesen wrote:

> Date: Mon, 28 Mar 2005 23:07:14 -0600
> From: Chris Friesen <[EMAIL PROTECTED]>
> To: krishna <[EMAIL PROTECTED]>
> Cc: Linux Kernel <linux-kernel@vger.kernel.org>
> Subject: Re: How to measure time accurately.
> 
> krishna wrote:
> > Hi All,
> > 
> > Can any one tell me how to measure time accurately for a block of C code in
> > device drivers.
> > For example, If I want to measure the time duration of firmware download.
> 
> Most cpus have some way of getting at a counter or decrementer of various
> frequencies.  Usually it requires low-level hardware knowledge and often it
> needs assembly code.
> 
> 
> On ppc you'd use the mftbu/mftbl instructions, as suggested by Lee on x86
> you'd use the rdtsc instruction.
> 

In some cases you can simply count jiffies - depending on how accurate you 
need to time things I'd say that often something like this is adequate :


unsigned long start, time_spent;

start = jiffies;
/* do stuff */
time_spent = jiffies - start;
printk("stuff took %d jiffies (%d seconds)\n", time_spent, time_spent/HZ);


-- 
Jesper Juhl

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to