mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-22 15:02:32 +00:00
0cd478518f
Fixes a regression on spi flash devices (upstream commit 1583eaece6fa). Changelogs: * https://www.kernel.org/pub/linux/kernel/v4.x/ChangeLog-4.1.7 * https://www.kernel.org/pub/linux/kernel/v4.x/ChangeLog-4.1.8 * https://www.kernel.org/pub/linux/kernel/v4.x/ChangeLog-4.1.9 * https://www.kernel.org/pub/linux/kernel/v4.x/ChangeLog-4.1.10 096-ipv4-off-by-one-in-continuation-handling-in-proc-net.patch was applied upstream and dropped. Signed-off-by: Mathias Kresin <openwrt@kresin.me> [update from 4.1.9 to 4.1.10] Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de> SVN-Revision: 47104
31 lines
664 B
Diff
31 lines
664 B
Diff
--- a/net/netlink/af_netlink.c
|
|
+++ b/net/netlink/af_netlink.c
|
|
@@ -1775,27 +1775,7 @@ void netlink_detachskb(struct sock *sk,
|
|
|
|
static struct sk_buff *netlink_trim(struct sk_buff *skb, gfp_t allocation)
|
|
{
|
|
- int delta;
|
|
-
|
|
WARN_ON(skb->sk != NULL);
|
|
- if (netlink_skb_is_mmaped(skb))
|
|
- return skb;
|
|
-
|
|
- delta = skb->end - skb->tail;
|
|
- if (is_vmalloc_addr(skb->head) || delta * 2 < skb->truesize)
|
|
- return skb;
|
|
-
|
|
- if (skb_shared(skb)) {
|
|
- struct sk_buff *nskb = skb_clone(skb, allocation);
|
|
- if (!nskb)
|
|
- return skb;
|
|
- consume_skb(skb);
|
|
- skb = nskb;
|
|
- }
|
|
-
|
|
- if (!pskb_expand_head(skb, 0, -delta, allocation))
|
|
- skb->truesize -= delta;
|
|
-
|
|
return skb;
|
|
}
|
|
|