Page MenuHomeFreeBSD

nvmecontrol wdc: Don't pass a bogus pointer to free().
ClosedPublic

Authored by jhb on Sep 29 2022, 10:39 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Sep 30, 1:39 PM
Unknown Object (File)
Sun, Sep 22, 9:32 AM
Unknown Object (File)
Thu, Sep 19, 8:44 PM
Unknown Object (File)
Wed, Sep 18, 10:25 PM
Unknown Object (File)
Mon, Sep 16, 5:43 AM
Unknown Object (File)
Sun, Sep 15, 5:35 AM
Unknown Object (File)
Sun, Sep 15, 5:35 AM
Unknown Object (File)
Sun, Sep 15, 5:35 AM
Subscribers

Details

Summary

wdc_get_dui_log_size allocates a buffer and then advances the
returned pointer. Passing this advanced pointer to free() is UB,
so save the original pointer to pass to free() instead.

Reported by: GCC 12 -Wfree-nonheap-object

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable