[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20191013201716.dwxfbr5kbueexomw@shells.gnugeneration.com>
Date: Sun, 13 Oct 2019 13:17:16 -0700
From: Vito Caputo <vcaputo@...garu.com>
To: Eric Dumazet <eric.dumazet@...il.com>
Cc: davem@...emloft.net, netdev@...r.kernel.org
Subject: Re: [PATCH] net: core: skbuff: skb_checksum_setup() drop err
On Sun, Oct 13, 2019 at 12:58:04PM -0700, Eric Dumazet wrote:
>
>
> On 10/12/19 5:30 PM, Vito Caputo wrote:
> > Return directly from all switch cases, no point in storing in err.
> >
> > Signed-off-by: Vito Caputo <vcaputo@...garu.com>
> > ---
> > net/core/skbuff.c | 15 +++------------
> > 1 file changed, 3 insertions(+), 12 deletions(-)
> >
> > diff --git a/net/core/skbuff.c b/net/core/skbuff.c
> > index f5f904f46893..c59b68a413b5 100644
> > --- a/net/core/skbuff.c
> > +++ b/net/core/skbuff.c
> > @@ -4888,23 +4888,14 @@ static int skb_checksum_setup_ipv6(struct sk_buff *skb, bool recalculate)
> > */
> > int skb_checksum_setup(struct sk_buff *skb, bool recalculate)
> > {
> > - int err;
> > -
> > switch (skb->protocol) {
> > case htons(ETH_P_IP):
> > - err = skb_checksum_setup_ipv4(skb, recalculate);
> > - break;
> > -
> > + return skb_checksum_setup_ipv4(skb, recalculate);
> > case htons(ETH_P_IPV6):
> > - err = skb_checksum_setup_ipv6(skb, recalculate);
> > - break;
> > -
> > + return skb_checksum_setup_ipv6(skb, recalculate);
> > default:
> > - err = -EPROTO;
> > - break;
> > + return -EPROTO;
> > }
> > -
> > - return err;
> > }
> > EXPORT_SYMBOL(skb_checksum_setup);
>
>
> We prefer having a single return point in a function, if possible.
>
> The err variable would make easier for debugging support,
> if say a developer needs to trace this function.
>
Except there are examples under net/core of precisely this pattern, e.g.:
---
__be32 flow_get_u32_src(const struct flow_keys *flow)
{
switch (flow->control.addr_type) {
case FLOW_DISSECTOR_KEY_IPV4_ADDRS:
return flow->addrs.v4addrs.src;
case FLOW_DISSECTOR_KEY_IPV6_ADDRS:
return (__force __be32)ipv6_addr_hash(
&flow->addrs.v6addrs.src);
case FLOW_DISSECTOR_KEY_TIPC:
return flow->addrs.tipckey.key;
default:
return 0;
}
}
EXPORT_SYMBOL(flow_get_u32_src);
__be32 flow_get_u32_dst(const struct flow_keys *flow)
{
switch (flow->control.addr_type) {
case FLOW_DISSECTOR_KEY_IPV4_ADDRS:
return flow->addrs.v4addrs.dst;
case FLOW_DISSECTOR_KEY_IPV6_ADDRS:
return (__force __be32)ipv6_addr_hash(
&flow->addrs.v6addrs.dst);
default:
return 0;
}
}
EXPORT_SYMBOL(flow_get_u32_dst);
---
This compact form of mapping is found throughout the kernel, is
skb_checksum_setup() special?
Regards,
Vito Caputo
Powered by blists - more mailing lists