The patch titled Subject: initramfs: make dir_entry.name a flexible array member has been added to the -mm tree. Its filename is initramfs-make-dir_entryname-a-flexible-array-member.patch This patch should soon appear at https://ozlabs.org/~akpm/mmots/broken-out/initramfs-make-dir_entryname-a-flexible-array-member.patch and later at https://ozlabs.org/~akpm/mmotm/broken-out/initramfs-make-dir_entryname-a-flexible-array-member.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/process/submit-checklist.rst when testing your code *** The -mm tree is included into linux-next and is updated there every 3-4 working days ------------------------------------------------------ From: David Disseldorp <ddiss@xxxxxxx> Subject: initramfs: make dir_entry.name a flexible array member dir_entry.name is currently allocated via a separate kstrdup(). Change it to a flexible array member and allocate it along with struct dir_entry. Link: https://lkml.kernel.org/r/20220404093429.27570-3-ddiss@xxxxxxx Signed-off-by: David Disseldorp <ddiss@xxxxxxx> Acked-by: Christian Brauner <christian.brauner@xxxxxxxxxx> Cc: Al Viro <viro@xxxxxxxxxxxxxxxxxx> Cc: Martin Wilck <mwilck@xxxxxxxx> Cc: Matthew Wilcox (Oracle) <willy@xxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- init/initramfs.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) --- a/init/initramfs.c~initramfs-make-dir_entryname-a-flexible-array-member +++ a/init/initramfs.c @@ -130,17 +130,20 @@ static long __init do_utime(char *filena static __initdata LIST_HEAD(dir_list); struct dir_entry { struct list_head list; - char *name; time64_t mtime; + char name[]; }; static void __init dir_add(const char *name, time64_t mtime) { - struct dir_entry *de = kmalloc(sizeof(struct dir_entry), GFP_KERNEL); + size_t nlen = strlen(name) + 1; + struct dir_entry *de; + + de = kmalloc(sizeof(struct dir_entry) + nlen, GFP_KERNEL); if (!de) panic_show_mem("can't allocate dir_entry buffer"); INIT_LIST_HEAD(&de->list); - de->name = kstrdup(name, GFP_KERNEL); + strscpy(de->name, name, nlen); de->mtime = mtime; list_add(&de->list, &dir_list); } @@ -151,7 +154,6 @@ static void __init dir_utime(void) list_for_each_entry_safe(de, tmp, &dir_list, list) { list_del(&de->list); do_utime(de->name, de->mtime); - kfree(de->name); kfree(de); } } _ Patches currently in -mm which might be from ddiss@xxxxxxx are initramfs-refactor-do_header-cpio-magic-checks.patch initramfs-make-dir_entryname-a-flexible-array-member.patch initramfs-add-initramfs_preserve_mtime-kconfig-option.patch gen_init_cpio-fix-short-read-file-handling.patch gen_init_cpio-support-file-checksum-archiving.patch initramfs-support-cpio-extraction-with-file-checksums.patch