亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? libnetlink.c

?? mobile ipv6協議Linux實現源代碼
?? C
字號:
/* * libnetlink.c	RTnetlink service routines. * *		This program is free software; you can redistribute it and/or *		modify it under the terms of the GNU General Public License *		as published by the Free Software Foundation; either version *		2 of the License, or (at your option) any later version. * * Authors:	Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru> * */#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <syslog.h>#include <fcntl.h>#include <net/if_arp.h>#include <sys/socket.h>#include <netinet/in.h>#include <string.h>#include <errno.h>#include <time.h>#include <sys/uio.h>#include "libnetlink.h"int rtnl_open(struct rtnl_handle *rth, unsigned subscriptions){	int addr_len;	memset(rth, 0, sizeof(rth));	rth->fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE);	if (rth->fd < 0) {		perror("Cannot open netlink socket");		return -1;	}	memset(&rth->local, 0, sizeof(rth->local));	rth->local.nl_family = AF_NETLINK;	rth->local.nl_groups = subscriptions;	if (bind(rth->fd, (struct sockaddr*)&rth->local, sizeof(rth->local)) < 0) {		perror("Cannot bind netlink socket");		return -1;	}	addr_len = sizeof(rth->local);	if (getsockname(rth->fd, (struct sockaddr*)&rth->local, &addr_len) < 0) {		perror("Cannot getsockname");		return -1;	}	if (addr_len != sizeof(rth->local)) {		fprintf(stderr, "Wrong address length %d\n", addr_len);		return -1;	}	if (rth->local.nl_family != AF_NETLINK) {		fprintf(stderr, "Wrong address family %d\n", rth->local.nl_family);		return -1;	}	rth->seq = time(NULL);	return 0;}int rtnl_wilddump_request(struct rtnl_handle *rth, int family, int type){	struct {		struct nlmsghdr nlh;		struct rtgenmsg g;	} req;	struct sockaddr_nl nladdr;	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	req.nlh.nlmsg_len = sizeof(req);	req.nlh.nlmsg_type = type;	req.nlh.nlmsg_flags = NLM_F_ROOT|NLM_F_MATCH|NLM_F_REQUEST;	req.nlh.nlmsg_pid = 0;	req.nlh.nlmsg_seq = rth->dump = ++rth->seq;	req.g.rtgen_family = family;	return sendto(rth->fd, (void*)&req, sizeof(req), 0, (struct sockaddr*)&nladdr, sizeof(nladdr));}int rtnl_send(struct rtnl_handle *rth, char *buf, int len){	struct sockaddr_nl nladdr;	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	return sendto(rth->fd, buf, len, 0, (struct sockaddr*)&nladdr, sizeof(nladdr));}int rtnl_dump_request(struct rtnl_handle *rth, int type, void *req, int len){	struct nlmsghdr nlh;	struct sockaddr_nl nladdr;	struct iovec iov[2] = { { &nlh, sizeof(nlh) }, { req, len } };	struct msghdr msg = {		(void*)&nladdr, sizeof(nladdr),		iov,	2,		NULL,	0,		0	};	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	nlh.nlmsg_len = NLMSG_LENGTH(len);	nlh.nlmsg_type = type;	nlh.nlmsg_flags = NLM_F_ROOT|NLM_F_MATCH|NLM_F_REQUEST;	nlh.nlmsg_pid = 0;	nlh.nlmsg_seq = rth->dump = ++rth->seq;	return sendmsg(rth->fd, &msg, 0);}int rtnl_dump_filter(struct rtnl_handle *rth,		     int (*filter)(struct sockaddr_nl *, struct nlmsghdr *n, void *),		     void *arg1,		     int (*junk)(struct sockaddr_nl *,struct nlmsghdr *n, void *),		     void *arg2){	char	buf[8192];	struct sockaddr_nl nladdr;	struct iovec iov = { buf, sizeof(buf) };	while (1) {		int status;		struct nlmsghdr *h;		struct msghdr msg = {			(void*)&nladdr, sizeof(nladdr),			&iov,	1,			NULL,	0,			0		};		status = recvmsg(rth->fd, &msg, 0);		if (status < 0) {			if (errno == EINTR)				continue;			perror("OVERRUN");			continue;		}		if (status == 0) {			fprintf(stderr, "EOF on netlink\n");			return -1;		}		if (msg.msg_namelen != sizeof(nladdr)) {			fprintf(stderr, "sender address length == %d\n", msg.msg_namelen);			exit(1);		}		h = (struct nlmsghdr*)buf;		while (NLMSG_OK(h, status)) {			int err;			if (h->nlmsg_pid != rth->local.nl_pid ||			    h->nlmsg_seq != rth->dump) {				if (junk) {					err = junk(&nladdr, h, arg2);					if (err < 0)						return err;				}				goto skip_it;			}			if (h->nlmsg_type == NLMSG_DONE)				return 0;			if (h->nlmsg_type == NLMSG_ERROR) {				struct nlmsgerr *err = (struct nlmsgerr*)NLMSG_DATA(h);				if (h->nlmsg_len < NLMSG_LENGTH(sizeof(struct nlmsgerr))) {					fprintf(stderr, "ERROR truncated\n");				} else {					errno = -err->error;					perror("RTNETLINK answers");				}				return -1;			}			err = filter(&nladdr, h, arg1);			if (err < 0)				return err;skip_it:			h = NLMSG_NEXT(h, status);		}		if (msg.msg_flags & MSG_TRUNC) {			fprintf(stderr, "Message truncated\n");			continue;		}		if (status) {			fprintf(stderr, "!!!Remnant of size %d\n", status);			exit(1);		}	}}int rtnl_talk(struct rtnl_handle *rtnl, struct nlmsghdr *n, pid_t peer,	      unsigned groups, struct nlmsghdr *answer,	      int (*junk)(struct sockaddr_nl *,struct nlmsghdr *n, void *),	      void *jarg){	int status;	unsigned seq;	struct nlmsghdr *h;	struct sockaddr_nl nladdr;	struct iovec iov = { (void*)n, n->nlmsg_len };	char   buf[8192];	struct msghdr msg = {		(void*)&nladdr, sizeof(nladdr),		&iov,	1,		NULL,	0,		0	};	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	nladdr.nl_pid = peer;	nladdr.nl_groups = groups;	n->nlmsg_seq = seq = ++rtnl->seq;	if (answer == NULL)		n->nlmsg_flags |= NLM_F_ACK;	status = sendmsg(rtnl->fd, &msg, 0);	if (status < 0) {		perror("Cannot talk to rtnetlink");		return -1;	}	iov.iov_base = buf;	iov.iov_len = sizeof(buf);	while (1) {		status = recvmsg(rtnl->fd, &msg, 0);		if (status < 0) {			if (errno == EINTR)				continue;			perror("OVERRUN");			continue;		}		if (status == 0) {			fprintf(stderr, "EOF on netlink\n");			return -1;		}		if (msg.msg_namelen != sizeof(nladdr)) {			fprintf(stderr, "sender address length == %d\n", msg.msg_namelen);			exit(1);		}		for (h = (struct nlmsghdr*)buf; status >= sizeof(*h); ) {			int err;			int len = h->nlmsg_len;			int l = len - sizeof(*h);			if (l<0 || len>status) {				if (msg.msg_flags & MSG_TRUNC) {					fprintf(stderr, "Truncated message\n");					return -1;				}				fprintf(stderr, "!!!malformed message: len=%d\n", len);				exit(1);			}			if (h->nlmsg_pid != rtnl->local.nl_pid ||			    h->nlmsg_seq != seq) {				if (junk) {					err = junk(&nladdr, h, jarg);					if (err < 0)						return err;				}				continue;			}			if (h->nlmsg_type == NLMSG_ERROR) {				struct nlmsgerr *err = (struct nlmsgerr*)NLMSG_DATA(h);				if (l < sizeof(struct nlmsgerr)) {					fprintf(stderr, "ERROR truncated\n");				} else {					errno = -err->error;					if (errno == 0) {						if (answer)							memcpy(answer, h, h->nlmsg_len);						return 0;					}					perror("RTNETLINK answers");				}				return -1;			}			if (answer) {				memcpy(answer, h, h->nlmsg_len);				return 0;			}			fprintf(stderr, "Unexpected reply!!!\n");			status -= NLMSG_ALIGN(len);			h = (struct nlmsghdr*)((char*)h + NLMSG_ALIGN(len));		}		if (msg.msg_flags & MSG_TRUNC) {			fprintf(stderr, "Message truncated\n");			continue;		}		if (status) {			fprintf(stderr, "!!!Remnant of size %d\n", status);			exit(1);		}	}}int rtnl_listen(struct rtnl_handle *rtnl, 	      int (*handler)(struct sockaddr_nl *,struct nlmsghdr *n, void *),	      void *jarg){	int status;	struct nlmsghdr *h;	struct sockaddr_nl nladdr;	struct iovec iov;	char   buf[8192];	struct msghdr msg = {		(void*)&nladdr, sizeof(nladdr),		&iov,	1,		NULL,	0,		0	};	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	nladdr.nl_pid = 0;	nladdr.nl_groups = 0;	iov.iov_base = buf;	iov.iov_len = sizeof(buf);	while (1) {		status = recvmsg(rtnl->fd, &msg, 0);		if (status < 0) {			if (errno == EINTR)				continue;			perror("OVERRUN");			continue;		}		if (status == 0) {			fprintf(stderr, "EOF on netlink\n");			return -1;		}		if (msg.msg_namelen != sizeof(nladdr)) {			fprintf(stderr, "Sender address length == %d\n", msg.msg_namelen);			exit(1);		}		for (h = (struct nlmsghdr*)buf; status >= sizeof(*h); ) {			int err;			int len = h->nlmsg_len;			int l = len - sizeof(*h);			if (l<0 || len>status) {				if (msg.msg_flags & MSG_TRUNC) {					fprintf(stderr, "Truncated message\n");					return -1;				}				fprintf(stderr, "!!!malformed message: len=%d\n", len);				exit(1);			}			err = handler(&nladdr, h, jarg);			if (err < 0)				return err;			status -= NLMSG_ALIGN(len);			h = (struct nlmsghdr*)((char*)h + NLMSG_ALIGN(len));		}		if (msg.msg_flags & MSG_TRUNC) {			fprintf(stderr, "Message truncated\n");			continue;		}		if (status) {			fprintf(stderr, "!!!Remnant of size %d\n", status);			exit(1);		}	}}int rtnl_from_file(FILE *rtnl, 	      int (*handler)(struct sockaddr_nl *,struct nlmsghdr *n, void *),	      void *jarg){	int status;	struct sockaddr_nl nladdr;	char   buf[8192];	struct nlmsghdr *h = (void*)buf;	memset(&nladdr, 0, sizeof(nladdr));	nladdr.nl_family = AF_NETLINK;	nladdr.nl_pid = 0;	nladdr.nl_groups = 0;	while (1) {		int err, len, type;		int l;		status = fread(&buf, 1, sizeof(*h), rtnl);		if (status < 0) {			if (errno == EINTR)				continue;			perror("rtnl_from_file: fread");			return -1;		}		if (status == 0)			return 0;		len = h->nlmsg_len;		type= h->nlmsg_type;		l = len - sizeof(*h);		if (l<0 || len>sizeof(buf)) {			fprintf(stderr, "!!!malformed message: len=%d @%lu\n",				len, ftell(rtnl));			return -1;		}		status = fread(NLMSG_DATA(h), 1, NLMSG_ALIGN(l), rtnl);		if (status < 0) {			perror("rtnl_from_file: fread");			return -1;		}		if (status < l) {			fprintf(stderr, "rtnl-from_file: truncated message\n");			return -1;		}		err = handler(&nladdr, h, jarg);		if (err < 0)			return err;	}}int addattr32(struct nlmsghdr *n, int maxlen, int type, __u32 data){	int len = RTA_LENGTH(4);	struct rtattr *rta;	if (NLMSG_ALIGN(n->nlmsg_len) + len > maxlen)		return -1;	rta = (struct rtattr*)(((char*)n) + NLMSG_ALIGN(n->nlmsg_len));	rta->rta_type = type;	rta->rta_len = len;	memcpy(RTA_DATA(rta), &data, 4);	n->nlmsg_len = NLMSG_ALIGN(n->nlmsg_len) + len;	return 0;}int addattr_l(struct nlmsghdr *n, int maxlen, int type, void *data, int alen){	int len = RTA_LENGTH(alen);	struct rtattr *rta;	if (NLMSG_ALIGN(n->nlmsg_len) + len > maxlen)		return -1;	rta = (struct rtattr*)(((char*)n) + NLMSG_ALIGN(n->nlmsg_len));	rta->rta_type = type;	rta->rta_len = len;	memcpy(RTA_DATA(rta), data, alen);	n->nlmsg_len = NLMSG_ALIGN(n->nlmsg_len) + len;	return 0;}int rta_addattr32(struct rtattr *rta, int maxlen, int type, __u32 data){	int len = RTA_LENGTH(4);	struct rtattr *subrta;	if (RTA_ALIGN(rta->rta_len) + len > maxlen)		return -1;	subrta = (struct rtattr*)(((char*)rta) + RTA_ALIGN(rta->rta_len));	subrta->rta_type = type;	subrta->rta_len = len;	memcpy(RTA_DATA(subrta), &data, 4);	rta->rta_len = NLMSG_ALIGN(rta->rta_len) + len;	return 0;}int rta_addattr_l(struct rtattr *rta, int maxlen, int type, void *data, int alen){	struct rtattr *subrta;	int len = RTA_LENGTH(alen);	if (RTA_ALIGN(rta->rta_len) + len > maxlen)		return -1;	subrta = (struct rtattr*)(((char*)rta) + RTA_ALIGN(rta->rta_len));	subrta->rta_type = type;	subrta->rta_len = len;	memcpy(RTA_DATA(subrta), data, alen);	rta->rta_len = NLMSG_ALIGN(rta->rta_len) + len;	return 0;}int parse_rtattr(struct rtattr *tb[], int max, struct rtattr *rta, int len){	while (RTA_OK(rta, len)) {		if (rta->rta_type <= max)			tb[rta->rta_type] = rta;		rta = RTA_NEXT(rta,len);	}	if (len)		fprintf(stderr, "!!!Deficit %d, rta_len=%d\n", len, rta->rta_len);	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线视频日韩| 国产精品免费观看视频| 久久精品人人爽人人爽| 一区二区三区在线视频观看| 久久精品国产精品青草| 色999日韩国产欧美一区二区| 日韩欧美一二区| 日韩精彩视频在线观看| 国产在线精品不卡| 欧美日韩黄视频| 国产精品理论片| 捆绑紧缚一区二区三区视频| 在线精品视频免费播放| 久久久久88色偷偷免费| 日韩电影免费在线观看网站| 99久久精品国产精品久久| 26uuu精品一区二区三区四区在线| 亚洲最大色网站| 99国产精品一区| 国产网红主播福利一区二区| 免费不卡在线观看| 欧美精品一级二级三级| 亚洲精品成人a在线观看| www.色精品| 中文字幕第一页久久| 国产毛片精品国产一区二区三区| 制服.丝袜.亚洲.另类.中文| 亚洲妇女屁股眼交7| 在线国产电影不卡| 亚洲精品视频在线看| 成人av资源下载| 国产精品久久久久一区| 风流少妇一区二区| 国产精品污www在线观看| 国产高清成人在线| 国产日韩欧美麻豆| 国产精品一区二区在线播放| 91精品啪在线观看国产60岁| 性做久久久久久| 欧美群妇大交群的观看方式| 日韩在线a电影| 欧美精品乱码久久久久久| 首页欧美精品中文字幕| 91精品国产黑色紧身裤美女| 日韩精品亚洲一区二区三区免费| 欧美网站大全在线观看| 亚洲午夜电影在线| 欧美久久久久久久久久| 美女视频一区二区三区| 精品粉嫩aⅴ一区二区三区四区 | 91视频一区二区三区| 亚洲婷婷在线视频| 色乱码一区二区三区88| 亚洲成人动漫一区| 精品久久久久久最新网址| 国产盗摄一区二区| 亚洲欧美视频在线观看| 欧美日本不卡视频| 美女网站色91| 国产欧美日韩中文久久| 91网站黄www| 亚洲大片精品永久免费| 日韩欧美不卡一区| 国产mv日韩mv欧美| 亚洲一区二区中文在线| 欧美xxx久久| 94-欧美-setu| 日韩成人免费在线| 国产日韩欧美一区二区三区综合 | 精品精品国产高清一毛片一天堂| 国产东北露脸精品视频| 亚洲高清免费视频| 久久精品欧美日韩| 欧美日韩精品欧美日韩精品一 | 中文字幕第一页久久| 欧美午夜电影在线播放| 国产成人午夜电影网| 亚洲福利一区二区| 亚洲综合成人在线| 国产亚洲综合色| 7777精品伊人久久久大香线蕉超级流畅| 久久91精品久久久久久秒播| 亚洲欧美日韩国产综合在线 | 亚洲一区二区三区视频在线| 欧美成va人片在线观看| 在线一区二区三区做爰视频网站| 看片的网站亚洲| 亚洲激情校园春色| 日本一区二区高清| 在线不卡免费欧美| 色呦呦国产精品| 岛国精品在线播放| 久久精品国产澳门| 婷婷六月综合网| 亚洲乱码中文字幕| 国产精品免费视频网站| 精品国产乱码久久久久久影片| 在线观看国产91| 成人免费高清视频在线观看| 国产永久精品大片wwwapp| 日韩电影在线看| 亚洲一区av在线| 亚洲精品乱码久久久久久黑人| 久久久久9999亚洲精品| 日韩精品一区二区三区在线播放| 欧美日韩黄色影视| 欧美午夜一区二区三区免费大片| 91亚洲男人天堂| 99精品视频一区二区| 丁香激情综合国产| 岛国一区二区三区| 成人av在线影院| av在线一区二区| 成人av网站免费观看| 韩国女主播一区二区三区| 日韩精品电影在线| 日韩中文字幕亚洲一区二区va在线| 亚洲综合免费观看高清完整版| 亚洲免费高清视频在线| 玉足女爽爽91| 亚洲国产精品久久久久秋霞影院 | 成人精品视频一区二区三区| 国产一区视频导航| 国产成a人亚洲| 成人av高清在线| 日本二三区不卡| 欧美视频在线观看一区二区| 欧美午夜精品一区二区蜜桃 | 欧美色手机在线观看| 欧美私人免费视频| 欧美巨大另类极品videosbest| 91麻豆精品国产91久久久使用方法 | 91.xcao| 欧美一区二区三区四区久久| 日韩精品在线一区二区| 久久你懂得1024| 最新中文字幕一区二区三区| 亚洲美女屁股眼交3| 视频一区免费在线观看| 久久成人18免费观看| 丁香桃色午夜亚洲一区二区三区| 99re视频精品| 欧美日韩精品免费观看视频| 精品乱人伦一区二区三区| 国产精品美女久久久久久久久| 亚洲精品欧美综合四区| 三级亚洲高清视频| 欧美专区日韩专区| 91精品一区二区三区久久久久久| 欧美精品一区二区三区在线播放| 中文字幕一区二区三区四区不卡| 亚洲一区在线看| 国产精品一区久久久久| 色94色欧美sute亚洲线路一久 | 日韩视频在线永久播放| 国产日韩三级在线| 亚洲一区二区不卡免费| 色噜噜夜夜夜综合网| 欧美zozo另类异族| 亚洲激情五月婷婷| 国产一区视频网站| 欧美三级电影精品| 国产嫩草影院久久久久| 婷婷综合另类小说色区| 不卡区在线中文字幕| 18成人在线观看| 亚洲成国产人片在线观看| 高清beeg欧美| 精品国产成人系列| 亚洲成人免费影院| 高清不卡在线观看| 欧美刺激午夜性久久久久久久| 中文一区二区完整视频在线观看 | 中文字幕不卡三区| 亚洲大片精品永久免费| 99精品国产热久久91蜜凸| 欧美大片一区二区| 免费在线观看成人| 欧美一二三四区在线| 青青草97国产精品免费观看无弹窗版| 岛国精品一区二区| 中文字幕欧美区| 色综合久久天天| 亚洲天堂2014| 欧美不卡在线视频| 免费在线观看一区二区三区| 高清成人免费视频| 欧美日韩一级二级| 成人欧美一区二区三区| 91色.com| 亚洲成人免费视频| 欧美一区二区国产| 国产剧情一区二区三区| 国产精品欧美久久久久一区二区| 国产精品69久久久久水密桃 | 国产欧美日韩在线看| 久久久久久久久久久99999| 中文字幕中文字幕在线一区 | 中文在线一区二区| 久久精品99久久久|