Bug #15876
closedRouting Advertisements daemon fails to start when configured with more than 3 RDNSS entries in a prefix
100%
Description
It's possible to silently crash the Router Advertisements daemon (radvd) with a DHCPv6 scope that is configured with four DNS servers. pfSense WebUI appears to accept this configuration and does not readily indicate that the daemon has failed or why.
Netgate Forums article: https://forum.netgate.com/topic/195340/radvd-crashes-with-4-dns-servers-in-dhcpv6-scope
Steps to reproduce:
1) Enter four DNS servers into a DHCPv6 scope.
2) Enable Router Advertisements for the subnet and check the option for "Mirror DHCPv6 DNS Configuration".
3) Save the configuration. It will appear to save OK, but radvd has crashed. Clients will lose the IPv6 RA in time.
4) Further changes can be made to Routing Advertisements in the pfSense WebUI, but the daemon crashes on each save.
The following error is emitted by radvd:
too many addresses in RDNSS section
It's been confirmed by Netgate that radvd only accepts three DNS servers.
Steps to resolve / work around:
1) Reduce the number of DNS servers in the scope to three or less. Save the configuration. Service will start running.
Expected behavior - There are a couple options:
1) Refuse to accept the configuration and output an error.
2) Accept the configuration and output a warning that only the first three DNS servers will be advertised.
Updated by Christopher Saia about 1 month ago
Found in the radvd log:
2024-11-26 14:52:43.494021-05:00 radvd 99792 exiting, failed to read config file 2024-11-26 14:52:43.493191-05:00 radvd 99792 too many addresses in RDNSS section
Updated by Jim Pingle about 1 month ago
- Project changed from pfSense Plus to pfSense
- Subject changed from Routing Advertisements crashes with 4 DNS servers in DHCPv6 scope to Routing Advertisements daemon fails to start when configured with more than 3 RDNSS entries in a prefix
- Category changed from Routing to IPv6 Router Advertisements (radvd/rtsold)
- Target version set to 2.8.0
- Affected Plus Version deleted (
24.11) - Plus Target Version set to 25.01
Updated by Marcos M about 1 month ago
- Status changed from New to In Progress
- Assignee set to Marcos M
We can enforce the limit to avoid the service start failure.
Updated by Marcos M about 1 month ago
- Status changed from In Progress to Feedback
- % Done changed from 0 to 100
Applied in changeset 490c8d19bb6d89d93df32c42705153cc5c995853.
Updated by Christopher Cope about 1 month ago
Applying the changes as a patch on
25.01-DEVELOPMENT (amd64) built on Tue Nov 26 14:49:00 UTC 2024 FreeBSD 15.0-CURRENT
results in the limit being enforced and radvd working as expected. Waiting to mark resolved until it included in a dev build.
Updated by Christopher Cope about 1 month ago
- Status changed from Feedback to Resolved
Fix is applied and working as expected on
25.01-DEVELOPMENT (amd64) built on Fri Dec 6 21:32:00 UTC 2024 FreeBSD 15.0-CURRENT
Marking resolved.
Updated by Jim Pingle 24 days ago
- Plus Target Version changed from 25.01 to 25.03