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)
Fri, Nov 8, 10:18 PM
Unknown Object (File)
Fri, Nov 8, 10:13 PM
Unknown Object (File)
Sat, Nov 2, 5:32 AM
Unknown Object (File)
Fri, Nov 1, 1:36 PM
Unknown Object (File)
Oct 1 2024, 12:49 PM
Unknown Object (File)
Sep 24 2024, 7:14 PM
Unknown Object (File)
Sep 24 2024, 12:16 PM
Unknown Object (File)
Sep 24 2024, 1:09 AM

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.