ipv6: help __ip6_finish_output() inlining
authorPavel Begunkov <asml.silence@gmail.com>
Thu, 28 Apr 2022 10:58:47 +0000 (11:58 +0100)
committerDavid S. Miller <davem@davemloft.net>
Sat, 30 Apr 2022 11:58:45 +0000 (12:58 +0100)
There are two callers of __ip6_finish_output(), both are in
ip6_finish_output(). We can combine the call sites into one and handle
return code after, that will inline __ip6_finish_output().

Note, error handling under NET_XMIT_CN will only return 0 if
__ip6_finish_output() succeded, and in this case it return 0.
Considering that NET_XMIT_SUCCESS is 0, it'll be returning exactly the
same result for it as before.

Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv6/ip6_output.c

index 1f3d777e7694cd813e92ef122bb4ebdd23e4df53..bda1d9f76f7ee515b2e90010acafdf5290c165b5 100644 (file)
@@ -198,7 +198,6 @@ static int ip6_finish_output(struct net *net, struct sock *sk, struct sk_buff *s
        ret = BPF_CGROUP_RUN_PROG_INET_EGRESS(sk, skb);
        switch (ret) {
        case NET_XMIT_SUCCESS:
-               return __ip6_finish_output(net, sk, skb);
        case NET_XMIT_CN:
                return __ip6_finish_output(net, sk, skb) ? : ret;
        default: