AP: Convert "dhcp_snoop" to use the generic "x_snoop"

Signed-off-by: Kyeyoon Park <kyeyoonp@qca.qualcomm.com>
This commit is contained in:
Kyeyoon Park 2014-10-31 18:18:35 -07:00 committed by Jouni Malinen
parent c127355cb8
commit 1d783762cf
2 changed files with 17 additions and 51 deletions

View file

@ -7,7 +7,6 @@
*/ */
#include "utils/includes.h" #include "utils/includes.h"
#include <linux/filter.h>
#include <linux/ip.h> #include <linux/ip.h>
#include <linux/udp.h> #include <linux/udp.h>
@ -16,6 +15,7 @@
#include "hostapd.h" #include "hostapd.h"
#include "sta_info.h" #include "sta_info.h"
#include "ap_drv_ops.h" #include "ap_drv_ops.h"
#include "x_snoop.h"
#include "dhcp_snoop.h" #include "dhcp_snoop.h"
struct bootp_pkt { struct bootp_pkt {
@ -132,22 +132,8 @@ static void handle_dhcp(void *ctx, const u8 *src_addr, const u8 *buf,
int dhcp_snoop_init(struct hostapd_data *hapd) int dhcp_snoop_init(struct hostapd_data *hapd)
{ {
struct hostapd_bss_config *conf = hapd->conf; hapd->sock_dhcp = x_snoop_get_l2_packet(hapd, handle_dhcp,
L2_PACKET_FILTER_DHCP);
if (!conf->isolate) {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: ap_isolate must be enabled for DHCP snooping");
return -1;
}
if (conf->bridge[0] == '\0') {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: Bridge must be configured for DHCP snooping");
return -1;
}
hapd->sock_dhcp = l2_packet_init(conf->bridge, NULL, ETH_P_ALL,
handle_dhcp, hapd, 1);
if (hapd->sock_dhcp == NULL) { if (hapd->sock_dhcp == NULL) {
wpa_printf(MSG_DEBUG, wpa_printf(MSG_DEBUG,
"dhcp_snoop: Failed to initialize L2 packet processing for DHCP packet: %s", "dhcp_snoop: Failed to initialize L2 packet processing for DHCP packet: %s",
@ -155,42 +141,11 @@ int dhcp_snoop_init(struct hostapd_data *hapd)
return -1; return -1;
} }
if (l2_packet_set_packet_filter(hapd->sock_dhcp,
L2_PACKET_FILTER_DHCP)) {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: Failed to set L2 packet filter for DHCP: %s",
strerror(errno));
return -1;
}
if (hostapd_drv_br_port_set_attr(hapd, DRV_BR_PORT_ATTR_HAIRPIN_MODE,
1)) {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: Failed to enable hairpin_mode on the bridge port");
return -1;
}
if (hostapd_drv_br_port_set_attr(hapd, DRV_BR_PORT_ATTR_PROXYARP, 1)) {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: Failed to enable proxyarp on the bridge port");
return -1;
}
if (hostapd_drv_br_set_net_param(hapd, DRV_BR_NET_PARAM_GARP_ACCEPT,
1)) {
wpa_printf(MSG_DEBUG,
"dhcp_snoop: Failed to enable accepting gratuitous ARP on the bridge");
return -1;
}
return 0; return 0;
} }
void dhcp_snoop_deinit(struct hostapd_data *hapd) void dhcp_snoop_deinit(struct hostapd_data *hapd)
{ {
hostapd_drv_br_set_net_param(hapd, DRV_BR_NET_PARAM_GARP_ACCEPT, 0);
hostapd_drv_br_port_set_attr(hapd, DRV_BR_PORT_ATTR_PROXYARP, 0);
hostapd_drv_br_port_set_attr(hapd, DRV_BR_PORT_ATTR_HAIRPIN_MODE, 0);
l2_packet_deinit(hapd->sock_dhcp); l2_packet_deinit(hapd->sock_dhcp);
} }

View file

@ -36,6 +36,7 @@
#include "dfs.h" #include "dfs.h"
#include "ieee802_11.h" #include "ieee802_11.h"
#include "bss_load.h" #include "bss_load.h"
#include "x_snoop.h"
#include "dhcp_snoop.h" #include "dhcp_snoop.h"
@ -314,6 +315,7 @@ static void hostapd_free_hapd_data(struct hostapd_data *hapd)
bss_load_update_deinit(hapd); bss_load_update_deinit(hapd);
dhcp_snoop_deinit(hapd); dhcp_snoop_deinit(hapd);
x_snoop_deinit(hapd);
#ifdef CONFIG_SQLITE #ifdef CONFIG_SQLITE
bin_clear_free(hapd->tmp_eap_user.identity, bin_clear_free(hapd->tmp_eap_user.identity,
@ -893,11 +895,20 @@ static int hostapd_setup_bss(struct hostapd_data *hapd, int first)
return -1; return -1;
} }
if (conf->proxy_arp && dhcp_snoop_init(hapd)) { if (conf->proxy_arp) {
wpa_printf(MSG_ERROR, "DHCP snooping initialization failed"); if (x_snoop_init(hapd)) {
wpa_printf(MSG_ERROR,
"Generic snooping infrastructure initialization failed");
return -1; return -1;
} }
if (dhcp_snoop_init(hapd)) {
wpa_printf(MSG_ERROR,
"DHCP snooping initialization failed");
return -1;
}
}
if (!hostapd_drv_none(hapd) && vlan_init(hapd)) { if (!hostapd_drv_none(hapd) && vlan_init(hapd)) {
wpa_printf(MSG_ERROR, "VLAN initialization failed."); wpa_printf(MSG_ERROR, "VLAN initialization failed.");
return -1; return -1;