Commit 17fc8084 authored by Andrea Righi's avatar Andrea Righi Committed by Linus Torvalds

module/decompress: use kvmalloc() consistently

We consistently switched from kmalloc() to vmalloc() in module
decompression to prevent potential memory allocation failures with large
modules, however vmalloc() is not as memory-efficient and fast as
kmalloc().

Since we don't know in general the size of the workspace required by the
decompression algorithm, it is more reasonable to use kvmalloc()
consistently, also considering that we don't have special memory
requirements here.
Suggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Tested-by: default avatarAndrea Righi <andrea.righi@canonical.com>
Signed-off-by: default avatarAndrea Righi <andrea.righi@canonical.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent ca219be0
...@@ -100,7 +100,7 @@ static ssize_t module_gzip_decompress(struct load_info *info, ...@@ -100,7 +100,7 @@ static ssize_t module_gzip_decompress(struct load_info *info,
s.next_in = buf + gzip_hdr_len; s.next_in = buf + gzip_hdr_len;
s.avail_in = size - gzip_hdr_len; s.avail_in = size - gzip_hdr_len;
s.workspace = vmalloc(zlib_inflate_workspacesize()); s.workspace = kvmalloc(zlib_inflate_workspacesize(), GFP_KERNEL);
if (!s.workspace) if (!s.workspace)
return -ENOMEM; return -ENOMEM;
...@@ -138,7 +138,7 @@ static ssize_t module_gzip_decompress(struct load_info *info, ...@@ -138,7 +138,7 @@ static ssize_t module_gzip_decompress(struct load_info *info,
out_inflate_end: out_inflate_end:
zlib_inflateEnd(&s); zlib_inflateEnd(&s);
out: out:
vfree(s.workspace); kvfree(s.workspace);
return retval; return retval;
} }
#elif defined(CONFIG_MODULE_COMPRESS_XZ) #elif defined(CONFIG_MODULE_COMPRESS_XZ)
...@@ -241,7 +241,7 @@ static ssize_t module_zstd_decompress(struct load_info *info, ...@@ -241,7 +241,7 @@ static ssize_t module_zstd_decompress(struct load_info *info,
} }
wksp_size = zstd_dstream_workspace_bound(header.windowSize); wksp_size = zstd_dstream_workspace_bound(header.windowSize);
wksp = vmalloc(wksp_size); wksp = kvmalloc(wksp_size, GFP_KERNEL);
if (!wksp) { if (!wksp) {
retval = -ENOMEM; retval = -ENOMEM;
goto out; goto out;
...@@ -284,7 +284,7 @@ static ssize_t module_zstd_decompress(struct load_info *info, ...@@ -284,7 +284,7 @@ static ssize_t module_zstd_decompress(struct load_info *info,
retval = new_size; retval = new_size;
out: out:
vfree(wksp); kvfree(wksp);
return retval; return retval;
} }
#else #else
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment