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
Unknown Object (File)
Tue, Nov 19, 6:17 PM
Unknown Object (File)
Sun, Nov 17, 8:08 AM
Unknown Object (File)
Fri, Nov 15, 3:03 AM
Unknown Object (File)
Thu, Nov 14, 6:36 AM
Unknown Object (File)
Wed, Nov 13, 8:33 PM
Unknown Object (File)
Tue, Nov 12, 6:32 PM
Unknown Object (File)
Apr 13 2024, 11:03 AM
Unknown Object (File)
Apr 7 2024, 9:58 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

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

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.