测定Linux内核100ms的时钟滴答数

原创 2007年09月20日 10:51:00
     在《Linux设备驱动程序》(第3版)中使用了以下代码实现了一种简单的、对精度要求不高的延时:
    while ( time_before( jiffies, j1 ) )
        cpu_relax();
    该程序主要利用Linux系统使用jiffies计数器记录时钟滴答数,给j1赋值将要延迟终止的jiffies值,若当前jiffies值到达j1时,则程序将退出循环,继续执行后续代码。但j1值设定为多少呢?书中未介绍。延迟一般习惯以时间为单位,如休眠多少秒或毫秒。而对不同的linux系统和不同的计算机硬件,时钟滴答的时间间隔是不一样的。本文编写了一个驱动,用于测定100ms的时钟滴答数。若测定出该值,要延迟多少时间,就很方便转换的需要延迟的时钟滴答数了。

// sumjiffies.c
#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h> // printk()
#include <linux/sched.h>  // jiffies, HZ
#include <linux/delay.h>  // mdelay()

#define REPEAT_TIMES 10

static int __init sumjiffies_init(void)
{
    unsigned long start_jiffies, stop_jiffies, sum_jiffies;
    int i;
    printk( KERN_ALERT "sumjiffies load .../n" );
    sum_jiffies = 0;
    for ( i=0; i<REPEAT_TIMES; i++ )
    {
        start_jiffies = jiffies;
        mdelay(100);
        stop_jiffies = jiffies;
        sum_jiffies += (long)stop_jiffies - (long)start_jiffies;
        printk( KERN_ALERT "[%d] stop_jiffies - start_jiffies = %ld - %ld = %ld/n",
                            i, stop_jiffies, start_jiffies, (long)stop_jiffies - (long)start_jiffies );
    }
    printk( KERN_ALERT "average jiffies of 100ms: %ld/n", sum_jiffies / REPEAT_TIMES );
    return 0;
}

static void __exit sumjiffies_exit(void)
{
    printk( KERN_ALERT "Goodbye/n" );
}

module_init( sumjiffies_init );
module_exit( sumjiffies_exit );

MODULE_LICENSE("Dual BSD/GPL");
MODULE_AUTHOR("ThinkerABC");

以下是对上述程序sumjiffies.c在linux kernel 2.4环境下编译和运行结果。

[root@a ~]# gcc -O2 -Wall -DMODULE -D__KERNEL__ -I /usr/src/linux/include/ -c sumjiffies.c
[root@a ~]# insmod sumjiffies.o
[root@a ~]# lsmod sumjiffies
Module                  Size  Used by    Not tainted
sumjiffies               576   0  (unused)
[root@a ~]# rmmod sumjiffies
[root@a ~]# dmesg
sumjiffies load ...
[0] stop_jiffies - start_jiffies = 69624 - 69573 = 51
[1] stop_jiffies - start_jiffies = 69674 - 69624 = 50
[2] stop_jiffies - start_jiffies = 69725 - 69674 = 51
[3] stop_jiffies - start_jiffies = 69776 - 69725 = 51
[4] stop_jiffies - start_jiffies = 69827 - 69776 = 51
[5] stop_jiffies - start_jiffies = 69878 - 69827 = 51
[6] stop_jiffies - start_jiffies = 69928 - 69878 = 50
[7] stop_jiffies - start_jiffies = 69979 - 69928 = 51
[8] stop_jiffies - start_jiffies = 70030 - 69979 = 51
[9] stop_jiffies - start_jiffies = 70081 - 70030 = 51
average jiffies of 100ms: 50
Goodbye
[root@a ~]#

从以上运行结果中可知在我的实验机中,100ms的平均时钟滴答数为50。

如果要使我的实验机上运行的Linux模块中延迟约1秒,这只需使用以下代码即可:
    j1 = jiffies + 500;
    while ( time_before( jiffies, j1 ) )
        cpu_relax();

利用系统滴答时间计算实际程序运行时间

1、前言 测试一个程序的执行时间,时间包括用户CPU时间、系统CPU时间、时钟时间。之前获取之前时间都是在程序的main函数用time函数实现,这个只能粗略的计算程序的执行时间,不能准确的获取其他时...

时钟滴答定时器(sysclk)用法详解

目录: 概述:本篇博客针对sysclk内核定时器(时钟滴答定时器)的常见用法进行总结,分别实现sysclk的定时、延时、计时功能,全部为代码,寄存器描述需参考《Cortex-M3 权威指南》。 平台:...

Linux/Centos下多种方法查看系统block size大小

http://blog.onovps.com/archives/view-block-size.html   1.用tune2fs查看block size大小: 1 2 ...

MBR及linux下grub执行原理浅析

前几天,手痒痒把系统搞坏了,但正如那句话说的:塞翁失马,怎知不是福?查找了很多资料,学习到了很多新知识,发现大牛们要么不出手,出手的文章必定深入浅出,风趣幽默,还穿插了很多从技术中悟出的人生哲理,让人...

linux内核时钟与定时器的实现

一、概述 在计算机系统,CPU是以一个节拍一个节拍运行的(cpu cycle),这就是CPU的频率(HZ)。类似的,操作系统需要提供超时功能,显示时间(如PC机右下角的时钟),统计(CPU占有率计算...
  • imtgj
  • imtgj
  • 2012年04月21日 23:39
  • 4166

Linux内核的时钟中断机制

good,转载一下。   Linux内核的时钟中断机制 第七章 Linux内核的时钟中断 (By 詹荣开,NUDT) opyright © 2003 by 詹荣开 E-ma...
  • zjc156m
  • zjc156m
  • 2013年06月26日 15:34
  • 2179

Linux内核时钟系统和定时器实现

1. Linux内核时钟系统和定时器实现Linux 2.6.16之前,内核只支持低精度时钟,内核定时器的工作方式: 系统启动后,会读取时钟源设备(RTC, HPET,PIT…),初始化当前系统时间; ...

Linux内核开发之中断与时钟[转]

资料地址:http://www.cnblogs.com/hanyan225/archive/2010/10/25/1860087.html   定时器分为硬件和软件定时器,软件定时器最终还是要依...

clk_get函数实现,Linux内核时钟框架

(1)  对应外设时钟的开启 struct clk=clk_get(NULL,"adc"); clk.enable(); 之后adc对应的时钟位就能时能。 struct c...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:测定Linux内核100ms的时钟滴答数
举报原因:
原因补充:

(最多只允许输入30个字)