您的当前位置:首页正文

linu内核模块中 软中断的 例子

2021-05-28 来源:易榕旅网


直接上例子吧。只是捕获某个设备的中断而已。。。

view plaincopy to clipboardprint

#include

#include

#include

#include

#include

#define DEBUG

#ifdef DEBUG

#define MSG(message, args...) printk(KERN_DEBUG \"irq:\" message, ##args)

#else

#define MSG(message, args...)

#endif

MODULE_LICENSE(\"GPL\");

MODULE_AUTHOR(\"silence1214\");

int irq;

char *interface;

// 下面这2个参数通过插入内核模块的时候赋值的...

module_param(irq, int, 0644);

module_param(interface, charp, 0644);

// 中断捕获的时候的处理函数

int irq_handle_function(int irq, void *device_id)

{

static int count = 1;

MSG(\"[%d]receive the irq at %ld...\\n\

count++;

return IRQ_NONE;

}

int init_module()

{

// 注册中断捕获,第三个参数的意思是和其他设备共享该中断号,最后一个参数是设备的id,其实对于共享下的设备这个号码据说是随便写,一般都写irq的了。

//只要注册成功就可以等待对应设备的该中断号的到来 就可以处理回调函数了。。

if(request_irq(irq, irq_handle_function, IRQF_SHARED, interface, (void *)&irq))

{

MSG(\"regist irq failure...\\n\");

return -EIO;

}

MSG(\"interface=%s and irq=%d...\\n\

MSG(\"regist irq success...\\n\");

return 0;

}

void cleanup_module()

{

free_irq(irq, &irq);

MSG(\"unregist irq...\\n\");

}

#include

#include

#include

#include

#include

#define DEBUG

#ifdef DEBUG

#define MSG(message, args...) printk(KERN_DEBUG \"irq:\" message, ##args)

#else

#define MSG(message, args...)

#endif

MODULE_LICENSE(\"GPL\");

MODULE_AUTHOR(\"silence1214\");

int irq;

char *interface;

// 下面这2个参数通过插入内核模块的时候赋值的...

module_param(irq, int, 0644);

module_param(interface, charp, 0644);

// 中断捕获的时候的处理函数

int irq_handle_function(int irq, void *device_id)

{

static int count = 1;

MSG(\"[%d]receive the irq at %ld...\\n\

count++;

return IRQ_NONE;

}

int init_module()

{

// 注册中断捕获,第三个参数的意思是和其他设备共享该中断号,最后一个参数是设备的id,其实对于共享下的设备这个号码据说是随便写,一般都写irq的了。

//只要注册成功就可以等待对应设备的该中断号的到来 就可以处理回调函数了。。

if(request_irq(irq, irq_handle_function, IRQF_SHARED, interface, (void *)&irq))

{

MSG(\"regist irq failure...\\n\");

return -EIO;

}

MSG(\"interface=%s and irq=%d...\\n\

MSG(\"regist irq success...\\n\");

return 0;

}

void cleanup_module()

{

free_irq(irq, &irq);

MSG(\"unregist irq...\\n\");

}

对应的makefile的内容是

view plaincopy to clipboardprint

obj-m:=irq.o

default:

make -C /lib/modules/$(shell uname -r)/build M=$(shell pwd) modules

default:

make -C /lib/modules/$(shell uname -r)/build M=$(shell pwd) modules

我的当前内核版本为:

执行步骤:

2:查看 cat /proc/interrupts

我的打印结果是:

这个19就是我需要使用的中断号,eth0其实就是网卡〔第一块,我也就这么一块〕。。。

然后我使用插入内核模块的命令是:2.1:insmod irq.ko interface=eth1 irq=19如果没有报任何信息就是插入正确了,接着2.2:输入 dmesg 回车。。就会看到如下截图的信息了。。就是我们程序中打印的信息。。

好了这就是算成功了。。。2.3:原理就是,,注册了一个捕获中断号为19的程序。。。然后当发出19的中断号的设备发出中断时。。我程序捕获一下。。。3:最后使用命令 cat /proc/interrupts 查看一下刚刚的变化

那个19的记录后面是不是多出了个eth1这个eth1就是刚刚insmod irq.ko interface=eth1 irq=19 命令中的eth1哈 咱们设备的名字。。。ok了。。。

算是入门了。。

因篇幅问题不能全部显示,请点此查看更多更全内容