diff options
Diffstat (limited to 'include/net/ipv6.h')
| -rw-r--r-- | include/net/ipv6.h | 22 | 
1 files changed, 18 insertions, 4 deletions
| diff --git a/include/net/ipv6.h b/include/net/ipv6.h index 64d12e77719a..0810aa57c780 100644 --- a/include/net/ipv6.h +++ b/include/net/ipv6.h @@ -217,7 +217,7 @@ struct ipv6_txoptions {  };  struct ip6_flowlabel { -	struct ip6_flowlabel	*next; +	struct ip6_flowlabel __rcu *next;  	__be32			label;  	atomic_t		users;  	struct in6_addr		dst; @@ -238,9 +238,9 @@ struct ip6_flowlabel {  #define IPV6_FLOWLABEL_MASK	cpu_to_be32(0x000FFFFF)  struct ipv6_fl_socklist { -	struct ipv6_fl_socklist	*next; -	struct ip6_flowlabel	*fl; -	struct rcu_head		rcu; +	struct ipv6_fl_socklist	__rcu	*next; +	struct ip6_flowlabel		*fl; +	struct rcu_head			rcu;  };  extern struct ip6_flowlabel	*fl6_sock_lookup(struct sock *sk, __be32 label); @@ -320,6 +320,18 @@ static inline int ipv6_addr_src_scope(const struct in6_addr *addr)  	return __ipv6_addr_src_scope(__ipv6_addr_type(addr));  } +static inline bool __ipv6_addr_needs_scope_id(int type) +{ +	return type & IPV6_ADDR_LINKLOCAL || +	       (type & IPV6_ADDR_MULTICAST && +		(type & (IPV6_ADDR_LOOPBACK|IPV6_ADDR_LINKLOCAL))); +} + +static inline __u32 ipv6_iface_scope_id(const struct in6_addr *addr, int iface) +{ +	return __ipv6_addr_needs_scope_id(__ipv6_addr_type(addr)) ? iface : 0; +} +  static inline int ipv6_addr_cmp(const struct in6_addr *a1, const struct in6_addr *a2)  {  	return memcmp(a1, a2, sizeof(struct in6_addr)); @@ -466,6 +478,7 @@ struct ip6_create_arg {  	u32 user;  	const struct in6_addr *src;  	const struct in6_addr *dst; +	u8 ecn;  };  void ip6_frag_init(struct inet_frag_queue *q, void *a); @@ -485,6 +498,7 @@ struct frag_queue {  	int			iif;  	unsigned int		csum;  	__u16			nhoffset; +	u8			ecn;  };  void ip6_expire_frag_queue(struct net *net, struct frag_queue *fq, | 
