Re: [PATCH 17/23] initramfs: switch initramfs unpacking to struct file based APIs

From: Linus Torvalds
Date: Tue Jul 14 2020 - 15:31:27 EST


On Tue, Jul 14, 2020 at 12:09 PM Christoph Hellwig <hch@xxxxxx> wrote:
>
> There is no good reason to mess with file descriptors from in-kernel
> code, switch the initramfs unpacking to struct file based write
> instead.

Looking at this diff, I realized this really should be cleaned up more.

+ wfile = filp_open(collected, openflags, mode);
> + if (IS_ERR(wfile))
> + return 0;
> +
> + vfs_fchown(wfile, uid, gid);
> + vfs_fchmod(wfile, mode);
> + if (body_len)
> + vfs_truncate(&wfile->f_path, body_len);
> + vcollected = kstrdup(collected, GFP_KERNEL);

That "vcollected" is ugly and broken, and seems oh-so-wrong.

Because it's only use is:


> - ksys_close(wfd);
> + fput(wfile);
> do_utime(vcollected, mtime);
> kfree(vcollected);

which should just have done the exact same thing that you did with
vfs_chown() and friends: we already have a "utimes_common()" that
takes a path, and it could have been made into "vfs_utimes()", and
then this whole vcollected confusion would go away and be replaced by

vfs_truncate(&wfile->f_path, mtime);

(ok, with all the "timespec64 t[2]" things going on that do_utime()
does now, but you get the idea).

Talk about de-crufting that initramfs unpacking..

But I don't hate this patch, I'm just pointing out that there's room
for improvement.

Linus