第20篇:Linux设备驱动程序入门<七>

**Q:**如何编写定时器中断驱动内核模块?

**A:**使用在FPGA中实现的间隔定时器FPGA Timer0,寄存器接口基地址为0x00002000,时钟频率100MHz,中断ID为72。调用这个定时器需要向Counter start value寄存器写入适当的值(有两个Counter start value寄存器,一个存储32位定时器值中的高16位,另一个存储低16位);通过程序将TO位写为0,即可将其值清零。如果Control寄存器中的ITO位为1,则每次设置TO位的时候,定时器将产生一个ARM中断。

本次实验编写的定时器中断驱动内核模块可实现在数码管上显示实时时钟,内核模块中使用到一个hardware timer模块,实现持续记录时间的功能,部分代码如下:

启动DE1-SoC-UP Linux系统,执行make命令编译生成模块文件然后加载模块,可观察到DE1-SoC开发板上的七段数码管HEX5~HEX0上显示实时时钟,从00:00:00开始计时,到59:59:99后重新返回00:00:00开始计时;在Terminal上使用rmmod命令移除内核模块后,exit程序会将七段数码管清零。

相关推荐
ktd0071 小时前
`timescale 1ns/1ps的意义
fpga开发
我是苹果,不是香蕉2 小时前
双端口ram与真双端口ram的区别
fpga开发
尤老师FPGA2 小时前
LVDS系列11:Xilinx Ultrascale系可编程输入延迟(一)
fpga开发
怪小庄吖7 小时前
7系列 之 OSERDESE2
笔记·fpga开发·硬件架构·硬件工程·xilinx·7系列fpga·i/o资源
怪小庄吖7 小时前
UG471 之 SelectIO 逻辑资源
笔记·fpga开发·硬件架构·硬件工程·xilinx·7系列fpga·i/o资源
MVP-curry-萌神11 小时前
FPGA图像处理(5)------ 图片水平镜像
图像处理·fpga开发
9527华安11 小时前
Altera系列FPGA纯verilog视频图像去雾,基于暗通道先验算法实现,提供4套Quartus工程源码和技术支持
fpga开发·图像去雾·quartus·altera·基于暗通道先验
碎碎思14 小时前
不用官方EDA怎么开发FPGA?
fpga开发
一条九漏鱼1 天前
Verilog Test Fixture 时钟激励
fpga开发