]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
isofs: replace __get_free_page() with kmalloc()
authorMike Rapoport (Microsoft) <rppt@kernel.org>
Sat, 23 May 2026 17:54:23 +0000 (20:54 +0300)
committerJan Kara <jack@suse.cz>
Mon, 25 May 2026 16:17:27 +0000 (18:17 +0200)
isofs_readdir() allocates a temporary buffer with __get_free_page().

kmalloc() is a better API for such use and it also provides better
scalability and more debugging possibilities.

Replace use of __get_free_page() with kmalloc().

Signed-off-by: Mike Rapoport (Microsoft) <rppt@kernel.org>
Link: https://patch.msgid.link/20260523-b4-fs-v1-11-275e36a83f0e@kernel.org
Signed-off-by: Jan Kara <jack@suse.cz>
fs/isofs/dir.c

index 2fd9948d606e9c92f3003bfbaa4f0271c750a93d..6d220eab531e5935f49aaacc807c5c6c55f9d22d 100644 (file)
@@ -13,6 +13,7 @@
  */
 #include <linux/gfp.h>
 #include <linux/filelock.h>
+#include <linux/slab.h>
 #include "isofs.h"
 
 int isofs_name_translate(struct iso_directory_record *de, char *new, struct inode *inode)
@@ -255,7 +256,7 @@ static int isofs_readdir(struct file *file, struct dir_context *ctx)
        struct iso_directory_record *tmpde;
        struct inode *inode = file_inode(file);
 
-       tmpname = (char *)__get_free_page(GFP_KERNEL);
+       tmpname = kmalloc(PAGE_SIZE, GFP_KERNEL);
        if (tmpname == NULL)
                return -ENOMEM;
 
@@ -263,7 +264,7 @@ static int isofs_readdir(struct file *file, struct dir_context *ctx)
 
        result = do_isofs_readdir(inode, file, ctx, tmpname, tmpde);
 
-       free_page((unsigned long) tmpname);
+       kfree(tmpname);
        return result;
 }