diff options
| -rw-r--r-- | net/ipv4/tcp_output.c | 6 | ||||
| -rw-r--r-- | net/key/af_key.c | 17 |
2 files changed, 6 insertions, 17 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index a61a3e3082ae..d65d17bb2a09 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
| @@ -646,11 +646,7 @@ static void tcp_set_skb_tso_segs(struct sock *sk, struct sk_buff *skb, unsigned | |||
| 646 | skb_shinfo(skb)->gso_size = 0; | 646 | skb_shinfo(skb)->gso_size = 0; |
| 647 | skb_shinfo(skb)->gso_type = 0; | 647 | skb_shinfo(skb)->gso_type = 0; |
| 648 | } else { | 648 | } else { |
| 649 | unsigned int factor; | 649 | skb_shinfo(skb)->gso_segs = DIV_ROUND_UP(skb->len, mss_now); |
| 650 | |||
| 651 | factor = skb->len + (mss_now - 1); | ||
| 652 | factor /= mss_now; | ||
| 653 | skb_shinfo(skb)->gso_segs = factor; | ||
| 654 | skb_shinfo(skb)->gso_size = mss_now; | 650 | skb_shinfo(skb)->gso_size = mss_now; |
| 655 | skb_shinfo(skb)->gso_type = sk->sk_gso_type; | 651 | skb_shinfo(skb)->gso_type = sk->sk_gso_type; |
| 656 | } | 652 | } |
diff --git a/net/key/af_key.c b/net/key/af_key.c index 5502df115a63..17b2a6927f01 100644 --- a/net/key/af_key.c +++ b/net/key/af_key.c | |||
| @@ -352,16 +352,14 @@ static int verify_address_len(void *p) | |||
| 352 | 352 | ||
| 353 | switch (addr->sa_family) { | 353 | switch (addr->sa_family) { |
| 354 | case AF_INET: | 354 | case AF_INET: |
| 355 | len = sizeof(*sp) + sizeof(*sin) + (sizeof(uint64_t) - 1); | 355 | len = DIV_ROUND_UP(sizeof(*sp) + sizeof(*sin), sizeof(uint64_t)); |
| 356 | len /= sizeof(uint64_t); | ||
| 357 | if (sp->sadb_address_len != len || | 356 | if (sp->sadb_address_len != len || |
| 358 | sp->sadb_address_prefixlen > 32) | 357 | sp->sadb_address_prefixlen > 32) |
| 359 | return -EINVAL; | 358 | return -EINVAL; |
| 360 | break; | 359 | break; |
| 361 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) | 360 | #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) |
| 362 | case AF_INET6: | 361 | case AF_INET6: |
| 363 | len = sizeof(*sp) + sizeof(*sin6) + (sizeof(uint64_t) - 1); | 362 | len = DIV_ROUND_UP(sizeof(*sp) + sizeof(*sin6), sizeof(uint64_t)); |
| 364 | len /= sizeof(uint64_t); | ||
| 365 | if (sp->sadb_address_len != len || | 363 | if (sp->sadb_address_len != len || |
| 366 | sp->sadb_address_prefixlen > 128) | 364 | sp->sadb_address_prefixlen > 128) |
| 367 | return -EINVAL; | 365 | return -EINVAL; |
| @@ -386,14 +384,9 @@ static int verify_address_len(void *p) | |||
| 386 | 384 | ||
| 387 | static inline int pfkey_sec_ctx_len(struct sadb_x_sec_ctx *sec_ctx) | 385 | static inline int pfkey_sec_ctx_len(struct sadb_x_sec_ctx *sec_ctx) |
| 388 | { | 386 | { |
| 389 | int len = 0; | 387 | return DIV_ROUND_UP(sizeof(struct sadb_x_sec_ctx) + |
| 390 | 388 | sec_ctx->sadb_x_ctx_len, | |
| 391 | len += sizeof(struct sadb_x_sec_ctx); | 389 | sizeof(uint64_t)); |
| 392 | len += sec_ctx->sadb_x_ctx_len; | ||
| 393 | len += sizeof(uint64_t) - 1; | ||
| 394 | len /= sizeof(uint64_t); | ||
| 395 | |||
| 396 | return len; | ||
| 397 | } | 390 | } |
| 398 | 391 | ||
| 399 | static inline int verify_sec_ctx_len(void *p) | 392 | static inline int verify_sec_ctx_len(void *p) |
