LinuxDev 板


LINE

※ [本文转录自 uefang 信箱] 作者: [email protected] ("云飞-Smith") 标题: [Linu] Linux Kernel: 简介HZ, tick and jiffies 时间: Sun Aug 16 14:14:48 2009 作者: uefang (云飞-Smith) 站内: Uefacool 标题: [Linu] Linux Kernel: 简介HZ, tick and jiffies 时间: 2009/08/16 Sun 14:04:49 Take by http://adrianhuang.blogspot.com/2007/10/linux-kernel-hz-tick-and-jiffies.html Linux核心几个重要跟时间有关的名词或变数,底下将介绍HZ、tick与jiffies。 HZ Linux核心每隔固定周期会发出timer interrupt (IRQ 0),HZ是用来定义每一秒有几次 timer interrupts。举例来说,HZ为1000,代表每秒有1000次timer interrupts。 HZ可在编译核心时设定,如下所示 (以核心版本2.6.20-15为例): adrian@adrian-desktop:~$ cd /usr/src/linux adrian@adrian-desktop:/usr/src/linux$ make menuconfig Processor type and features ---> Timer frequency (250 HZ) ---> 其中HZ可设定100、250、300或1000。以小弟的核心版本预设值为250。 小实验 观察/proc/interrupt的timer中断次数,并於一秒後再次观察其值。理论上,两者应该相 差250左右。 adrian@adrian-desktop:~$ cat /proc/interrupts | grep timer && sleep 1 && cat /proc/interrupts | grep timer 0: 9309306 IO-APIC-edge timer 0: 9309562 IO-APIC-edge timer 上面四个栏位分别为中断号码、CPU中断次数、PIC与装置名称。 问题来了,timer interrupt会做哪些事情? 答案如下所列: 1.更新时间、日期与系统从开机至目前经过多少时间 。 2.更新系统资源使用率统计 3.检查正在执行的程序是否已经超过其所分配的执行时间额度。如果是的话,则侵占 (preempt)该程序以利执行其它等待执行的程序。 4.检查软体时间器(Software timer,如alarm系统呼叫)跟时间延迟函式 (Delay function)的延迟时间是否已经超过。 Tick Tick是HZ的倒数,意即timer interrupt每发生一次中断的时间。如HZ为250时,tick为 4毫秒 (millisecond)。 Jiffies Jiffies为Linux核心变数(32位元变数,unsigned long),它被用来纪录系统自开几以来 ,已经过多少的tick。每发生一次timer interrupt,Jiffies变数会被加一。值得注意的 是,Jiffies於系统开机时,并非初始化成零,而是被设为-300*HZ (arch/i386/kernel/ time.c),即代表系统於开机五分钟後,jiffies便会溢位。那溢位怎麽办? 事实上,Linux核心定义几个macro(timer_after、time_after_eq、time_before与 time_before_eq),即便是溢位,也能藉由这几个macro正确地取得jiffies的内容。 另外,80x86架构定义一个与jiffies相关的变数jiffies_64 ,此变数64位元,要等到此 变数溢位可能要好几百万年。因此要等到溢位这刻发生应该很难吧。那如何经由jiffies _64取得jiffies资讯呢? 事实上,jiffies被对应至jiffies_64最低的32位元。因此,经 由jiffies_64可以完全不理会溢位的问题便能取得jiffies。 -- □ 本文章由 uefang123-110-129-226.best.dynamic.lsc.net.tw 发表 --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 123.110.129.226
1F:推 kaioukilu:实用推 08/16 16:57
2F:推 ashin0212:有看有推 08/19 08:09
3F:推 AdrianHuang:呵呵~~没想到小弟的文章在这里出现~~ 01/15 13:51







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:e-shopping站内搜寻

TOP