?? netlink-exam-user-recv.c
字號:
//application receiver: netlink-exam-user-recv.c
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h> //========================
#include <linux/netlink.h> //========================
#define MAX_MSGSIZE 1024
int main(void)
{/* struct sockaddr_nl{ sa_family_t nl_family; unsigned short nl_pad; //default is 0 __u32 nl_pid; __u32 nl_groups;}; struct nlmsghdr //為 netlink socket 自己的消息頭,netlink 控制塊{ __u32 nlmsg_len; //Length of message __u16 nlmsg_type; // Message type __u16 nlmsg_flags; // Additional flags __u32 nlmsg_seq; // Sequence number __u32 nlmsg_pid; // Sending process PID };*/
struct sockaddr_nl saddr, daddr;
struct nlmsghdr *nlhdr = NULL;
struct msghdr msg;
struct iovec iov;
int sd;
int ret = 1;
sd = socket(AF_NETLINK, SOCK_RAW,NETLINK_GENERIC); //===============
memset(&saddr, 0, sizeof(saddr));
memset(&daddr, 0, sizeof(daddr));
saddr.nl_family = AF_NETLINK;
saddr.nl_pid = getpid();
saddr.nl_groups = 1;
bind(sd, (struct sockaddr*)&saddr, sizeof(saddr)); //===============
nlhdr = (struct nlmsghdr *)malloc(NLMSG_SPACE(MAX_MSGSIZE));//宏NLMSG_SPACE(len)返回不小于NLMSG_LENGTH(len)且字節(jié)對齊的最小數(shù)值,它也用于分配消息緩存
while (1) {
memset(nlhdr, 0, NLMSG_SPACE(MAX_MSGSIZE));
iov.iov_base = (void *)nlhdr;
iov.iov_len = NLMSG_SPACE(MAX_MSGSIZE);
msg.msg_name = (void *)&daddr;
msg.msg_namelen = sizeof(daddr);
msg.msg_iov = &iov;
msg.msg_iovlen = 1;
ret = recvmsg(sd, &msg, 0); //===========================
if (ret == 0) {
printf("Exit.\n");
exit(0);
}
else if (ret == -1) {
perror("recvmsg:");
exit(1);
}
printf("%s", NLMSG_DATA(nlhdr));//宏NLMSG_DATA(nlh)用于取得消息的數(shù)據(jù)部分的首地址,設置和讀取消息數(shù)據(jù)部分時需要使用該宏。
}
close(sd); //======================================
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -