⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 driver_bsd.c

📁 hostapd无线AP工具
💻 C
📖 第 1 页 / 共 2 页
字号:
}static int bsd_flush(void *priv){	u8 allsta[IEEE80211_ADDR_LEN];	memset(allsta, 0xff, IEEE80211_ADDR_LEN);	return bsd_sta_deauth(priv, allsta, IEEE80211_REASON_AUTH_LEAVE);}static intbsd_read_sta_driver_data(void *priv, struct hostap_sta_driver_data *data,					u8 *addr){	struct bsd_driver_data *drv = priv;	struct ieee80211req_sta_stats stats;	memcpy(stats.is_u.macaddr, addr, IEEE80211_ADDR_LEN);	if (get80211var(drv, IEEE80211_IOC_STA_STATS, &stats, sizeof(stats)) > 0) {		/* XXX? do packets counts include non-data frames? */		data->rx_packets = stats.is_stats.ns_rx_data;		data->rx_bytes = stats.is_stats.ns_rx_bytes;		data->tx_packets = stats.is_stats.ns_tx_data;		data->tx_bytes = stats.is_stats.ns_tx_bytes;	}	return 0;}static intbsd_set_opt_ie(void *priv, const u8 *ie, size_t ie_len){	/*	 * Do nothing; we setup parameters at startup that define the	 * contents of the beacon information element.	 */	return 0;}static intbsd_sta_deauth(void *priv, u8 *addr, int reason_code){	struct bsd_driver_data *drv = priv;	hostapd *hapd = drv->hapd;	struct ieee80211req_mlme mlme;	HOSTAPD_DEBUG(HOSTAPD_DEBUG_MINIMAL,		"%s: addr=%s reason_code=%d\n",		__func__, ether_sprintf(addr), reason_code);	mlme.im_op = IEEE80211_MLME_DEAUTH;	mlme.im_reason = reason_code;	memcpy(mlme.im_macaddr, addr, IEEE80211_ADDR_LEN);	return set80211var(priv, IEEE80211_IOC_MLME, &mlme, sizeof(mlme));}static intbsd_sta_disassoc(void *priv, u8 *addr, int reason_code){	struct bsd_driver_data *drv = priv;	hostapd *hapd = drv->hapd;	struct ieee80211req_mlme mlme;	HOSTAPD_DEBUG(HOSTAPD_DEBUG_MINIMAL,		"%s: addr=%s reason_code=%d\n",		__func__, ether_sprintf(addr), reason_code);	mlme.im_reason = reason_code;	memcpy(mlme.im_macaddr, addr, IEEE80211_ADDR_LEN);	return set80211var(priv, IEEE80211_IOC_MLME, &mlme, sizeof(mlme));}static intbsd_del_sta(struct bsd_driver_data *drv, u8 addr[IEEE80211_ADDR_LEN]){	struct hostapd_data *hapd = drv->hapd;	struct hostapd_config *conf = hapd->conf;	struct sta_info *sta;	hostapd_logger(hapd, addr, HOSTAPD_MODULE_IEEE80211,		HOSTAPD_LEVEL_INFO, "deassociated");	sta = ap_get_sta(hapd, addr);	if (sta != NULL) {		sta->flags &= ~WLAN_STA_ASSOC;		if (conf->wpa)			wpa_sm_event(hapd, sta, WPA_DISASSOC);		sta->acct_terminate_cause = RADIUS_ACCT_TERMINATE_CAUSE_USER_REQUEST;		ieee802_1x_set_port_enabled(hapd, sta, 0);		ap_free_sta(hapd, sta);	}	return 0;}static intbsd_new_sta(struct bsd_driver_data *drv, u8 addr[IEEE80211_ADDR_LEN]){	struct hostapd_data *hapd = drv->hapd;	struct hostapd_config *conf = hapd->conf;	struct sta_info *sta;	struct ieee80211req_wpaie ie;	int new_assoc, ielen, res;	hostapd_logger(hapd, addr, HOSTAPD_MODULE_IEEE80211,		HOSTAPD_LEVEL_INFO, "associated");	sta = ap_sta_add(hapd, addr);	if (sta == NULL)		return -1;	/*	 * Fetch and validate any negotiated WPA/RSN parameters.	 */	if (conf->wpa) {		memset(&ie, 0, sizeof(ie));		memcpy(ie.wpa_macaddr, addr, IEEE80211_ADDR_LEN);		if (get80211var(drv, IEEE80211_IOC_WPAIE, &ie, sizeof(ie)) < 0) {			printf("Failed to get WPA/RSN information element.\n");			return -1;		/* XXX not right */		}		ielen = ie.wpa_ie[1];		if (ielen == 0) {			printf("No WPA/RSN information element for station!\n");			return -1;		/* XXX not right */		}		ielen += 2;		res = wpa_validate_wpa_ie(hapd, sta, ie.wpa_ie, ielen,				ie.wpa_ie[0] == WLAN_EID_RSN ?				    HOSTAPD_WPA_VERSION_WPA2 :				    HOSTAPD_WPA_VERSION_WPA);		if (res != WPA_IE_OK) {			printf("WPA/RSN information element rejected? "				"(res %u)\n", res);			return -1;		}		if (sta->wpa_ie != NULL)			free(sta->wpa_ie);		sta->wpa_ie = malloc(ielen);		if (sta->wpa_ie == NULL) {			printf("No memory for WPA/RSN information element!\n");			return -1;		}		memcpy(sta->wpa_ie, ie.wpa_ie, ielen);		sta->wpa_ie_len = ielen;	} else {		if (sta->wpa_ie != NULL)			free(sta->wpa_ie);		sta->wpa_ie = NULL;		sta->wpa_ie_len = 0;	}	/*	 * Now that the internal station state is setup	 * kick the authenticator into action.	 */	new_assoc = (sta->flags & WLAN_STA_ASSOC) == 0;	sta->flags |= WLAN_STA_ASSOC;	if (new_assoc) {		if (conf->wpa)			wpa_sm_event(hapd, sta, WPA_ASSOC);		hostapd_new_assoc_sta(hapd, sta);	} else {		if (conf->wpa)			wpa_sm_event(hapd, sta, WPA_REAUTH);	}	ieee802_1x_notify_port_enabled(sta->eapol_sm, 1);	return 0;}#include <net/route.h>#include <net80211/ieee80211_freebsd.h>static voidbsd_wireless_event_receive(int sock, void *ctx, void *sock_ctx){	struct bsd_driver_data *drv = ctx;	struct hostapd_data *hapd = drv->hapd;	char buf[2048];	struct if_announcemsghdr *ifan;	struct rt_msghdr *rtm;	struct ieee80211_michael_event *mic;	struct ieee80211_join_event *join;	struct ieee80211_leave_event *leave;	int n;	n = read(sock, buf, sizeof(buf));	if (n < 0) {		if (errno != EINTR && errno != EAGAIN)			perror("read(PF_ROUTE)");		return;	}	rtm = (struct rt_msghdr *) buf;	if (rtm->rtm_version != RTM_VERSION) {		wpa_printf(MSG_DEBUG, "Routing message version %d not "			"understood\n", rtm->rtm_version);		return;	}	ifan = (struct if_announcemsghdr *) rtm;	switch (rtm->rtm_type) {	case RTM_IEEE80211:		switch (ifan->ifan_what) {		case RTM_IEEE80211_ASSOC:		case RTM_IEEE80211_REASSOC:		case RTM_IEEE80211_DISASSOC:		case RTM_IEEE80211_SCAN:			break;		case RTM_IEEE80211_LEAVE:			leave = (struct ieee80211_leave_event *) &ifan[1];			bsd_del_sta(drv, leave->iev_addr);			break;		case RTM_IEEE80211_JOIN:#ifdef RTM_IEEE80211_REJOIN		case RTM_IEEE80211_REJOIN:#endif			join = (struct ieee80211_join_event *) &ifan[1];			bsd_new_sta(drv, join->iev_addr);			break;		case RTM_IEEE80211_REPLAY:			/* ignore */			break;		case RTM_IEEE80211_MICHAEL:			mic = (struct ieee80211_michael_event *) &ifan[1];			wpa_printf(MSG_DEBUG,				"Michael MIC failure wireless event: "				"keyix=%u src_addr=" MACSTR, mic->iev_keyix,				MAC2STR(mic->iev_src));			ieee80211_michael_mic_failure(hapd, mic->iev_src, 1);			break;		}		break;	}}static intbsd_wireless_event_init(void *priv){	struct bsd_driver_data *drv = priv;	int s;	drv->wext_sock = -1;	s = socket(PF_ROUTE, SOCK_RAW, 0);	if (s < 0) {		perror("socket(PF_ROUTE,SOCK_RAW)");		return -1;	}	eloop_register_read_sock(s, bsd_wireless_event_receive, drv, NULL);	drv->wext_sock = s;	return 0;}static voidbsd_wireless_event_deinit(void *priv){	struct bsd_driver_data *drv = priv;	if (drv != NULL) {		if (drv->wext_sock < 0)			return;		eloop_unregister_read_sock(drv->wext_sock);		close(drv->wext_sock);	}}static intbsd_send_eapol(void *priv, u8 *addr, u8 *data, size_t data_len, int encrypt){	struct bsd_driver_data *drv = priv;	hostapd *hapd = drv->hapd;	unsigned char buf[3000];	unsigned char *bp = buf;	struct l2_ethhdr *eth;	size_t len;	int status;	/*	 * Prepend the Etherent header.  If the caller left us	 * space at the front we could just insert it but since	 * we don't know we copy to a local buffer.  Given the frequency	 * and size of frames this probably doesn't matter.	 */	len = data_len + sizeof(struct l2_ethhdr);	if (len > sizeof(buf)) {		bp = malloc(len);		if (bp == NULL) {			printf("EAPOL frame discarded, cannot malloc temp "				"buffer of size %u!\n", len);			return -1;		}	}	eth = (struct l2_ethhdr *) bp;	memcpy(eth->h_dest, addr, ETH_ALEN);	memcpy(eth->h_source, drv->hapd->own_addr, ETH_ALEN);	eth->h_proto = htons(ETH_P_EAPOL);	memcpy(eth+1, data, data_len);	if (HOSTAPD_DEBUG_COND(HOSTAPD_DEBUG_MSGDUMPS))		hostapd_hexdump("TX EAPOL", bp, len);	status = l2_packet_send(drv->sock_xmit, bp, len);	if (bp != buf)		free(bp);	return status;}static voidhandle_read(void *ctx, unsigned char *src_addr, unsigned char *buf, size_t len){	struct bsd_driver_data *drv = ctx;	hostapd *hapd = drv->hapd;	struct sta_info *sta;	sta = ap_get_sta(hapd, src_addr);	if (!sta || !(sta->flags & WLAN_STA_ASSOC)) {		printf("Data frame from not associated STA %s\n",		       ether_sprintf(src_addr));		/* XXX cannot happen */		return;	}	ieee802_1x_receive(hapd, src_addr, buf, len);}static intbsd_get_ssid(void *priv, u8 *buf, int len){	struct bsd_driver_data *drv = priv;	hostapd *hapd = drv->hapd;	int ssid_len = get80211var(priv, IEEE80211_IOC_SSID, buf, len);	HOSTAPD_DEBUG(HOSTAPD_DEBUG_MINIMAL, "%s: ssid=\"%.*s\"\n",		__func__, ssid_len, buf);	return ssid_len;}static intbsd_set_ssid(void *priv, u8 *buf, int len){	struct bsd_driver_data *drv = priv;	hostapd *hapd = drv->hapd;	HOSTAPD_DEBUG(HOSTAPD_DEBUG_MINIMAL, "%s: ssid=\"%.*s\"\n",		__func__, len, buf);	return set80211var(priv, IEEE80211_IOC_SSID, buf, len);}static intbsd_init(struct hostapd_data *hapd){	struct bsd_driver_data *drv;	drv = malloc(sizeof(struct bsd_driver_data));	if (drv == NULL) {		printf("Could not allocate memory for bsd driver data\n");		goto bad;	}	memset(drv, 0, sizeof(*drv));	drv->ops = bsd_driver_ops;	drv->hapd = hapd;	drv->ioctl_sock = socket(PF_INET, SOCK_DGRAM, 0);	if (drv->ioctl_sock < 0) {		perror("socket[PF_INET,SOCK_DGRAM]");		goto bad;	}	memcpy(drv->iface, hapd->conf->iface, sizeof(drv->iface));	drv->sock_xmit = l2_packet_init(drv->iface, NULL, ETH_P_EAPOL,				handle_read, drv);	if (drv->sock_xmit == NULL)		goto bad;	if (l2_packet_get_own_addr(drv->sock_xmit, hapd->own_addr))		goto bad;	bsd_set_iface_flags(drv, 0);	/* mark down during setup */	hapd->driver = &drv->ops;	return 0;bad:	if (drv->sock_xmit != NULL)		l2_packet_deinit(drv->sock_xmit);	if (drv->ioctl_sock >= 0)		close(drv->ioctl_sock);	if (drv != NULL)		free(drv);	return -1;}static voidbsd_deinit(void *priv){	struct bsd_driver_data *drv = priv;	drv->hapd->driver = NULL;	(void) bsd_set_iface_flags(drv, 0);	if (drv->ioctl_sock >= 0)		close(drv->ioctl_sock);	if (drv->sock_xmit != NULL)		l2_packet_deinit(drv->sock_xmit);	free(drv);}static const struct driver_ops bsd_driver_ops = {	.name			= "bsd",	.init			= bsd_init,	.deinit			= bsd_deinit,	.set_ieee8021x		= bsd_set_ieee8021x,	.set_privacy		= bsd_set_privacy,	.set_encryption		= bsd_set_key,	.get_seqnum		= bsd_get_seqnum,	.flush			= bsd_flush,	.set_generic_elem	= bsd_set_opt_ie,	.wireless_event_init	= bsd_wireless_event_init,	.wireless_event_deinit	= bsd_wireless_event_deinit,	.set_sta_authorized	= bsd_set_sta_authorized,	.read_sta_data		= bsd_read_sta_driver_data,	.send_eapol		= bsd_send_eapol,	.sta_disassoc		= bsd_sta_disassoc,	.sta_deauth		= bsd_sta_deauth,	.set_ssid		= bsd_set_ssid,	.get_ssid		= bsd_get_ssid,};void bsd_driver_register(void){	driver_register(bsd_driver_ops.name, &bsd_driver_ops);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -