]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
net: move sk_validate_xmit_skb() to net/core/dev.c
authorDaniel Zahka <daniel.zahka@gmail.com>
Wed, 17 Sep 2025 00:09:33 +0000 (17:09 -0700)
committerPaolo Abeni <pabeni@redhat.com>
Thu, 18 Sep 2025 10:32:06 +0000 (12:32 +0200)
Move definition of sk_validate_xmit_skb() from net/core/sock.c to
net/core/dev.c.

This change is in preparation of the next patch, where
sk_validate_xmit_skb() will need to cast sk to a tcp_timewait_sock *,
and access member fields. Including linux/tcp.h from linux/sock.h
creates a circular dependency, and dev.c is the only current call site
of this function.

Reviewed-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: Daniel Zahka <daniel.zahka@gmail.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Link: https://patch.msgid.link/20250917000954.859376-7-daniel.zahka@gmail.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
include/net/sock.h
net/core/dev.c

index d1d3d36e39ae66180444d7c465f51a9f5f1d72b9..bf92029a88d6df0b438e93de06e40fa866c32d20 100644 (file)
@@ -2960,28 +2960,6 @@ sk_requests_wifi_status(struct sock *sk)
        return sk && sk_fullsock(sk) && sock_flag(sk, SOCK_WIFI_STATUS);
 }
 
-/* Checks if this SKB belongs to an HW offloaded socket
- * and whether any SW fallbacks are required based on dev.
- * Check decrypted mark in case skb_orphan() cleared socket.
- */
-static inline struct sk_buff *sk_validate_xmit_skb(struct sk_buff *skb,
-                                                  struct net_device *dev)
-{
-#ifdef CONFIG_SOCK_VALIDATE_XMIT
-       struct sock *sk = skb->sk;
-
-       if (sk && sk_fullsock(sk) && sk->sk_validate_xmit_skb) {
-               skb = sk->sk_validate_xmit_skb(sk, dev, skb);
-       } else if (unlikely(skb_is_decrypted(skb))) {
-               pr_warn_ratelimited("unencrypted skb with no associated socket - dropping\n");
-               kfree_skb(skb);
-               skb = NULL;
-       }
-#endif
-
-       return skb;
-}
-
 /* This helper checks if a socket is a LISTEN or NEW_SYN_RECV
  * SYNACK messages can be attached to either ones (depending on SYNCOOKIE)
  */
index 2522d9d8f0e4d0da3488afe98f46501eeecd5b51..384e59d7e715ee44d6eb16aabce6d343541d1cf4 100644 (file)
@@ -3907,6 +3907,28 @@ sw_checksum:
 }
 EXPORT_SYMBOL(skb_csum_hwoffload_help);
 
+/* Checks if this SKB belongs to an HW offloaded socket
+ * and whether any SW fallbacks are required based on dev.
+ * Check decrypted mark in case skb_orphan() cleared socket.
+ */
+static struct sk_buff *sk_validate_xmit_skb(struct sk_buff *skb,
+                                           struct net_device *dev)
+{
+#ifdef CONFIG_SOCK_VALIDATE_XMIT
+       struct sock *sk = skb->sk;
+
+       if (sk && sk_fullsock(sk) && sk->sk_validate_xmit_skb) {
+               skb = sk->sk_validate_xmit_skb(sk, dev, skb);
+       } else if (unlikely(skb_is_decrypted(skb))) {
+               pr_warn_ratelimited("unencrypted skb with no associated socket - dropping\n");
+               kfree_skb(skb);
+               skb = NULL;
+       }
+#endif
+
+       return skb;
+}
+
 static struct sk_buff *validate_xmit_unreadable_skb(struct sk_buff *skb,
                                                    struct net_device *dev)
 {