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:
committed by
Matthias Männich
parent
3158d3f337
commit
de4c6d5b31
+20
-3
@@ -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;
|
||||
|
||||
Reference in New Issue
Block a user