mirror of
https://github.com/torvalds/linux.git
synced 2024-11-11 06:31:49 +00:00
ima: store address of template_fmt_copy in a pointer before calling strsep
This patch stores the address of the 'template_fmt_copy' variable in a new variable, called 'template_fmt_ptr', so that the latter is passed as an argument of strsep() instead of the former. This modification is needed in order to correctly free the memory area referenced by 'template_fmt_copy' (strsep() modifies the pointer of the passed string). Signed-off-by: Roberto Sassu <roberto.sassu@polito.it> Reported-by: Sebastian Ott <sebott@linux.vnet.ibm.com> Signed-off-by: Mimi Zohar <zohar@us.ibm.com> Signed-off-by: James Morris <james.l.morris@oracle.com>
This commit is contained in:
parent
dc1ccc4815
commit
af91706d5d
@ -110,7 +110,7 @@ static int template_desc_init_fields(const char *template_fmt,
|
|||||||
struct ima_template_field ***fields,
|
struct ima_template_field ***fields,
|
||||||
int *num_fields)
|
int *num_fields)
|
||||||
{
|
{
|
||||||
char *c, *template_fmt_copy;
|
char *c, *template_fmt_copy, *template_fmt_ptr;
|
||||||
int template_num_fields = template_fmt_size(template_fmt);
|
int template_num_fields = template_fmt_size(template_fmt);
|
||||||
int i, result = 0;
|
int i, result = 0;
|
||||||
|
|
||||||
@ -127,7 +127,9 @@ static int template_desc_init_fields(const char *template_fmt,
|
|||||||
result = -ENOMEM;
|
result = -ENOMEM;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
for (i = 0; (c = strsep(&template_fmt_copy, "|")) != NULL &&
|
|
||||||
|
template_fmt_ptr = template_fmt_copy;
|
||||||
|
for (i = 0; (c = strsep(&template_fmt_ptr, "|")) != NULL &&
|
||||||
i < template_num_fields; i++) {
|
i < template_num_fields; i++) {
|
||||||
struct ima_template_field *f = lookup_template_field(c);
|
struct ima_template_field *f = lookup_template_field(c);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user