BSD: Fix the maximum size of a route(4) msg to 2048
The size of a single route(4) message cannot be derived from either the size of the AF_INET or AF_INET6 routing tables. Both could be empty or very large. As such revert back to a buffer size of 2048 which mirrors other programs which parse the routing socket. Signed-off-by: Roy Marples <roy@marples.name>
This commit is contained in:
parent
25c247684f
commit
b2b7f8dcfa
1 changed files with 3 additions and 28 deletions
|
@ -9,7 +9,6 @@
|
||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#include <sys/sysctl.h>
|
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "driver.h"
|
#include "driver.h"
|
||||||
|
@ -51,8 +50,6 @@ struct bsd_driver_global {
|
||||||
void *ctx;
|
void *ctx;
|
||||||
int sock; /* socket for 802.11 ioctls */
|
int sock; /* socket for 802.11 ioctls */
|
||||||
int route; /* routing socket for events */
|
int route; /* routing socket for events */
|
||||||
char *event_buf;
|
|
||||||
size_t event_buf_len;
|
|
||||||
struct dl_list ifaces; /* list of interfaces */
|
struct dl_list ifaces; /* list of interfaces */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -620,25 +617,10 @@ bsd_set_opt_ie(void *priv, const u8 *ie, size_t ie_len)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t
|
|
||||||
rtbuf_len(void)
|
|
||||||
{
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
int mib[6] = {CTL_NET, AF_ROUTE, 0, AF_INET, NET_RT_DUMP, 0};
|
|
||||||
|
|
||||||
if (sysctl(mib, 6, NULL, &len, NULL, 0) < 0) {
|
|
||||||
wpa_printf(MSG_WARNING, "%s failed: %s", __func__,
|
|
||||||
strerror(errno));
|
|
||||||
len = 2048;
|
|
||||||
}
|
|
||||||
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
bsd_wireless_event_receive(int sock, void *ctx, void *sock_ctx)
|
bsd_wireless_event_receive(int sock, void *ctx, void *sock_ctx)
|
||||||
{
|
{
|
||||||
|
char event_buf[2048]; /* max size of a single route(4) msg */
|
||||||
struct bsd_driver_global *global = sock_ctx;
|
struct bsd_driver_global *global = sock_ctx;
|
||||||
struct bsd_driver_data *drv;
|
struct bsd_driver_data *drv;
|
||||||
struct if_announcemsghdr *ifan;
|
struct if_announcemsghdr *ifan;
|
||||||
|
@ -650,7 +632,7 @@ bsd_wireless_event_receive(int sock, void *ctx, void *sock_ctx)
|
||||||
struct ieee80211_join_event *join;
|
struct ieee80211_join_event *join;
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
n = read(sock, global->event_buf, global->event_buf_len);
|
n = read(sock, event_buf, sizeof(event_buf));
|
||||||
if (n < 0) {
|
if (n < 0) {
|
||||||
if (errno != EINTR && errno != EAGAIN)
|
if (errno != EINTR && errno != EAGAIN)
|
||||||
wpa_printf(MSG_ERROR, "%s read() failed: %s",
|
wpa_printf(MSG_ERROR, "%s read() failed: %s",
|
||||||
|
@ -658,7 +640,7 @@ bsd_wireless_event_receive(int sock, void *ctx, void *sock_ctx)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
rtm = (struct rt_msghdr *) global->event_buf;
|
rtm = (struct rt_msghdr *) event_buf;
|
||||||
if (rtm->rtm_version != RTM_VERSION) {
|
if (rtm->rtm_version != RTM_VERSION) {
|
||||||
wpa_printf(MSG_DEBUG, "Invalid routing message version=%d",
|
wpa_printf(MSG_DEBUG, "Invalid routing message version=%d",
|
||||||
rtm->rtm_version);
|
rtm->rtm_version);
|
||||||
|
@ -1606,13 +1588,6 @@ bsd_global_init(void *ctx)
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
global->event_buf_len = rtbuf_len();
|
|
||||||
global->event_buf = os_malloc(global->event_buf_len);
|
|
||||||
if (global->event_buf == NULL) {
|
|
||||||
wpa_printf(MSG_ERROR, "%s: os_malloc() failed", __func__);
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
eloop_register_read_sock(global->route, bsd_wireless_event_receive,
|
eloop_register_read_sock(global->route, bsd_wireless_event_receive,
|
||||||
NULL, global);
|
NULL, global);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue