diff options
author | Yunsheng Lin <linyunsheng@huawei.com> | 2022-12-12 11:24:26 +0800 |
---|---|---|
committer | Jakub Kicinski <kuba@kernel.org> | 2022-12-12 15:04:39 -0800 |
commit | d7b061b80ee6f91aa0b89daa3069802d7ea4c57f (patch) | |
tree | b1a46f2adf5457bcb90d083bd2df3da05bcf3c0a /include/net | |
parent | 8f18655c49eb6abfe7fc3711d32d23b311fbc6a6 (diff) | |
download | linux-d7b061b80ee6f91aa0b89daa3069802d7ea4c57f.tar.bz2 |
net: tso: inline tso_count_descs()
tso_count_descs() is a small function doing simple calculation,
and tso_count_descs() is used in fast path, so inline it to
reduce the overhead of calls.
Signed-off-by: Yunsheng Lin <linyunsheng@huawei.com>
Link: https://lore.kernel.org/r/20221212032426.16050-1-linyunsheng@huawei.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'include/net')
-rw-r--r-- | include/net/tso.h | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/include/net/tso.h b/include/net/tso.h index 62c98a9c60f1..e7e157ae0526 100644 --- a/include/net/tso.h +++ b/include/net/tso.h @@ -2,6 +2,7 @@ #ifndef _TSO_H #define _TSO_H +#include <linux/skbuff.h> #include <net/ip.h> #define TSO_HEADER_SIZE 256 @@ -16,7 +17,12 @@ struct tso_t { u32 tcp_seq; }; -int tso_count_descs(const struct sk_buff *skb); +/* Calculate the worst case buffer count */ +static inline int tso_count_descs(const struct sk_buff *skb) +{ + return skb_shinfo(skb)->gso_segs * 2 + skb_shinfo(skb)->nr_frags; +} + void tso_build_hdr(const struct sk_buff *skb, char *hdr, struct tso_t *tso, int size, bool is_last); void tso_build_data(const struct sk_buff *skb, struct tso_t *tso, int size); |