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)
Sat, Dec 6, 10:12 AM
Unknown Object (File)
Mon, Dec 1, 10:00 AM
Unknown Object (File)
Thu, Nov 27, 11:54 PM
Unknown Object (File)
Wed, Nov 26, 10:38 PM
Unknown Object (File)
Sun, Nov 23, 3:13 PM
Unknown Object (File)
Nov 20 2025, 2:23 AM
Unknown Object (File)
Nov 9 2025, 2:18 AM
Unknown Object (File)
Nov 7 2025, 2:41 PM
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