我是靠谱客的博主 文艺滑板,最近开发中收集的这篇文章主要介绍两个linux内核通信,linux内核两个驱动之间的通信,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

有网友问到 linux两个驱动之间通信的问题:

开发环境:linux OS

想要实现的效果是:

先加载驱动1和驱动2,当驱动1的中断被触发后,进入中断处理函数,然后发送类似信号功能的某机制;

接着,驱动2收到后,停止阻塞,进行相应的处理...

请问:该用什么实现呢?

-----------------------------------------------------------------------------------------

我推荐使用内核完成量,该网友说总是编译有问题,然后我自己写了两个驱动测试了下:

drv_test/

├── Makefile

├── module1

│   ├── Makefile

│   ├── module1.c

├── module2

│   ├── Makefile

│   ├── module2.c

最外层的Makefile:

obj-y := module1/ module2/

module1里面的Makeifle:

obj-m = module1.o

module2里面的Makeifle:

obj-m = module2.o

module1.c

TD P { margin-bottom: 0in; }P { margin-bottom: 0.08in; }

#include

#include

#include

DECLARE_COMPLETION(your_comp);

EXPORT_SYMBOL_GPL(your_comp);

void interrupt(int irq, void *data)

{

complete(&your_comp);

}

static int module1_init(void)

{

pr_info("this is a test modulen");

//request_irq(IRQ_NUM, NULL, interrupt,NULL)

return 1;

}

static void module1_exit(void)

{

pr_info("exit!n");

}

module_init(module1_init);

module_exit(module1_exit);

MODULE_AUTHOR("ramon1892");

MODULE_LICENSE("GPL");

module2.c:

P { margin-bottom: 0.08in; }

#include

#include

#include

extern struct completion your_comp;

static int module2_init(void)

{

if(wait_for_completion_interruptible_timeout(&your_comp, 10*1000))

return 0;

pr_info("this is a test modulen");

return 1;

}

static void module2_exit(void)

{

pr_info("exit!n");

}

module_init(module2_init);

module_exit(module2_exit);

MODULE_AUTHOR("ramon1892");

MODULE_LICENSE("GPL");

然后直接在drv_test目录下执行:

make -C 【/kernel/source/】 M=$PWD CFLAGS+=-DEXPORT_SYMTAB

就好了,最后insmod module1.ko; insmode module2.ko 工作正常。

记录之~

最后

以上就是文艺滑板为你收集整理的两个linux内核通信,linux内核两个驱动之间的通信的全部内容,希望文章能够帮你解决两个linux内核通信,linux内核两个驱动之间的通信所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(34)

评论列表共有 0 条评论

立即
投稿
返回
顶部