我需要在我的应用程序中编写一个事件循环,以处理从用户发送到 ncurses 接口的所有事件以及从内核模块通过 netlink 发送的所有消息。
我有两个问题。
如何使套接字不阻塞?(
fcntl(sock_fd, F_SETFL, O_NONBLOCK);
也许/只有?)我怎样才能得到
fd
终端(ncurses),以便我可以将它添加到 epoll 的事件中?
这就是我启动套接字的方式:
int net_init(void){
int sock_fd;
struct sockaddr_nl src_addr, dest_addr;
sock_fd = socket(PF_NETLINK, SOCK_RAW, get_netlink_id()); <---- autonegotiation with the kernel module.
if(sock_fd < 0){
return -1;
}
memset(&src_addr, 0, sizeof(src_addr));
src_addr.nl_family = AF_NETLINK;
src_addr.nl_pid = getpid();
bind(sock_fd, (struct sockaddr *)&src_addr, sizeof(src_addr));
memset(&dest_addr, 0, sizeof(dest_addr));
memset(&dest_addr, 0, sizeof(dest_addr));
dest_addr.nl_family = AF_NETLINK;
dest_addr.nl_pid = 0;
dest_addr.nl_groups = 0;
nlh = (struct nlmsghdr *)new(NLMSG_SPACE(MAX_PAYLOAD));
memset(nlh, 0, NLMSG_SPACE(MAX_PAYLOAD));
nlh->nlmsg_len = NLMSG_SPACE(MAX_PAYLOAD);
nlh->nlmsg_pid = getpid();
nlh->nlmsg_flags = 0;
strcpy(NLMSG_DATA(nlh), ""); <--- Send empty string to the kernel module so it knows to what PID it should send data
iov.iov_base = (void *)nlh;
iov.iov_len = nlh->nlmsg_len;
msg.msg_name = (void *)&dest_addr;
msg.msg_namelen = sizeof(dest_addr);
msg.msg_iov = &iov;
msg.msg_iovlen = 1;
sendmsg(sock_fd, &msg, 0);
return sock_fd;
}