diff options
authorCy Schubert <cy@FreeBSD.org>2021-01-20 15:20:22 +0000
committerCy Schubert <cy@FreeBSD.org>2021-01-20 15:45:18 +0000
commitd70886d063166786ded0007af8cdcbf57b7b4827 (patch)
parentb9fdd1446cdaf396a63ef9bf31c55a8aa4a5fa31 (diff)
wpa_supplicant uses PF_ROUTE to return the routing table in order to
determine the length of the routing table buffer. As of 81728a538d24 wpa_supplicant is started before the routing table has been populated resulting in the length of zero to be returned. This causes wpa_supplicant to loop endlessly. (The workaround is to kill and restart wpa_supplicant as by the time it is restarted the routing table is populated.) (Personally, I was not able to reproduce this unless wlan0 was a member of lagg0. However, others experienced this problem on standalone wlan0.) PR: 252844 Submitted by: shu <ankohuu _ outlook.com> Reported by: shu <ankohuu _ outlook.com> Reviewed by: cy X-MFC with: 81728a538d24f483d0986850fa3f51d5d84d8f26 Differential Revision: https://reviews.freebsd.org/D28249
1 files changed, 1 insertions, 1 deletions
diff --git a/contrib/wpa/src/drivers/driver_bsd.c b/contrib/wpa/src/drivers/driver_bsd.c
index f99122e477c1..96cf066a7a46 100644
--- a/contrib/wpa/src/drivers/driver_bsd.c
+++ b/contrib/wpa/src/drivers/driver_bsd.c
@@ -648,7 +648,7 @@ rtbuf_len(void)
len = 2048;
- return len;
+ return (len == 0) ? 2048 : len;
#ifdef HOSTAPD