Hi Frank,

On Tue, Feb 18, 2025 at 10:30:44PM -0500, Frank Ch. Eigler wrote:
> Planning to commit this shortly:
> 
> commit a71bac67f4705b84368b71f5ece54deedaa1abf1 (HEAD -> master1)
> Author: Frank Ch. Eigler <f...@redhat.com>
> Date:   Tue Feb 18 22:09:12 2025 -0500
> 
>     debuginfod-client: correct invalid free() in failed ima path
>     
>     debuginfod-find with a failed signature configuration was found on f41
>     glibc (2.40) to sometimes leave invalid addresses in a sscanf("%ms", &ptr)
>     pointer in case of error, leading to an invalid free() during cleanup.

This does sounds like a bug in glibc sscanf. I cannot find a
description of what exactly happens with 'm' modifier allocated
buffers on error. So I can imagine a double free if sscanf frees the
buffer on error. But returning a bogus pointer? That seems a bug. If
we aren't guaranteed a valid pointer (or NULL) then this could easily
lead to memory leaks.

I would at least report it to glibc to see if this is intentional.

Cheers,

Mark

Reply via email to