Re: [PATCH] ima: store address of template_fmt_copy in a pointerbefore calling strsep

From: Sebastian Ott
Date: Wed Nov 27 2013 - 10:02:41 EST




On Wed, 27 Nov 2013, Roberto Sassu wrote:
> 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).
>

This one helped. Thanks!

Sebastian

> Signed-off-by: Roberto Sassu <roberto.sassu@xxxxxxxxx>
> ---
> security/integrity/ima/ima_template.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/security/integrity/ima/ima_template.c b/security/integrity/ima/ima_template.c
> index 913e192..635695f 100644
> --- a/security/integrity/ima/ima_template.c
> +++ b/security/integrity/ima/ima_template.c
> @@ -110,7 +110,7 @@ static int template_desc_init_fields(const char *template_fmt,
> struct ima_template_field ***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 i, result = 0;
>
> @@ -127,7 +127,9 @@ static int template_desc_init_fields(const char *template_fmt,
> result = -ENOMEM;
> 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++) {
> struct ima_template_field *f = lookup_template_field(c);
>
> --
> 1.8.1.4
>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/