vlan: Move ifconfig helpers to a separate file
This removes final ioctl() use within vlan_init.c. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
59d6390440
commit
7c03c08229
4 changed files with 68 additions and 50 deletions
|
@ -175,6 +175,7 @@ ifdef CONFIG_NO_VLAN
|
||||||
L_CFLAGS += -DCONFIG_NO_VLAN
|
L_CFLAGS += -DCONFIG_NO_VLAN
|
||||||
else
|
else
|
||||||
OBJS += src/ap/vlan_init.c
|
OBJS += src/ap/vlan_init.c
|
||||||
|
OBJS += src/ap/vlan_ifconfig.c
|
||||||
OBJS += src/ap/vlan.c
|
OBJS += src/ap/vlan.c
|
||||||
ifdef CONFIG_FULL_DYNAMIC_VLAN
|
ifdef CONFIG_FULL_DYNAMIC_VLAN
|
||||||
# Define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
|
# Define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
|
||||||
|
|
|
@ -194,6 +194,7 @@ ifdef CONFIG_NO_VLAN
|
||||||
CFLAGS += -DCONFIG_NO_VLAN
|
CFLAGS += -DCONFIG_NO_VLAN
|
||||||
else
|
else
|
||||||
OBJS += ../src/ap/vlan_init.o
|
OBJS += ../src/ap/vlan_init.o
|
||||||
|
OBJS += ../src/ap/vlan_ifconfig.o
|
||||||
OBJS += ../src/ap/vlan.o
|
OBJS += ../src/ap/vlan.o
|
||||||
ifdef CONFIG_FULL_DYNAMIC_VLAN
|
ifdef CONFIG_FULL_DYNAMIC_VLAN
|
||||||
# Define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
|
# Define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
|
||||||
|
|
63
src/ap/vlan_ifconfig.c
Normal file
63
src/ap/vlan_ifconfig.c
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
/*
|
||||||
|
* hostapd / VLAN ifconfig helpers
|
||||||
|
* Copyright 2003, Instant802 Networks, Inc.
|
||||||
|
* Copyright 2005-2006, Devicescape Software, Inc.
|
||||||
|
* Copyright (c) 2009, Jouni Malinen <j@w1.fi>
|
||||||
|
*
|
||||||
|
* This software may be distributed under the terms of the BSD license.
|
||||||
|
* See README for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "utils/includes.h"
|
||||||
|
#include <net/if.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
|
||||||
|
#include "utils/common.h"
|
||||||
|
#include "vlan_util.h"
|
||||||
|
|
||||||
|
|
||||||
|
int ifconfig_helper(const char *if_name, int up)
|
||||||
|
{
|
||||||
|
int fd;
|
||||||
|
struct ifreq ifr;
|
||||||
|
|
||||||
|
if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
|
||||||
|
wpa_printf(MSG_ERROR, "VLAN: %s: socket(AF_INET,SOCK_STREAM) "
|
||||||
|
"failed: %s", __func__, strerror(errno));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
os_memset(&ifr, 0, sizeof(ifr));
|
||||||
|
os_strlcpy(ifr.ifr_name, if_name, IFNAMSIZ);
|
||||||
|
|
||||||
|
if (ioctl(fd, SIOCGIFFLAGS, &ifr) != 0) {
|
||||||
|
wpa_printf(MSG_ERROR, "VLAN: %s: ioctl(SIOCGIFFLAGS) failed "
|
||||||
|
"for interface %s: %s",
|
||||||
|
__func__, if_name, strerror(errno));
|
||||||
|
close(fd);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (up)
|
||||||
|
ifr.ifr_flags |= IFF_UP;
|
||||||
|
else
|
||||||
|
ifr.ifr_flags &= ~IFF_UP;
|
||||||
|
|
||||||
|
if (ioctl(fd, SIOCSIFFLAGS, &ifr) != 0) {
|
||||||
|
wpa_printf(MSG_ERROR, "VLAN: %s: ioctl(SIOCSIFFLAGS) failed "
|
||||||
|
"for interface %s (up=%d): %s",
|
||||||
|
__func__, if_name, up, strerror(errno));
|
||||||
|
close(fd);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int ifconfig_up(const char *if_name)
|
||||||
|
{
|
||||||
|
wpa_printf(MSG_DEBUG, "VLAN: Set interface %s up", if_name);
|
||||||
|
return ifconfig_helper(if_name, 1);
|
||||||
|
}
|
|
@ -9,6 +9,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "utils/includes.h"
|
#include "utils/includes.h"
|
||||||
|
#include <net/if.h>
|
||||||
|
/* Avoid conflicts due to NetBSD net/if.h if_type define with driver.h */
|
||||||
|
#undef if_type
|
||||||
|
|
||||||
#include "utils/common.h"
|
#include "utils/common.h"
|
||||||
#include "hostapd.h"
|
#include "hostapd.h"
|
||||||
|
@ -18,56 +21,6 @@
|
||||||
#include "vlan_init.h"
|
#include "vlan_init.h"
|
||||||
#include "vlan_util.h"
|
#include "vlan_util.h"
|
||||||
|
|
||||||
#include <net/if.h>
|
|
||||||
#include <sys/ioctl.h>
|
|
||||||
|
|
||||||
|
|
||||||
int ifconfig_helper(const char *if_name, int up)
|
|
||||||
{
|
|
||||||
int fd;
|
|
||||||
struct ifreq ifr;
|
|
||||||
|
|
||||||
if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
|
|
||||||
wpa_printf(MSG_ERROR, "VLAN: %s: socket(AF_INET,SOCK_STREAM) "
|
|
||||||
"failed: %s", __func__, strerror(errno));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
os_memset(&ifr, 0, sizeof(ifr));
|
|
||||||
os_strlcpy(ifr.ifr_name, if_name, IFNAMSIZ);
|
|
||||||
|
|
||||||
if (ioctl(fd, SIOCGIFFLAGS, &ifr) != 0) {
|
|
||||||
wpa_printf(MSG_ERROR, "VLAN: %s: ioctl(SIOCGIFFLAGS) failed "
|
|
||||||
"for interface %s: %s",
|
|
||||||
__func__, if_name, strerror(errno));
|
|
||||||
close(fd);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (up)
|
|
||||||
ifr.ifr_flags |= IFF_UP;
|
|
||||||
else
|
|
||||||
ifr.ifr_flags &= ~IFF_UP;
|
|
||||||
|
|
||||||
if (ioctl(fd, SIOCSIFFLAGS, &ifr) != 0) {
|
|
||||||
wpa_printf(MSG_ERROR, "VLAN: %s: ioctl(SIOCSIFFLAGS) failed "
|
|
||||||
"for interface %s (up=%d): %s",
|
|
||||||
__func__, if_name, up, strerror(errno));
|
|
||||||
close(fd);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
close(fd);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int ifconfig_up(const char *if_name)
|
|
||||||
{
|
|
||||||
wpa_printf(MSG_DEBUG, "VLAN: Set interface %s up", if_name);
|
|
||||||
return ifconfig_helper(if_name, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int vlan_if_add(struct hostapd_data *hapd, struct hostapd_vlan *vlan,
|
static int vlan_if_add(struct hostapd_data *hapd, struct hostapd_vlan *vlan,
|
||||||
int existsok)
|
int existsok)
|
||||||
|
|
Loading…
Reference in a new issue