diff options
| author | Takashi Iwai <tiwai@suse.de> | 2009-12-15 04:29:06 -0500 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2009-12-15 04:29:06 -0500 | 
| commit | 709334c87dbdb44150ce436b3d13c814db0dcae9 (patch) | |
| tree | 5861a45f70c1f283720337abd864498f5afb3dbe /include/net/dst.h | |
| parent | 0d64b568fcd48b133721c1d322e7c51d85eb12df (diff) | |
| parent | f74890277a196949e4004fe2955e1d4fb3930f98 (diff) | |
Merge branch 'fixes' of git://git.alsa-project.org/alsa-kernel into for-linus
Diffstat (limited to 'include/net/dst.h')
| -rw-r--r-- | include/net/dst.h | 23 | 
1 files changed, 18 insertions, 5 deletions
| diff --git a/include/net/dst.h b/include/net/dst.h index 5a900ddcf10d..387cb3cfde7e 100644 --- a/include/net/dst.h +++ b/include/net/dst.h | |||
| @@ -36,8 +36,7 @@ | |||
| 36 | 36 | ||
| 37 | struct sk_buff; | 37 | struct sk_buff; | 
| 38 | 38 | ||
| 39 | struct dst_entry | 39 | struct dst_entry { | 
| 40 | { | ||
| 41 | struct rcu_head rcu_head; | 40 | struct rcu_head rcu_head; | 
| 42 | struct dst_entry *child; | 41 | struct dst_entry *child; | 
| 43 | struct net_device *dev; | 42 | struct net_device *dev; | 
| @@ -111,6 +110,12 @@ dst_metric(const struct dst_entry *dst, int metric) | |||
| 111 | return dst->metrics[metric-1]; | 110 | return dst->metrics[metric-1]; | 
| 112 | } | 111 | } | 
| 113 | 112 | ||
| 113 | static inline u32 | ||
| 114 | dst_feature(const struct dst_entry *dst, u32 feature) | ||
| 115 | { | ||
| 116 | return (dst ? dst_metric(dst, RTAX_FEATURES) & feature : 0); | ||
| 117 | } | ||
| 118 | |||
| 114 | static inline u32 dst_mtu(const struct dst_entry *dst) | 119 | static inline u32 dst_mtu(const struct dst_entry *dst) | 
| 115 | { | 120 | { | 
| 116 | u32 mtu = dst_metric(dst, RTAX_MTU); | 121 | u32 mtu = dst_metric(dst, RTAX_MTU); | 
| @@ -136,7 +141,7 @@ static inline void set_dst_metric_rtt(struct dst_entry *dst, int metric, | |||
| 136 | static inline u32 | 141 | static inline u32 | 
| 137 | dst_allfrag(const struct dst_entry *dst) | 142 | dst_allfrag(const struct dst_entry *dst) | 
| 138 | { | 143 | { | 
| 139 | int ret = dst_metric(dst, RTAX_FEATURES) & RTAX_FEATURE_ALLFRAG; | 144 | int ret = dst_feature(dst, RTAX_FEATURE_ALLFRAG); | 
| 140 | /* Yes, _exactly_. This is paranoia. */ | 145 | /* Yes, _exactly_. This is paranoia. */ | 
| 141 | barrier(); | 146 | barrier(); | 
| 142 | return ret; | 147 | return ret; | 
| @@ -222,11 +227,19 @@ static inline void dst_confirm(struct dst_entry *dst) | |||
| 222 | neigh_confirm(dst->neighbour); | 227 | neigh_confirm(dst->neighbour); | 
| 223 | } | 228 | } | 
| 224 | 229 | ||
| 225 | static inline void dst_negative_advice(struct dst_entry **dst_p) | 230 | static inline void dst_negative_advice(struct dst_entry **dst_p, | 
| 231 | struct sock *sk) | ||
| 226 | { | 232 | { | 
| 227 | struct dst_entry * dst = *dst_p; | 233 | struct dst_entry * dst = *dst_p; | 
| 228 | if (dst && dst->ops->negative_advice) | 234 | if (dst && dst->ops->negative_advice) { | 
| 229 | *dst_p = dst->ops->negative_advice(dst); | 235 | *dst_p = dst->ops->negative_advice(dst); | 
| 236 | |||
| 237 | if (dst != *dst_p) { | ||
| 238 | extern void sk_reset_txq(struct sock *sk); | ||
| 239 | |||
| 240 | sk_reset_txq(sk); | ||
| 241 | } | ||
| 242 | } | ||
| 230 | } | 243 | } | 
| 231 | 244 | ||
| 232 | static inline void dst_link_failure(struct sk_buff *skb) | 245 | static inline void dst_link_failure(struct sk_buff *skb) | 
