免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3754 | 回复: 3
打印 上一主题 下一主题

问个关于udev规则的问题,是关于socket的 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-10 21:56 |只看该作者 |倒序浏览
本帖最后由 gelandesprung 于 2010-06-10 21:58 编辑

我的udev配置目录下有这样一条规则
  1. # event to be catched by udevmonitor                                            
  2. RUN+="socket:/org/kernel/udev/monitor"
复制代码
如果我想在我的应用程序中接收udev发送的消息,如何接收。就是那个socket怎么建?(查了好久没有查到)
还有就是:是不是udev把从内核收到的广播消息都发送到这个socket中去?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2010-06-12 15:14 |只看该作者
是不是类似于钩子这样的机制?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2010-06-12 15:15 |只看该作者
感觉你说的这个跟netlink的机制有点像!!!

论坛徽章:
0
4 [报告]
发表于 2010-06-17 20:41 |只看该作者
本人比较笨,研究了几天,了解了一点。内核通过netlink把内核消息发送出去,udevd专门建一个连接监听然后接收消息。
  1. # event to be catched by udevmonitor                                            
  2. RUN+="socket:/org/kernel/udev/monitor"
复制代码
是udevd的一条规则,意思是把udevd收到的消息发送到一个socket,这个socket绑定在/org/kernel/udev/monitor上,我们可以写个程序去接收这消息如下:
我在/etc/udevd/rules.d/下添加一条规则
  1. RUN+="socket:@/org/kernels/udev/udevd
复制代码
然后编译运行下面的代码,就可以接收到消息了。
  1. #include <unistd.h>
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <stddef.h>
  5. #include <string.h>
  6. #include <fcntl.h>
  7. #include <errno.h>
  8. #include <signal.h>
  9. #include <getopt.h>
  10. #include <sys/time.h>
  11. #include <sys/socket.h>
  12. #include <sys/un.h>
  13. #include <sys/select.h>
  14. #include <linux/types.h>
  15. #include <linux/netlink.h>

  16. static int udev_sock = -1;

  17. static int
  18. init_socket (void)
  19. {
  20.   struct sockaddr_un saddr;
  21.   socklen_t addrlen;
  22.   int retval;
  23.   memset (&saddr, 0x00, sizeof (saddr));
  24.   saddr.sun_family = AF_LOCAL;
  25.   strcpy (&saddr.sun_path[1], "/org/kernels/udev/udevd");
  26.   addrlen =
  27.     offsetof (struct sockaddr_un, sun_path) + strlen (saddr.sun_path + 1) + 1;
  28.   udev_sock = socket (AF_LOCAL, SOCK_DGRAM, 0);
  29.   if (udev_sock == -1)
  30.     {
  31.       printf ("create socket err\n");
  32.       return -1;
  33.     }
  34.   retval = bind (udev_sock, (struct sockaddr *) &saddr, addrlen);
  35.   if (retval < 0)
  36.     {
  37. printf("bind error\n");
  38.       close (udev_sock);
  39.       udev_sock = -1;
  40.       return -1;
  41.     }
  42.   return 0;
  43. }

  44. int
  45. main ()
  46. {
  47.   fd_set readfds;
  48.   char buf[1024];
  49.   int retval = 0;
  50. int fdcount;
  51. int buflen = 0;
  52. init_socket();
  53.   while (1)
  54.     {
  55.       FD_ZERO (&readfds);
  56.       if (udev_sock >= 0)
  57.         FD_SET (udev_sock, &readfds);
  58.       fdcount = select (udev_sock + 1, &readfds, NULL, NULL, NULL);
  59.       if (fdcount < 0)
  60.         {
  61.           continue;
  62.         }

  63.       if (udev_sock >= 0 && FD_ISSET (udev_sock, &readfds))
  64.         {
  65.           buflen = recv (udev_sock, &buf, sizeof (buf), 0);
  66.           printf ("%s\n", buf);
  67.         }
  68.     }
  69. }
复制代码
不过这些还是不能解决我的问题,我需要电源键被按下的时候也能收到一条消息,但没有收到,不知道是不是只有插拔事件才会产生事件。还是的确有办法只是我没有找到,我现在能想到的是我们的电源键有一个设备文件,可以从中读取状态,也就是说它是有驱动的,是不是可以改驱动产生一个事件,然后我再去读电源键设备的文件状态。这样就不用一直查询了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP