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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? neighbour.h

?? linux和2410結(jié)合開發(fā) 用他可以生成2410所需的zImage文件
?? H
字號:
#ifndef _NET_NEIGHBOUR_H#define _NET_NEIGHBOUR_H/* *	Generic neighbour manipulation * *	Authors: *	Pedro Roque		<roque@di.fc.ul.pt> *	Alexey Kuznetsov	<kuznet@ms2.inr.ac.ru> *//* The following flags & states are exported to user space,   so that they should be moved to include/linux/ directory. *//* *	Neighbor Cache Entry Flags */#define NTF_PROXY	0x08	/* == ATF_PUBL */#define NTF_ROUTER	0x80/* *	Neighbor Cache Entry States. */#define NUD_INCOMPLETE	0x01#define NUD_REACHABLE	0x02#define NUD_STALE	0x04#define NUD_DELAY	0x08#define NUD_PROBE	0x10#define NUD_FAILED	0x20/* Dummy states */#define NUD_NOARP	0x40#define NUD_PERMANENT	0x80#define NUD_NONE	0x00/* NUD_NOARP & NUD_PERMANENT are pseudostates, they never change   and make no address resolution or NUD.   NUD_PERMANENT is also cannot be deleted by garbage collectors. */#ifdef __KERNEL__#include <asm/atomic.h>#include <linux/skbuff.h>#define NUD_IN_TIMER	(NUD_INCOMPLETE|NUD_DELAY|NUD_PROBE)#define NUD_VALID	(NUD_PERMANENT|NUD_NOARP|NUD_REACHABLE|NUD_PROBE|NUD_STALE|NUD_DELAY)#define NUD_CONNECTED	(NUD_PERMANENT|NUD_NOARP|NUD_REACHABLE)struct neigh_parms{	struct neigh_parms *next;	int	(*neigh_setup)(struct neighbour *);	struct neigh_table *tbl;	int	entries;	void	*priv;	void	*sysctl_table;	int	base_reachable_time;	int	retrans_time;	int	gc_staletime;	int	reachable_time;	int	delay_probe_time;	int	queue_len;	int	ucast_probes;	int	app_probes;	int	mcast_probes;	int	anycast_delay;	int	proxy_delay;	int	proxy_qlen;	int	locktime;};struct neigh_statistics{	unsigned long allocs;	unsigned long res_failed;	unsigned long rcv_probes_mcast;	unsigned long rcv_probes_ucast;};struct neighbour{	struct neighbour	*next;	struct neigh_table	*tbl;	struct neigh_parms	*parms;	struct net_device		*dev;	unsigned long		used;	unsigned long		confirmed;	unsigned long		updated;	__u8			flags;	__u8			nud_state;	__u8			type;	__u8			dead;	atomic_t		probes;	rwlock_t		lock;	unsigned char		ha[(MAX_ADDR_LEN+sizeof(unsigned long)-1)&~(sizeof(unsigned long)-1)];	struct hh_cache		*hh;	atomic_t		refcnt;	int			(*output)(struct sk_buff *skb);	struct sk_buff_head	arp_queue;	struct timer_list	timer;	struct neigh_ops	*ops;	u8			primary_key[0];};struct neigh_ops{	int			family;	void			(*destructor)(struct neighbour *);	void			(*solicit)(struct neighbour *, struct sk_buff*);	void			(*error_report)(struct neighbour *, struct sk_buff*);	int			(*output)(struct sk_buff*);	int			(*connected_output)(struct sk_buff*);	int			(*hh_output)(struct sk_buff*);	int			(*queue_xmit)(struct sk_buff*);};struct pneigh_entry{	struct pneigh_entry	*next;	struct net_device		*dev;	u8			key[0];};#define NEIGH_HASHMASK		0x1F#define PNEIGH_HASHMASK		0xF/* *	neighbour table manipulation */struct neigh_table{	struct neigh_table	*next;	int			family;	int			entry_size;	int			key_len;	__u32			(*hash)(const void *pkey, const struct net_device *);	int			(*constructor)(struct neighbour *);	int			(*pconstructor)(struct pneigh_entry *);	void			(*pdestructor)(struct pneigh_entry *);	void			(*proxy_redo)(struct sk_buff *skb);	char			*id;	struct neigh_parms	parms;	/* HACK. gc_* shoul follow parms without a gap! */	int			gc_interval;	int			gc_thresh1;	int			gc_thresh2;	int			gc_thresh3;	unsigned long		last_flush;	struct timer_list 	gc_timer;	struct timer_list 	proxy_timer;	struct sk_buff_head	proxy_queue;	int			entries;	rwlock_t		lock;	unsigned long		last_rand;	struct neigh_parms	*parms_list;	kmem_cache_t		*kmem_cachep;	struct tasklet_struct	gc_task;	struct neigh_statistics	stats;	struct neighbour	*hash_buckets[NEIGH_HASHMASK+1];	struct pneigh_entry	*phash_buckets[PNEIGH_HASHMASK+1];};extern void			neigh_table_init(struct neigh_table *tbl);extern int			neigh_table_clear(struct neigh_table *tbl);extern struct neighbour *	neigh_lookup(struct neigh_table *tbl,					     const void *pkey,					     struct net_device *dev);extern struct neighbour *	neigh_create(struct neigh_table *tbl,					     const void *pkey,					     struct net_device *dev);extern void			neigh_destroy(struct neighbour *neigh);extern int			__neigh_event_send(struct neighbour *neigh, struct sk_buff *skb);extern int			neigh_update(struct neighbour *neigh, const u8 *lladdr, u8 new, int override, int arp);extern int			neigh_ifdown(struct neigh_table *tbl, struct net_device *dev);extern int			neigh_resolve_output(struct sk_buff *skb);extern int			neigh_connected_output(struct sk_buff *skb);extern int			neigh_compat_output(struct sk_buff *skb);extern struct neighbour 	*neigh_event_ns(struct neigh_table *tbl,						u8 *lladdr, void *saddr,						struct net_device *dev);extern struct neigh_parms	*neigh_parms_alloc(struct net_device *dev, struct neigh_table *tbl);extern void			neigh_parms_release(struct neigh_table *tbl, struct neigh_parms *parms);extern unsigned long		neigh_rand_reach_time(unsigned long base);extern void			pneigh_enqueue(struct neigh_table *tbl, struct neigh_parms *p,					       struct sk_buff *skb);extern struct pneigh_entry	*pneigh_lookup(struct neigh_table *tbl, const void *key, struct net_device *dev, int creat);extern int			pneigh_delete(struct neigh_table *tbl, const void *key, struct net_device *dev);struct netlink_callback;struct nlmsghdr;extern int neigh_dump_info(struct sk_buff *skb, struct netlink_callback *cb);extern int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg);extern int neigh_delete(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg);extern void neigh_app_ns(struct neighbour *n);extern int			neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p,						      int p_id, int pdev_id, char *p_name);extern void			neigh_sysctl_unregister(struct neigh_parms *p);/* *	Neighbour references */static inline void neigh_release(struct neighbour *neigh){	if (atomic_dec_and_test(&neigh->refcnt))		neigh_destroy(neigh);}static inline struct neighbour * neigh_clone(struct neighbour *neigh){	if (neigh)		atomic_inc(&neigh->refcnt);	return neigh;}#define neigh_hold(n)	atomic_inc(&(n)->refcnt)static inline void neigh_confirm(struct neighbour *neigh){	if (neigh)		neigh->confirmed = jiffies;}static inline int neigh_is_connected(struct neighbour *neigh){	return neigh->nud_state&NUD_CONNECTED;}static inline int neigh_is_valid(struct neighbour *neigh){	return neigh->nud_state&NUD_VALID;}static inline int neigh_event_send(struct neighbour *neigh, struct sk_buff *skb){	neigh->used = jiffies;	if (!(neigh->nud_state&(NUD_CONNECTED|NUD_DELAY|NUD_PROBE)))		return __neigh_event_send(neigh, skb);	return 0;}static inline struct neighbour *__neigh_lookup(struct neigh_table *tbl, const void *pkey, struct net_device *dev, int creat){	struct neighbour *n = neigh_lookup(tbl, pkey, dev);	if (n || !creat)		return n;	n = neigh_create(tbl, pkey, dev);	return IS_ERR(n) ? NULL : n;}static inline struct neighbour *__neigh_lookup_errno(struct neigh_table *tbl, const void *pkey,  struct net_device *dev){	struct neighbour *n = neigh_lookup(tbl, pkey, dev);	if (n)		return n;	return neigh_create(tbl, pkey, dev);}#endif#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久综合九色合综国产精品| 亚洲一区二区三区四区在线观看| 国产精品女人毛片| 五月综合激情日本mⅴ| 国产精品一级黄| 欧美日韩一区二区三区免费看| 久久久影视传媒| 日韩av一级片| 欧洲国内综合视频| 国产精品午夜免费| 国产在线精品视频| 日韩一级免费观看| 亚洲高清在线精品| 成人av网在线| 久久精品视频免费观看| 男女性色大片免费观看一区二区| 91在线高清观看| 26uuuu精品一区二区| 秋霞影院一区二区| 欧美撒尿777hd撒尿| 亚洲精品欧美二区三区中文字幕| 丰满放荡岳乱妇91ww| 精品国产乱码久久久久久久| 日韩高清欧美激情| 欧美中文字幕一区二区三区| 成人免费视频在线观看| 国产成人午夜99999| 久久人人97超碰com| 麻豆专区一区二区三区四区五区| 欧美日韩一区二区三区不卡 | 亚洲视频 欧洲视频| 丁香天五香天堂综合| 久久久久久免费| 国产一区三区三区| 久久久久国产精品麻豆ai换脸| 久久精品国内一区二区三区| 欧美一二三区在线| 免费美女久久99| 精品91自产拍在线观看一区| 久久99精品久久久| 久久久99久久| 成人免费视频国产在线观看| 中文字幕在线一区免费| 在线一区二区三区做爰视频网站| 一区二区激情视频| 欧美精品日韩一本| 久久国产精品99精品国产| 久久免费看少妇高潮| 国产69精品久久久久777| 国产精品国产三级国产专播品爱网 | 亚洲精品在线观看网站| 国产一区二区三区电影在线观看 | 奇米影视一区二区三区| 欧美不卡一区二区三区| 国产成人免费视频网站| 亚洲欧美激情插| 777亚洲妇女| 国产麻豆精品theporn| 国产精品久久久久aaaa| 欧美亚洲一区三区| 精品一二三四在线| 最新热久久免费视频| 欧美午夜在线观看| 狠狠色狠狠色综合日日91app| 欧美高清在线一区| 欧美美女视频在线观看| 国产一区视频导航| 亚洲网友自拍偷拍| 久久众筹精品私拍模特| 在线免费观看一区| 精品在线亚洲视频| 一区二区三区四区在线播放 | 精品嫩草影院久久| 不卡电影一区二区三区| 婷婷久久综合九色国产成人| 久久久精品天堂| 欧美日韩一区三区四区| 国产成人亚洲精品青草天美| 亚洲在线视频网站| 国产肉丝袜一区二区| 制服丝袜亚洲播放| 色综合中文字幕国产 | 亚洲激情自拍视频| 26uuu亚洲婷婷狠狠天堂| 色哟哟精品一区| 国产成人精品影院| 日产精品久久久久久久性色| 国产精品夫妻自拍| www久久精品| 欧美人妖巨大在线| 色噜噜久久综合| 国产成人av电影在线观看| 午夜精品久久久久久久久久久| 国产三区在线成人av| 91麻豆精品国产91久久久| 色综合天天天天做夜夜夜夜做| 精品一区二区三区在线播放视频| 亚洲一区二区三区激情| 国产精品久久国产精麻豆99网站| 精品国产sm最大网站| 欧美电影影音先锋| 欧美天堂一区二区三区| 色综合久久久久久久| 国产不卡视频一区二区三区| 久久国产成人午夜av影院| 香蕉成人伊视频在线观看| 国产精品白丝在线| 国产精品素人视频| 久久精品欧美日韩精品| 精品国一区二区三区| 日韩一二三区不卡| 欧美一级夜夜爽| 欧美一区二区三区婷婷月色| 欧美日韩中文字幕一区二区| 91成人在线精品| 欧美在线一二三| 欧美美女直播网站| 欧美精品日韩一本| 日韩精品综合一本久道在线视频| 欧美一区二区性放荡片| 日韩一级片在线观看| 欧美精品一区视频| 中文字幕乱码日本亚洲一区二区| 国产女人aaa级久久久级 | 一区二区三区四区视频精品免费| 自拍视频在线观看一区二区| 亚洲色图一区二区| 亚洲国产精品一区二区久久恐怖片 | 丁香一区二区三区| 99精品桃花视频在线观看| 成人av在线一区二区| 色综合久久精品| 欧美日韩国产不卡| 日韩午夜电影在线观看| 精品欧美乱码久久久久久1区2区| 久久久蜜桃精品| 国产精品久久久久久久久晋中 | 欧美一级夜夜爽| 国产午夜精品在线观看| 最新国产成人在线观看| 亚洲成人777| 国产乱码一区二区三区| 99v久久综合狠狠综合久久| 在线观看三级视频欧美| 日韩一卡二卡三卡四卡| 国产精品拍天天在线| 亚洲精品亚洲人成人网| 蜜桃视频免费观看一区| 福利电影一区二区| 欧美高清视频不卡网| 久久久www成人免费毛片麻豆 | 日本一不卡视频| 国产99久久久国产精品| 欧美亚一区二区| 久久综合久久综合久久综合| 日韩一区在线看| 麻豆一区二区三区| 色婷婷av一区二区三区之一色屋| 欧美一级黄色片| 亚洲欧美视频在线观看| 久久er精品视频| 欧美最猛黑人xxxxx猛交| 久久精品亚洲麻豆av一区二区 | 久久国产人妖系列| 在线视频一区二区三区| 久久免费视频一区| 日韩黄色一级片| 91在线观看下载| 久久久综合精品| 午夜不卡av免费| 99视频一区二区| 久久久不卡影院| 七七婷婷婷婷精品国产| 91免费版在线看| 国产视频一区不卡| 免费看欧美女人艹b| 91久久人澡人人添人人爽欧美| 久久影音资源网| 奇米在线7777在线精品| 欧美三级欧美一级| 亚洲精品菠萝久久久久久久| 高清不卡一二三区| 欧美本精品男人aⅴ天堂| 亚洲.国产.中文慕字在线| 一本色道**综合亚洲精品蜜桃冫| 久久久久久久久久久久久久久99 | 一区视频在线播放| 国产精品一区二区三区网站| 91精品国产高清一区二区三区蜜臀 | 国内精品久久久久影院色| 制服丝袜亚洲精品中文字幕| 亚洲精品日韩专区silk| www.成人网.com| 国产精品久久久久久久午夜片| 国产综合色精品一区二区三区| 日韩欧美激情四射| 麻豆国产精品视频| 精品国产一区二区三区四区四| 久久精品国产99国产精品| 日韩午夜电影av|