Page MenuHomeFreeBSD

netlink: fix adding an interface route
ClosedPublic

Authored by takahiro.kurosawa_gmail.com on Aug 5 2023, 5:23 AM.
Tags
None
Referenced Files
F123381423: D41330.id130698.diff
Mon, Jul 14, 6:22 AM
Unknown Object (File)
Sun, Jul 13, 4:14 AM
Unknown Object (File)
Sat, Jul 12, 12:11 PM
Unknown Object (File)
Tue, Jul 8, 6:30 AM
Unknown Object (File)
Thu, Jul 3, 2:50 AM
Unknown Object (File)
Tue, Jul 1, 8:56 AM
Unknown Object (File)
Sat, Jun 21, 11:57 AM
Unknown Object (File)
Thu, Jun 19, 6:39 PM

Details

Summary

"route add <host> -iface <netif>" for a netif without an IPv4/IPv6 address
fails with EINVAL. Need to use a link-level ifaddr for gw if an ifaddr
for dst is not found as the rtsock-based implementation does.

Test Plan

ifconfig tun0 create
ifconfig tun0 up
route add 192.0.2.1 -iface tun0

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

@melifaro does this change seem correct to you?

PR: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=275341
Fixes:

# ifconfig wg1 create
# ifconfig wg1 up
# route -n add 10.2.0.0/24 -interface wg1

This looks good to me.

I have a separate patch that introduces v4 and v6 atf-sh test cases for sbin/route that I will land along with D41436 when it gets a v6 test case soon.

This revision is now accepted and ready to land.Nov 28 2023, 6:00 PM
This revision was automatically updated to reflect the committed changes.