diff options
| author | Menglong Dong <[email protected]> | 2021-06-28 06:37:44 +0000 |
|---|---|---|
| committer | David S. Miller <[email protected]> | 2021-06-28 20:31:57 +0000 |
| commit | 0c6de0c943dbb42831bf7502eb5c007f71e752d2 (patch) | |
| tree | 6364734be857c1e028de3cd2e6f7a1a37721f18c /net/switchdev/switchdev.c | |
| parent | Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git (diff) | |
| download | kernel-0c6de0c943dbb42831bf7502eb5c007f71e752d2.tar.gz kernel-0c6de0c943dbb42831bf7502eb5c007f71e752d2.zip | |
net: tipc: fix FB_MTU eat two pages
FB_MTU is used in 'tipc_msg_build()' to alloc smaller skb when memory
allocation fails, which can avoid unnecessary sending failures.
The value of FB_MTU now is 3744, and the data size will be:
(3744 + SKB_DATA_ALIGN(sizeof(struct skb_shared_info)) + \
SKB_DATA_ALIGN(BUF_HEADROOM + BUF_TAILROOM + 3))
which is larger than one page(4096), and two pages will be allocated.
To avoid it, replace '3744' with a calculation:
(PAGE_SIZE - SKB_DATA_ALIGN(BUF_OVERHEAD) - \
SKB_DATA_ALIGN(sizeof(struct skb_shared_info)))
What's more, alloc_skb_fclone() will call SKB_DATA_ALIGN for data size,
and it's not necessary to make alignment for buf_size in
tipc_buf_acquire(). So, just remove it.
Fixes: 4c94cc2d3d57 ("tipc: fall back to smaller MTU if allocation of local send skb fails")
Signed-off-by: Menglong Dong <[email protected]>
Acked-by: Jon Maloy <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'net/switchdev/switchdev.c')
0 files changed, 0 insertions, 0 deletions
