Re: [PATCH net] tun: fix ethtool_ops get_msglvl and set_msglvl handlers

From: Michal Kubecek
Date: Wed Mar 04 2020 - 01:57:45 EST


On Tue, Mar 03, 2020 at 02:59:16PM -0800, David Miller wrote:
> From: Michal Kubecek <mkubecek@xxxxxxx>
> Date: Tue, 3 Mar 2020 09:22:52 +0100 (CET)
>
> > The get_msglvl and setmsglvl handlers only work as expected if TUN_DEBUG
> > is defined (which required editing the source). Otherwise tun_get_msglvl()
> > returns -EOPNOTSUPP but as this handler is not supposed to return error
> > code, it is not recognized as one and passed to userspace as is, resulting
> > in bogus output of ethtool command. The set_msglvl handler ignores its
> > argument and does nothing if TUN_DEBUG is left undefined.
> >
> > The way to return EOPNOTSUPP to userspace for both requests is not to
> > provide these ethtool_ops callbacks at all if TUN_DEBUG is left undefined.
> >
> > Signed-off-by: Michal Kubecek <mkubecek@xxxxxxx>
>
> I agree with your analysis.
>
> But this TUN_DEBUG thing stands outside of what we let drivers do. Either
> this tracing is not so useful and can be deleted, or the tracing should
> be available unconditionally so that it can be turned on by the vast
> majority of users who do not edit the source.
>
> I suspect making the TUN_DEBUG code unconditional is that way to go here.

I started to think in this direction too and ended up with

- DBG1() macro checks a variable which is never set; it's also used
only in one place which doesn't seem to differ from others where
tun_debug() is used
- many tun_debug() calls can be dropped as they only inform about
entering a function and sometimes show some if its arguments; we
have ftrace and kprobes for that
- the rest should be rewritten to netif_info()
- the two tun_debug() in packet processing path could use netif_dbg()
to avoid overhead when not turned on

...which is where I stopped and went with the quick fix instead.

On the other hand, there is no rush, the issue seems to exist since
before git. And unlike some other drivers doing strange things for
debugging, tun is widely used so it deserves a cleanup.

I'll send a patch (or patches) with proper cleanup for net-next.

Michal