summaryrefslogtreecommitdiffstats
path: root/include/net
diff options
context:
space:
mode:
authorYunsheng Lin <linyunsheng@huawei.com>2022-12-12 11:24:26 +0800
committerJakub Kicinski <kuba@kernel.org>2022-12-12 15:04:39 -0800
commitd7b061b80ee6f91aa0b89daa3069802d7ea4c57f (patch)
treeb1a46f2adf5457bcb90d083bd2df3da05bcf3c0a /include/net
parent8f18655c49eb6abfe7fc3711d32d23b311fbc6a6 (diff)
downloadlinux-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.h8
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);