首页 > 其他分享 >学习笔记8

学习笔记8

时间:2023-11-03 12:02:00浏览次数:29  
标签:知识点 定时器 struct 笔记 学习 tms time CPU

第五章 定时器及时钟服务

硬件定时器

定时器是由时钟源和可编程计数器组成的硬件设备。
时钟源通常是一个晶体振荡器,会产生周期性电信号,以精确的频率驱动计数器。使用一个倒计时值对计数器进行编程,每个时钟信号减1。当计数减为0时,计数器向CPU生成一个定时器中断,将计数值重新加载到计数器中,并重复倒计时。
计数器周期称为定时器刻度,是系统的基本计时单元。

个人计算机定时器

实时时钟(RTC)

RTC由一个小型备用电池供电。即使在个人计算机关机时,它也能连续运行。它用于实时提供时间和日期信息。当Linux启动时,它使用RTC更新系统时间变量,以与当前时间保持一致。在所有类Unix系统中,时间变量是一个长整数,包含 从1970年1月1日起经过的秒数。

可编程间隔定时器(PIT)

PIT是与CPU分离的一个硬件定时器。可对它进行编程,以提供以毫秒为单位的定时器刻度。在所有I/O设备中,PIT可以最高优先 级IRQ0中断。PIT定时器中断由Linux内核的定时器中断处理程序来处理,为系统操作提 供基本的定时单元,例如进程调度、进程间隔定时器和其他许多定时事件。

多核CPU中的本地定时器

在多核CPU中,每个核都是一个独立的处理器,它有自己的本地定时器,由CPU时钟驱动。

高分辨率定时器

大多数电脑都有一个时间戳定时器(TSC),由系统时钟驱动。它的内容可通过64位TSC寄存器读取。由于不同系统主板的时钟频率可能不同,TSC不适合作为实时设备,但它提供纳秒级的定时器分辨率。

CPU操作

每个CPU都有一个程序计数器(PC),也称为指令指针(IP),以及一个标志或状态寄存器(SR)、一个堆栈指针(SP)和几个通用寄存器,当PC指向内存中要执行的下一条指令时,SR包含CPU的当前状态,如操作模式、中断掩码和条件码,SP指向当前堆栈栈顶。
CPU操作可通过无限循环进行建模。

time系统调用

clock_t times(struct tms *buf);可用于获取某进程的具体执行时间。它将进程时间存储在struct tms buf中:
struct tms{
    clock_t tms_utime;	// user mode time
    clock_t	tms_stime;	// system mode time
    clock_t	tms_cutime;	// user time of children
    clock_t	tms_cstime;	// system time of children
};

time和date命令
date:打印或设置系统日期和时间。
time:报告进程在用户模式和系统模式下的执行时间和总时间。
hwclock:查询并设置硬件时钟(RTC),也可以通过BIOS来完成。

间隔定时器

间隔定时器的值用以下结构体(在<sys/time.h>中)定义:

struct itimerval {
    struct timeval it_inteirval; 
    struct timeval it_value; 
};
struct timeval (
    time_t tv_sec;
    suseconds_t tv_usec;	
);

sigaction使用示例:

#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <signal.h>
//#include <siginfo.h>

void handler(int sig, siginfo_t *siginfo, void *context)
{
    printf("handler: sig=%d from PID=%d UID=%d\n",sig, siginfo->si_pid, siginfo->si_uid);
}
int main(int argc, char *argv[])
{
    struct sigaction act;
    memset(&act, 0, sizeof(act));
    act.sa_sigaction = &handler;
    act.sa_flags = SA_SIGINFO; 
    sigaction(SIGTERM, &act, NULL);
    printf("proc PID=%d looping\n", getpid()); 
    printf ("enter kill PID to send SIGTERM signal to it\n"); 
    while(1)
    {
        sleep (10);
    }
}

运行结果截图:

苏格拉底挑战

  1. 知识点1:CPU操作

    我在学习CPU操作知识点,请你以苏格拉底的方式对我进行提问,一次一个问题。

 - 针对我CPU操作知识点,我理解了吗?

 - 我的回答结束了,请对我的回答进行评价总结。

  1. 知识点2:硬件定时器

    • 我在学习使用硬件定时器函数知识点,请你以苏格拉底的方式对我进行提问,一次一个问题。

  • 针对我硬件定时器知识点,我理解了吗?

  • 我的回答结束了,请对我的回答进行评价总结。

问题与解决思路

在学习过程中,我遇到了以下问题,并使用chatgpt等AI工具解决:

  1. 问题1:高分辨率定时器是怎么工作的

标签:知识点,定时器,struct,笔记,学习,tms,time,CPU
From: https://www.cnblogs.com/zqr031029/p/17807311.html

相关文章

  • 机器学习——自定义层
    深度学习成功背后的一个因素是神经网络的灵活性:我们可以用创造性的方式组合不同的层,从而设计出适用于各种任务的架构。例如,研究人员发明了专门用于处理图像、文本、序列数据和执行动态规划的层。有时我们会遇到或要自己发明一个现在在深度学习框架中还不存在的层。在这些情况......
  • 慕课笔记-项目开发要点(1)
     马克思曾说,实践是检验认识的真理性的唯一标准,认识来源于实践,正确的认识指导实践才能获得成功。否则终将是纸上谈兵,镜花水月。 初衷在学习了html、css和js的相关内容后,为了巩固自己的知识而进行的一系列项目实战训练,记录自己在开发中遇到的值得记录的知识点,希望自己能够在其......
  • java基础学习:path,java_home环境变量配置
    1.path变量: 装jdk后会自动配置java和javac的path路径 2.JAVA_HOME环境变量:   ......
  • Django实战项目-学习任务系统-发送邮件通知
    接着上期代码内容,继续完善优化系统功能。 本次增加发送邮件通知功能,学习任务系统发布的任务,需要及时通知到学生用户知晓。由于目前智能手机普及,人人都离不开手机,所以手机端接收通知信息更加及时有效。 其中微信使用频率最多,本来想使用微信通知功能,但是经过网上搜集资料测试......
  • java笔记_15_动态生成Excel文件
    //创建表头数据//内层List按纵向创建,外层List按横向添加,横向重复的名称会自动合并表格。List<List<String>>list=newArrayList<>();List<String>childList1=newArrayList<>();childList1.add("aaa");childList1.add("bbb");childList1.add......
  • Selenium 4.0beta:读源码学习新功能
    Selenium4源码分析这一篇文章我们来分析Selenium4python版源码。除非你对Selenium3的源码烂熟于心,否则通过对比工具分析更容易看出Selenium4更新了哪些API。文件对比工具推荐BeyondCompare驱动支持Selenium4去掉了android、blackberry和phantomjs等驱动支持。Selenium......
  • android侧滑应用学习记录
    android侧滑菜单怎么禁止滑动1、点击图标,看看是哪个软件的快捷组件。打开软件的设置,取消桌面或其它界面显示就OK。另外,也可以通过权限设置,禁止软件显示通知等等,禁止这一类的组件和任务栏显示。2、打开“设置”面板;找到“个人”类里的“安全”选项。点击进入;找到选项“屏幕锁定”选......
  • 0为什么你应该学习Go语言
    终于等到你!Go语言——让你用写Python代码的开发效率编写C语言代码。为什么互联网世界需要Go语言世界上已经有太多太多的编程语言了,为什么又出来一个Go语言?硬件限制:摩尔定律已然失效摩尔定律:当价格不变时,集成电路上可容纳的元器件的数目,约每隔18-24个月便会增加一倍,性能也将提......
  • 《代码大全》阅读笔记
    在for循环里面,循环的标志位不要再循环体内修改。且跳出循环体后,不要用循环的标志位。循环体的边界应当使用整数或枚举类型循环长度与多层嵌套会增加理解复杂度。return的目的增强子程序的可读性。递归并不常用,如果使用,必须慎重。递归的使用需考虑递归能够正常停止,系统的堆栈......
  • 数据结构笔记
    数据结构刷题笔记Points线段树显然先对\(x\)离散用线段树维护区间最大值,查询在线段树上二分出最小的\(x\)用set维护每个\(x\)对应的\(y\),lower_bound即可......