Re: [PATCH net-next] devlink: Delete not-used devlink APIs
From: Leon Romanovsky
Date: Thu Sep 16 2021 - 09:52:09 EST
On Thu, Sep 16, 2021 at 06:33:18AM -0700, Jakub Kicinski wrote:
> On Thu, 16 Sep 2021 13:38:33 +0300 Leon Romanovsky wrote:
> > From: Leon Romanovsky <leonro@xxxxxxxxxx>
> >
> > Devlink core exported generously the functions calls that were used
> > by netdevsim tests or not used at all.
> >
> > Delete such APIs with one exception - devlink_alloc_ns(). That function
> > should be spared from deleting because it is a special form of devlink_alloc()
> > needed for the netdevsim.
>
> Do you have a reason to do this or are you just cleaning up?
Yes for both questions. The trigger was my need to move parameter
notifications to be delayed till devlink register (like you asked). At
some point of time, I realized that devlink_*_publish() API is rubbish
and can be deleted (integrated into devlink_register). So I started to
cleanup as much as possible.
>
> The fmsg functions are not actually removed, just unexported.
> Are there out of tree drivers abusing them?
I don't know, but exported symbols pollute symbols table and the less we
have there, the better will be for everyone.
>
> The port_param functions are "symmetric" with the global param
> ones. Removing them makes the API look somewhat incomplete.
There is no value in having "complete" API that no one uses.
>
> Obviously the general guidance is that we shouldn't export
> functions which have no upstream users but that applies to
> meaningful APIs. For all practical purposes this is just a
> sliver of an API, completeness gives nice warm feelings.
It is misleading, I have much more warm feeling when I see API that is
used. Once it will be needed, the next developer will copy/paste it
pretty fast.
>
> Anyway, just curious what made you do this. I wouldn't do it
> myself but neither am I substantially opposed.
Move of devlink_register() to be last command in the devlink init flow
and removal of devlink_*_publish() calls as an outcome of that.
Thanks