tag 标签: 内部定时器

相关博文
  • 热度 3
    2023-11-9 16:57
    586 次阅读|
    0 个评论
    1. 内部定时器介绍 内核定时器是内核用来控制在未来某个时间点(基于 jiffies )调度执行某个函数的一种机制,其实现位于 kernel/linux/timer.h 和 kernel/timer.c 文件中。 被调度的函数肯定是异步执行的,它类似于一种“软件中断”,而且是处于非进程的上下文中,所以调度函数必须遵守以下规则: a. 没有 current 指针、不允许访问用户空间。因为没有进程上下文,相关代码和被中断的进程没有任何联系。 b. 不能执行休眠(或可能引起休眠的函数)和调度。 c. 任何被访问的数据结构都应该针对并发访问进行保护,以防止竞争条件。 内核定时器的调度函数运行过一次后就不会再被运行了(相当于自动注销),但可以通过在被调度的函数中重新调度自己来周期运行。 在 SMP 系统中,调度函数总是在注册它的同一 CPU 上运行,以尽可能获得缓存的局域性。 2. 驱动示例代码 RK3568 蜂鸣器定时鸣叫 : #include #include #include #include #include #defineGPIO_PIN 15 // 替换为你的 GPIO 引脚 staticstruct timer_list timer; intgpio_status = 1; // 定时器中断处理函数 staticvoid timer_callback(struct timer_list *t) { gpio_set_value(GPIO_PIN ,gpio_status); gpio_status = ! gpio_status; mod_timer(&timer, jiffies +msecs_to_jiffies(1000)); // 1 秒后再次触发定时器 } staticint __init mymodule_init(void) { int ret; // 请求 GPIO ret = gpio_request(GPIO_PIN,"my_gpio"); if (ret) { printk(" 无法请求 GPIO %d\n",GPIO_PIN); return ret; } // 配置 GPIO 引脚为输出 gpio_direction_output(GPIO_PIN, 0); // 初始化定时器 timer_setup(&timer, timer_callback, 0); mod_timer(&timer, jiffies +msecs_to_jiffies(2000)); // 2 秒后触发定时器 return 0; } staticvoid __exit mymodule_exit(void) { // 删除定时器 del_timer_sync(&timer); // 释放 GPIO gpio_free(GPIO_PIN); } module_init(mymodule_init); module_exit(mymodule_exit); MODULE_LICENSE("GPL"); MODULE_AUTHOR("zou"); MODULE_DESCRIPTION("SampleGPIO and Timer Interrupt Kernel Module"); 3. 内部定时器验证 将驱动编译成模块并 insmod (加载)模块后,等待 2 秒后蜂鸣器开始以 1s 时间间隔鸣叫。
相关资源
  • 所需E币: 4
    时间: 2019-12-25 21:14
    大小: 60KB
    上传者: 978461154_qq
    MCS-51内部含有一个可编程全双工串行通信接口,具有UART的全部功能。该接口电路不仅能同时进行数据的发送和接收,也可作为一个同步移位寄存器使用。在进行异步通信时,数据的发送和接收分别在各自的时钟(TCLK和RCLK)控制下进行的,但都必须与字符位数的波特率保持一致。MCS-51串行口的发送和接收时钟可由两种方式产生,一种是由主机频率fosc经分频后产生,另一种方式是由内部定时器T1或T2的溢出率经16分频后提供。……