1、内核的ndelay是由udelay实现的,精度是1us
无法实现纳秒级延时,要想实现有2个方法
2、第一种调用系统的底层延时函数,计算延时的clock
cpu_relax(); 是cpu忙等待
static void __timer_delay(unsigned long cycles) { cycles_t start = get_cycles(); while ((get_cycles() - start) < cycles) cpu_relax(); } static void __timer_const_udelay(unsigned long xloops) { unsigned long long loops = xloops; loops *= arm_delay_ops.ticks_per_jiffy; __timer_delay(loops >> UDELAY_SHIFT); }
3、time和jiffs比较
可以用下面的方法实现忙等待: while(time_before(jiffies, j1)) cpu_relax() 其中,j1是要延迟中止时的jiffies值 cpu_relax()不推荐使用 让出处理器 while(time_before(jiffies, j2)) schedule() 但是如果当前cpu只有一个进程,那么swapper也就是idle进程运行的机会也是0.