Page MenuHomeFreeBSD

libpfctl: fix memory leak
ClosedPublic

Authored by kp on May 27 2021, 9:48 AM.
Tags
None
Referenced Files
F93313115: D30492.id90167.diff
Sun, Sep 8, 9:05 PM
F93291062: D30492.id.diff
Sun, Sep 8, 6:11 PM
Unknown Object (File)
Sun, Sep 8, 3:09 AM
Unknown Object (File)
Tue, Sep 3, 3:25 AM
Unknown Object (File)
Mon, Sep 2, 8:47 PM
Unknown Object (File)
Mon, Sep 2, 10:52 AM
Unknown Object (File)
Thu, Aug 29, 3:48 PM
Unknown Object (File)
Mon, Aug 19, 9:01 AM
Subscribers

Details

Summary

When we create an nvlist and insert it into another nvlist we must
remember to destroy it. The nvlist_add_nvlist() function makes a copy,
just like nvlist_add_string() makes a copy of the string.

See also 4483fb47735c29408c72045469c9c4b3e549668b

MFC after: 3 days
Sponsored by: Rubicon Communications, LLC ("Netgate")

Diff Detail

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

Event Timeline

kp requested review of this revision.May 27 2021, 9:48 AM
scottl added a subscriber: scottl.

This looks like a deficiency in the API design, but I don't object to this change.

This revision is now accepted and ready to land.May 28 2021, 7:14 PM

This looks like a deficiency in the API design, but I don't object to this change.

You mean the nvlist API? Not really. This one is on me.
The API is consistent in copying data that's added to an nvlist with nvlist_add_*(). It does it with strings, and it also does it with nvlists. It does make sense, but I'd not thought of that when I originally wrote this code.

This revision was automatically updated to reflect the committed changes.