FROMGIT: module: Factor out elf_validity_cache_strtab

This patch only moves the existing strtab population to a function.
Validation comes in a following patch, this is split out to make the new
validation checks more clearly separated.

Change-Id: Idbce6e31c98c0641a2cc3cf6ae85a6a38ac843bd
Signed-off-by: Matthew Maurer <mmaurer@google.com>
Reviewed-by: Sami Tolvanen <samitolvanen@google.com>
Signed-off-by: Luis Chamberlain <mcgrof@kernel.org>
(cherry picked from commit 837031e052af32c747906238fb1feb87778e4fe0 kernel/git/modules/linux.git modules-next)
Bug: 347787665
This commit is contained in:
Matthew Maurer
2024-10-15 23:16:44 +00:00
committed by Matthias Männich
parent 3158d3f337
commit de4c6d5b31
+20 -3
View File
@@ -2125,6 +2125,23 @@ static int elf_validity_cache_index(struct load_info *info, int flags)
return 0;
}
/**
* elf_validity_cache_strtab() - Cache symbol string table
* @info: Load info to read from and update.
* Must have &load_info->sechdrs and &load_info->secstrings populated.
* Must have &load_info->index populated.
*
* Return: 0 on success, negative error code if a check failed.
*/
static int elf_validity_cache_strtab(struct load_info *info)
{
Elf_Shdr *str_shdr = &info->sechdrs[info->index.str];
char *strtab = (char *)info->hdr + str_shdr->sh_offset;
info->strtab = strtab;
return 0;
}
/*
* Check userspace passed ELF module against our expectations, and cache
* useful variables for further processing as we go.
@@ -2158,9 +2175,9 @@ static int elf_validity_cache_copy(struct load_info *info, int flags)
err = elf_validity_cache_index(info, flags);
if (err < 0)
return err;
/* Sets internal strings. */
info->strtab = (char *)info->hdr + info->sechdrs[info->index.str].sh_offset;
err = elf_validity_cache_strtab(info);
if (err < 0)
return err;
/* This is temporary: point mod into copy of data. */
info->mod = (void *)info->hdr + info->sechdrs[info->index.mod].sh_offset;