Re: [PATCH 04/24] fs: move the putname from filename_create to the callers
From: Linus Torvalds
Date: Mon Jul 20 2020 - 14:06:23 EST
On Mon, Jul 20, 2020 at 8:59 AM Christoph Hellwig <hch@xxxxxx> wrote:
>
> This allows reusing the struct filename for retries, and will also allow
> pushing the getname up the stack for a few places to allower for better
> handling of kernel space filenames.
I find this _very_ confusing.
Now the rule is that filename_create() does the putname() if it fails,
but not if it succeeds.
That's just all kinds of messed up.
It was already slightly confusing how "getname()" was paired with
"putname()", and how you didn't need to check for errors, but at least
it was easy to explain: "filename_create() will check errors and use
the name we got".
That slightly confusing calling convention made the code much more
compact, and nobody involved needed to do error checks on the name
etc.
Now that "slightly confusing" convention has gone from "slightly" to
"outright", and the whole advantage of the interface has completely
gone away, because now you not only need to do the putname() in the
caller, you need to do it _conditionally_.
So please don't do this.
The other patches also all make it *really* hard to follow when
putname() is done - because depending on the context, you have to do
it when returning an error, or when an error was not returned.
I really think this is a huge mistake. Don't do it this way. NAK NAK NAK.
Please instead of making this all completely messy and completely
impossible to follow the rule about exactly who does "putname()" and
under what conditions, just leave the slight duplication in place.
Duplicating simple helper routines is *good*. Complex and
hard-to-understand and non-intuitive rules are *bad*.
You're adding badness.
Linus