Linux内核模块时间同步函数汇总

2024-04-16 08:32

本文主要是介绍Linux内核模块时间同步函数汇总,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在linux内核模块中能用到的函数比用户空间多,但是它的函数往往被用得很少。当然在内核中叶可以调用用户空间的函数只要直接调用系统调用的封装函数就行,如下:

如调用long gettimeofday(struct timeval tv, struct timezone tz);函数可以直接调用封装体:

_syscall1(long,gettimeofday, struct timeval,tv,struct timezone ,tz);

这个是现在内核的系统调用标准形式,syscall后面接的数字表示这个系统调用类型,系统调用将参数个数的多少进行了分类。

 

当然也可以直接使用内核特有的函数,这样效率更高:

获得当前时间函数:

头文件: time.h

属性:系统符号导出函数

从jiffies得到时间

 void do_gettimeofday(struct timeval *tv); 

从xtimer墙上时间得到时间

struct timerspec current_kernel_time(void);

 

延时:

长延迟

头文件:jeffies.h / time.h

while(time_before(jiffies,jiffies+msecs_to_jiffies(delay_time)){

              schedule();

}

纳秒,微妙,毫 秒延迟,必须是短延迟,时间过长会报错

头文件: delay.h

void ndelay(unsigned long nesec);

void udelay(unsigned long usecs);

void mdelay(unsigned long msecs);

void msleep(unsigned int millisecs);

void ssleep(unsigned int seconds);

 

超时:

头文件: wait.h

long wait_event_timerout(wait_queue_head_t q, condition, long timeout);

long wait_event_interruptible_timerout(wait_queue_head_t q, condition, long timeout);

 

定时器

头文件:timer.h

定时器数据结构:

struct timer_list{

         unsigned long expires;             /* 超时时间*/

         void (*fun)(unsigned long);      /*超时做的事情的函数指针*/

         unsigned long data;                 /*函数数据参数*/

};

初始化定时器

void init_timer(struct timer_list *timer);

添加定时器

void add_timer(struct timer_list *timer); 

销毁定时器

int del_timer(struct timer_list *timer);

 

信号量函数:

头文件:semaphore.h

属性:初始化函数是头文件静态,其他函数时系统符号导出

1. 初始化信号量

static inline void sema_init(struct semaphore *sem, int val);

第一个参数信号量,第二个参数信号量初始值。

2. 获得信号量

void down(struct semaphore *sem);

3.释放信号量

void up(struct semaphore *sem);

4.在一定时间限制内获得信号量,返回值返回是得到信号量返回的还是超时返回

int down_timeout(struct semaphore *sem, long jiffies);

5. 非阻塞测试是否有可以得到信号量,返回值表明是否获得了信号量。

int down_trylock(struct semaphore *sem) 

6.可打断的获得信号量,返回值表示是一般返回还是被打断

int down_interruptible(struct semaphore *sem) 

7.获得可打断信号量,针对致命打断如 kill信号,返回如上

int down_killable(struct semaphore *sem) 

 

软中断:

tasklet

1.初始化

头文件:无

属性:系统符号导出

void tasklet_init(struct tasklet_struct *t,void (*func)(unsigned long), unsigned long data);

第一个参数是tasklet结构体指针,第二个参数是执行任务的函数,第三个参数是数据结构体指针。 

2.调度tasklet

头文件:interrupt.h

属性:头文件静态

static inline void tasklet_schedule(struct tasklet_struct *t); 

3.结束tasklet

属性:系统符号导出

extern void tasklet_kill(struct tasklet_struct *t); 

4.高精准定时器tasklet

tasklet_hrtimer_init, tasklet_hrtimer_start,tasklet_hrtimer_cancel

工作队列workqueue

1. 创建并初始化工作队列

INIT_WORK(_work, _func);

头文件:workqueue.h

属性:头文件宏定义

或者create_workqueue,这个好像没有上面那个全面,不是很清楚。

2. 销毁工作队列

头文件:workqueue.h

void destroy_workqueue(struct workqueue_struct *wq) 

3. 重置工作队列 

头文件:workqueue.h

int cancel_work_sync(struct work_struct *work); 

4. 调度工作队列,下面两个函数一样,s调用q

头文件:workqueue.h

int schedule_work(struct work_struct *work)

int queue_work(struct workqueue_struct *wq, struct work_struct *work)

这篇关于Linux内核模块时间同步函数汇总的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908288

相关文章

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n