Page MenuHomeFreeBSD

route: fix rtentry double free
ClosedPublic

Authored by kp on Jun 3 2025, 12:49 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jul 7, 7:14 AM
Unknown Object (File)
Mon, Jul 7, 2:16 AM
Unknown Object (File)
Sat, Jul 5, 9:36 AM
Unknown Object (File)
Fri, Jul 4, 9:48 AM
Unknown Object (File)
Tue, Jul 1, 6:14 AM
Unknown Object (File)
Mon, Jun 30, 10:46 PM
Unknown Object (File)
Fri, Jun 27, 10:40 PM
Unknown Object (File)
Tue, Jun 24, 5:55 PM

Details

Summary

add_route_flags() frees the rtentry on error when called with the RTM_F_CREATE
flag. Don't free the rtentry a second time.

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.Jun 3 2025, 12:49 PM
sys/net/route/route_ctl.c
676

Then isn't this access to freed rt_new?

sys/net/route/route_ctl.c
676

Good catch, I missed that one.
I think we can get away with using 'rt' here instead of 'rt_new', because rt_new should be a copy of rt.

Remove one more use of rt_new

This revision is now accepted and ready to land.Jun 5 2025, 7:36 AM
This revision was automatically updated to reflect the committed changes.