aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/ipv4/inet_fragment.c10
-rw-r--r--net/ipv4/ip_fragment.c17
-rw-r--r--net/ipv6/netfilter/nf_conntrack_reasm.c15
-rw-r--r--net/ipv6/reassembly.c17
4 files changed, 31 insertions, 28 deletions
diff --git a/net/ipv4/inet_fragment.c b/net/ipv4/inet_fragment.c
index 724d69aed031..93170bfcc22e 100644
--- a/net/ipv4/inet_fragment.c
+++ b/net/ipv4/inet_fragment.c
@@ -104,10 +104,10 @@ void inet_frag_kill(struct inet_frag_queue *fq, struct inet_frags *f)
104 if (del_timer(&fq->timer)) 104 if (del_timer(&fq->timer))
105 atomic_dec(&fq->refcnt); 105 atomic_dec(&fq->refcnt);
106 106
107 if (!(fq->last_in & COMPLETE)) { 107 if (!(fq->last_in & INET_FRAG_COMPLETE)) {
108 fq_unlink(fq, f); 108 fq_unlink(fq, f);
109 atomic_dec(&fq->refcnt); 109 atomic_dec(&fq->refcnt);
110 fq->last_in |= COMPLETE; 110 fq->last_in |= INET_FRAG_COMPLETE;
111 } 111 }
112} 112}
113 113
@@ -131,7 +131,7 @@ void inet_frag_destroy(struct inet_frag_queue *q, struct inet_frags *f,
131 struct sk_buff *fp; 131 struct sk_buff *fp;
132 struct netns_frags *nf; 132 struct netns_frags *nf;
133 133
134 BUG_TRAP(q->last_in & COMPLETE); 134 BUG_TRAP(q->last_in & INET_FRAG_COMPLETE);
135 BUG_TRAP(del_timer(&q->timer) == 0); 135 BUG_TRAP(del_timer(&q->timer) == 0);
136 136
137 /* Release all fragment data. */ 137 /* Release all fragment data. */
@@ -174,7 +174,7 @@ int inet_frag_evictor(struct netns_frags *nf, struct inet_frags *f)
174 read_unlock(&f->lock); 174 read_unlock(&f->lock);
175 175
176 spin_lock(&q->lock); 176 spin_lock(&q->lock);
177 if (!(q->last_in & COMPLETE)) 177 if (!(q->last_in & INET_FRAG_COMPLETE))
178 inet_frag_kill(q, f); 178 inet_frag_kill(q, f);
179 spin_unlock(&q->lock); 179 spin_unlock(&q->lock);
180 180
@@ -206,7 +206,7 @@ static struct inet_frag_queue *inet_frag_intern(struct netns_frags *nf,
206 if (qp->net == nf && f->match(qp, arg)) { 206 if (qp->net == nf && f->match(qp, arg)) {
207 atomic_inc(&qp->refcnt); 207 atomic_inc(&qp->refcnt);
208 write_unlock(&f->lock); 208 write_unlock(&f->lock);
209 qp_in->last_in |= COMPLETE; 209 qp_in->last_in |= INET_FRAG_COMPLETE;
210 inet_frag_put(qp_in, f); 210 inet_frag_put(qp_in, f);
211 return qp; 211 return qp;
212 } 212 }
diff --git a/net/ipv4/ip_fragment.c b/net/ipv4/ip_fragment.c
index fcb60e76b234..02ae470fe60c 100644
--- a/net/ipv4/ip_fragment.c
+++ b/net/ipv4/ip_fragment.c
@@ -194,7 +194,7 @@ static void ip_expire(unsigned long arg)
194 194
195 spin_lock(&qp->q.lock); 195 spin_lock(&qp->q.lock);
196 196
197 if (qp->q.last_in & COMPLETE) 197 if (qp->q.last_in & INET_FRAG_COMPLETE)
198 goto out; 198 goto out;
199 199
200 ipq_kill(qp); 200 ipq_kill(qp);
@@ -202,7 +202,7 @@ static void ip_expire(unsigned long arg)
202 IP_INC_STATS_BH(IPSTATS_MIB_REASMTIMEOUT); 202 IP_INC_STATS_BH(IPSTATS_MIB_REASMTIMEOUT);
203 IP_INC_STATS_BH(IPSTATS_MIB_REASMFAILS); 203 IP_INC_STATS_BH(IPSTATS_MIB_REASMFAILS);
204 204
205 if ((qp->q.last_in&FIRST_IN) && qp->q.fragments != NULL) { 205 if ((qp->q.last_in & INET_FRAG_FIRST_IN) && qp->q.fragments != NULL) {
206 struct sk_buff *head = qp->q.fragments; 206 struct sk_buff *head = qp->q.fragments;
207 struct net *net; 207 struct net *net;
208 208
@@ -301,7 +301,7 @@ static int ip_frag_queue(struct ipq *qp, struct sk_buff *skb)
301 int ihl, end; 301 int ihl, end;
302 int err = -ENOENT; 302 int err = -ENOENT;
303 303
304 if (qp->q.last_in & COMPLETE) 304 if (qp->q.last_in & INET_FRAG_COMPLETE)
305 goto err; 305 goto err;
306 306
307 if (!(IPCB(skb)->flags & IPSKB_FRAG_COMPLETE) && 307 if (!(IPCB(skb)->flags & IPSKB_FRAG_COMPLETE) &&
@@ -327,9 +327,9 @@ static int ip_frag_queue(struct ipq *qp, struct sk_buff *skb)
327 * or have different end, the segment is corrrupted. 327 * or have different end, the segment is corrrupted.
328 */ 328 */
329 if (end < qp->q.len || 329 if (end < qp->q.len ||
330 ((qp->q.last_in & LAST_IN) && end != qp->q.len)) 330 ((qp->q.last_in & INET_FRAG_LAST_IN) && end != qp->q.len))
331 goto err; 331 goto err;
332 qp->q.last_in |= LAST_IN; 332 qp->q.last_in |= INET_FRAG_LAST_IN;
333 qp->q.len = end; 333 qp->q.len = end;
334 } else { 334 } else {
335 if (end&7) { 335 if (end&7) {
@@ -339,7 +339,7 @@ static int ip_frag_queue(struct ipq *qp, struct sk_buff *skb)
339 } 339 }
340 if (end > qp->q.len) { 340 if (end > qp->q.len) {
341 /* Some bits beyond end -> corruption. */ 341 /* Some bits beyond end -> corruption. */
342 if (qp->q.last_in & LAST_IN) 342 if (qp->q.last_in & INET_FRAG_LAST_IN)
343 goto err; 343 goto err;
344 qp->q.len = end; 344 qp->q.len = end;
345 } 345 }
@@ -438,9 +438,10 @@ static int ip_frag_queue(struct ipq *qp, struct sk_buff *skb)
438 qp->q.meat += skb->len; 438 qp->q.meat += skb->len;
439 atomic_add(skb->truesize, &qp->q.net->mem); 439 atomic_add(skb->truesize, &qp->q.net->mem);
440 if (offset == 0) 440 if (offset == 0)
441 qp->q.last_in |= FIRST_IN; 441 qp->q.last_in |= INET_FRAG_FIRST_IN;
442 442
443 if (qp->q.last_in == (FIRST_IN | LAST_IN) && qp->q.meat == qp->q.len) 443 if (qp->q.last_in == (INET_FRAG_FIRST_IN | INET_FRAG_LAST_IN) &&
444 qp->q.meat == qp->q.len)
444 return ip_frag_reasm(qp, prev, dev); 445 return ip_frag_reasm(qp, prev, dev);
445 446
446 write_lock(&ip4_frags.lock); 447 write_lock(&ip4_frags.lock);
diff --git a/net/ipv6/netfilter/nf_conntrack_reasm.c b/net/ipv6/netfilter/nf_conntrack_reasm.c
index 2a0d698b24d5..ad8066200f9d 100644
--- a/net/ipv6/netfilter/nf_conntrack_reasm.c
+++ b/net/ipv6/netfilter/nf_conntrack_reasm.c
@@ -183,7 +183,7 @@ static void nf_ct_frag6_expire(unsigned long data)
183 183
184 spin_lock(&fq->q.lock); 184 spin_lock(&fq->q.lock);
185 185
186 if (fq->q.last_in & COMPLETE) 186 if (fq->q.last_in & INET_FRAG_COMPLETE)
187 goto out; 187 goto out;
188 188
189 fq_kill(fq); 189 fq_kill(fq);
@@ -225,7 +225,7 @@ static int nf_ct_frag6_queue(struct nf_ct_frag6_queue *fq, struct sk_buff *skb,
225 struct sk_buff *prev, *next; 225 struct sk_buff *prev, *next;
226 int offset, end; 226 int offset, end;
227 227
228 if (fq->q.last_in & COMPLETE) { 228 if (fq->q.last_in & INET_FRAG_COMPLETE) {
229 pr_debug("Allready completed\n"); 229 pr_debug("Allready completed\n");
230 goto err; 230 goto err;
231 } 231 }
@@ -252,11 +252,11 @@ static int nf_ct_frag6_queue(struct nf_ct_frag6_queue *fq, struct sk_buff *skb,
252 * or have different end, the segment is corrupted. 252 * or have different end, the segment is corrupted.
253 */ 253 */
254 if (end < fq->q.len || 254 if (end < fq->q.len ||
255 ((fq->q.last_in & LAST_IN) && end != fq->q.len)) { 255 ((fq->q.last_in & INET_FRAG_LAST_IN) && end != fq->q.len)) {
256 pr_debug("already received last fragment\n"); 256 pr_debug("already received last fragment\n");
257 goto err; 257 goto err;
258 } 258 }
259 fq->q.last_in |= LAST_IN; 259 fq->q.last_in |= INET_FRAG_LAST_IN;
260 fq->q.len = end; 260 fq->q.len = end;
261 } else { 261 } else {
262 /* Check if the fragment is rounded to 8 bytes. 262 /* Check if the fragment is rounded to 8 bytes.
@@ -271,7 +271,7 @@ static int nf_ct_frag6_queue(struct nf_ct_frag6_queue *fq, struct sk_buff *skb,
271 } 271 }
272 if (end > fq->q.len) { 272 if (end > fq->q.len) {
273 /* Some bits beyond end -> corruption. */ 273 /* Some bits beyond end -> corruption. */
274 if (fq->q.last_in & LAST_IN) { 274 if (fq->q.last_in & INET_FRAG_LAST_IN) {
275 pr_debug("last packet already reached.\n"); 275 pr_debug("last packet already reached.\n");
276 goto err; 276 goto err;
277 } 277 }
@@ -383,7 +383,7 @@ static int nf_ct_frag6_queue(struct nf_ct_frag6_queue *fq, struct sk_buff *skb,
383 */ 383 */
384 if (offset == 0) { 384 if (offset == 0) {
385 fq->nhoffset = nhoff; 385 fq->nhoffset = nhoff;
386 fq->q.last_in |= FIRST_IN; 386 fq->q.last_in |= INET_FRAG_FIRST_IN;
387 } 387 }
388 write_lock(&nf_frags.lock); 388 write_lock(&nf_frags.lock);
389 list_move_tail(&fq->q.lru_list, &nf_init_frags.lru_list); 389 list_move_tail(&fq->q.lru_list, &nf_init_frags.lru_list);
@@ -645,7 +645,8 @@ struct sk_buff *nf_ct_frag6_gather(struct sk_buff *skb)
645 goto ret_orig; 645 goto ret_orig;
646 } 646 }
647 647
648 if (fq->q.last_in == (FIRST_IN|LAST_IN) && fq->q.meat == fq->q.len) { 648 if (fq->q.last_in == (INET_FRAG_FIRST_IN | INET_FRAG_LAST_IN) &&
649 fq->q.meat == fq->q.len) {
649 ret_skb = nf_ct_frag6_reasm(fq, dev); 650 ret_skb = nf_ct_frag6_reasm(fq, dev);
650 if (ret_skb == NULL) 651 if (ret_skb == NULL)
651 pr_debug("Can't reassemble fragmented packets\n"); 652 pr_debug("Can't reassemble fragmented packets\n");
diff --git a/net/ipv6/reassembly.c b/net/ipv6/reassembly.c
index 4e1447634f36..7b247e3a16fe 100644
--- a/net/ipv6/reassembly.c
+++ b/net/ipv6/reassembly.c
@@ -202,7 +202,7 @@ static void ip6_frag_expire(unsigned long data)
202 202
203 spin_lock(&fq->q.lock); 203 spin_lock(&fq->q.lock);
204 204
205 if (fq->q.last_in & COMPLETE) 205 if (fq->q.last_in & INET_FRAG_COMPLETE)
206 goto out; 206 goto out;
207 207
208 fq_kill(fq); 208 fq_kill(fq);
@@ -217,7 +217,7 @@ static void ip6_frag_expire(unsigned long data)
217 rcu_read_unlock(); 217 rcu_read_unlock();
218 218
219 /* Don't send error if the first segment did not arrive. */ 219 /* Don't send error if the first segment did not arrive. */
220 if (!(fq->q.last_in&FIRST_IN) || !fq->q.fragments) 220 if (!(fq->q.last_in & INET_FRAG_FIRST_IN) || !fq->q.fragments)
221 goto out; 221 goto out;
222 222
223 /* 223 /*
@@ -265,7 +265,7 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
265 struct net_device *dev; 265 struct net_device *dev;
266 int offset, end; 266 int offset, end;
267 267
268 if (fq->q.last_in & COMPLETE) 268 if (fq->q.last_in & INET_FRAG_COMPLETE)
269 goto err; 269 goto err;
270 270
271 offset = ntohs(fhdr->frag_off) & ~0x7; 271 offset = ntohs(fhdr->frag_off) & ~0x7;
@@ -294,9 +294,9 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
294 * or have different end, the segment is corrupted. 294 * or have different end, the segment is corrupted.
295 */ 295 */
296 if (end < fq->q.len || 296 if (end < fq->q.len ||
297 ((fq->q.last_in & LAST_IN) && end != fq->q.len)) 297 ((fq->q.last_in & INET_FRAG_LAST_IN) && end != fq->q.len))
298 goto err; 298 goto err;
299 fq->q.last_in |= LAST_IN; 299 fq->q.last_in |= INET_FRAG_LAST_IN;
300 fq->q.len = end; 300 fq->q.len = end;
301 } else { 301 } else {
302 /* Check if the fragment is rounded to 8 bytes. 302 /* Check if the fragment is rounded to 8 bytes.
@@ -314,7 +314,7 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
314 } 314 }
315 if (end > fq->q.len) { 315 if (end > fq->q.len) {
316 /* Some bits beyond end -> corruption. */ 316 /* Some bits beyond end -> corruption. */
317 if (fq->q.last_in & LAST_IN) 317 if (fq->q.last_in & INET_FRAG_LAST_IN)
318 goto err; 318 goto err;
319 fq->q.len = end; 319 fq->q.len = end;
320 } 320 }
@@ -417,10 +417,11 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
417 */ 417 */
418 if (offset == 0) { 418 if (offset == 0) {
419 fq->nhoffset = nhoff; 419 fq->nhoffset = nhoff;
420 fq->q.last_in |= FIRST_IN; 420 fq->q.last_in |= INET_FRAG_FIRST_IN;
421 } 421 }
422 422
423 if (fq->q.last_in == (FIRST_IN | LAST_IN) && fq->q.meat == fq->q.len) 423 if (fq->q.last_in == (INET_FRAG_FIRST_IN | INET_FRAG_LAST_IN) &&
424 fq->q.meat == fq->q.len)
424 return ip6_frag_reasm(fq, prev, dev); 425 return ip6_frag_reasm(fq, prev, dev);
425 426
426 write_lock(&ip6_frags.lock); 427 write_lock(&ip6_frags.lock);