亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ieee80211_power.c

?? Linux下wifi實現
?? C
字號:
/*- * Copyright (c) 2001 Atsushi Onoe * Copyright (c) 2002-2005 Sam Leffler, Errno Consulting * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products *    derived from this software without specific prior written permission. * * Alternatively, this software may be distributed under the terms of the * GNU General Public License ("GPL") version 2 as published by the Free * Software Foundation. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * $Id: ieee80211_power.c 1637 2006-06-10 02:17:05Z mentor $ */#ifndef EXPORT_SYMTAB#define	EXPORT_SYMTAB#endif/* * IEEE 802.11 power save support. */#include <linux/config.h>#include <linux/version.h>#include <linux/module.h>#include <linux/skbuff.h>#include <linux/netdevice.h>#include <linux/etherdevice.h>#include "if_media.h"#include <net80211/ieee80211_var.h>#include <net80211/ieee80211_proto.h>static void ieee80211_set_tim(struct ieee80211_node *ni, int set);voidieee80211_power_attach(struct ieee80211com *ic){}voidieee80211_power_detach(struct ieee80211com *ic){}voidieee80211_power_vattach(struct ieee80211vap *vap){	if (vap->iv_opmode == IEEE80211_M_HOSTAP ||	    vap->iv_opmode == IEEE80211_M_IBSS) {		/* NB: driver should override */		vap->iv_set_tim = ieee80211_set_tim;	}}voidieee80211_power_latevattach(struct ieee80211vap *vap){	/*	 * Allocate these only if needed.  Beware that we	 * know adhoc mode doesn't support ATIM yet...	 */	if (vap->iv_opmode == IEEE80211_M_HOSTAP) {		vap->iv_tim_len = howmany(vap->iv_max_aid,8) * sizeof(u_int8_t);		MALLOC(vap->iv_tim_bitmap, u_int8_t *, vap->iv_tim_len,			M_DEVBUF, M_NOWAIT | M_ZERO);		if (vap->iv_tim_bitmap == NULL) {			printf("%s: no memory for TIM bitmap!\n", __func__);			/* XXX good enough to keep from crashing? */			vap->iv_tim_len = 0;		}	}}voidieee80211_power_vdetach(struct ieee80211vap *vap){	if (vap->iv_tim_bitmap != NULL) {		FREE(vap->iv_tim_bitmap, M_DEVBUF);		vap->iv_tim_bitmap = NULL;	}}/* * Clear any frames queued on a node's power save queue. * The number of frames that were present is returned. */intieee80211_node_saveq_drain(struct ieee80211_node *ni){	struct sk_buff *skb;	int qlen;	IEEE80211_NODE_SAVEQ_LOCK(ni);	qlen = skb_queue_len(&ni->ni_savedq);	while ((skb = __skb_dequeue(&ni->ni_savedq)) != NULL) {		ieee80211_free_node(ni);		dev_kfree_skb_any(skb);	}	IEEE80211_NODE_SAVEQ_UNLOCK(ni);	return qlen;}/* * Age frames on the power save queue. The aging interval is * 4 times the listen interval specified by the station.  This * number is factored into the age calculations when the frame * is placed on the queue.  We store ages as time differences * so we can check and/or adjust only the head of the list. * If a frame's age exceeds the threshold then discard it. * The number of frames discarded is returned so the caller * can check if it needs to adjust the tim. */intieee80211_node_saveq_age(struct ieee80211_node *ni){	int discard = 0;	/* XXX racey but good 'nuf? */	if (IEEE80211_NODE_SAVEQ_QLEN(ni) != 0) {#ifdef IEEE80211_DEBUG		struct ieee80211vap *vap = ni->ni_vap;#endif		struct sk_buff *skb;		IEEE80211_NODE_SAVEQ_LOCK(ni);		while ((skb = skb_peek(&ni->ni_savedq)) != NULL &&		     M_AGE_GET(skb) < IEEE80211_INACT_WAIT) {			IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,				"discard frame, age %u", M_AGE_GET(skb));			skb = __skb_dequeue(&ni->ni_savedq);			dev_kfree_skb_any(skb);			discard++;		}		if (skb != NULL)			M_AGE_SUB(skb, IEEE80211_INACT_WAIT);		IEEE80211_NODE_SAVEQ_UNLOCK(ni);		IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,			"discard %u frames for age", discard);		IEEE80211_NODE_STAT_ADD(ni, ps_discard, discard);	}	return discard;}/* * Indicate whether there are frames queued for a station in power-save mode. */static voidieee80211_set_tim(struct ieee80211_node *ni, int set){	struct ieee80211vap *vap = ni->ni_vap;	u_int16_t aid;	KASSERT(vap->iv_opmode == IEEE80211_M_HOSTAP ||		vap->iv_opmode == IEEE80211_M_IBSS,		("operating mode %u", vap->iv_opmode));	aid = IEEE80211_AID(ni->ni_associd);	KASSERT(aid < vap->iv_max_aid,		("bogus aid %u, max %u", aid, vap->iv_max_aid));	IEEE80211_LOCK(ni->ni_ic);	if (set != (isset(vap->iv_tim_bitmap, aid) != 0)) {		if (set) {			setbit(vap->iv_tim_bitmap, aid);			vap->iv_ps_pending++;		} else {			clrbit(vap->iv_tim_bitmap, aid);			vap->iv_ps_pending--;		}		vap->iv_flags |= IEEE80211_F_TIMUPDATE;	}	IEEE80211_UNLOCK(ni->ni_ic);}/* * Save an outbound packet for a node in power-save sleep state. * The new packet is placed on the node's saved queue, and the TIM * is changed, if necessary. */voidieee80211_pwrsave(struct ieee80211_node *ni, struct sk_buff *skb){	struct ieee80211vap *vap = ni->ni_vap;	struct ieee80211com *ic = ni->ni_ic;	unsigned long flags;	struct sk_buff *tail;	int qlen, age;	spin_lock_irqsave(&ni->ni_savedq.lock, flags);	if (skb_queue_len(&ni->ni_savedq) >= IEEE80211_PS_MAX_QUEUE) {		IEEE80211_NODE_STAT(ni, psq_drops);		spin_unlock_irqrestore(&ni->ni_savedq.lock, flags);		IEEE80211_NOTE(vap, IEEE80211_MSG_ANY, ni,			"pwr save q overflow, drops %d (size %d)",			ni->ni_stats.ns_psq_drops, IEEE80211_PS_MAX_QUEUE);#ifdef IEEE80211_DEBUG		if (ieee80211_msg_dumppkts(vap))			ieee80211_dump_pkt(ni->ni_ic, skb->data, skb->len, -1, -1);#endif		dev_kfree_skb(skb);		return;	}	/*	 * Tag the frame with it's expiry time and insert	 * it in the queue.  The aging interval is 4 times	 * the listen interval specified by the station.	 * Frames that sit around too long are reclaimed	 * using this information.	 */	/* XXX handle overflow? */	age = ((ni->ni_intval * ic->ic_lintval) << 2) / 1024; /* TU -> secs */	tail = skb_peek_tail(&ni->ni_savedq);	if (tail != NULL) {		age -= M_AGE_GET(tail);		__skb_append(tail, skb, &ni->ni_savedq);	} else		__skb_queue_head(&ni->ni_savedq, skb);	M_AGE_SET(skb, age);	qlen = skb_queue_len(&ni->ni_savedq);	spin_unlock_irqrestore(&ni->ni_savedq.lock, flags);	IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,		"save frame, %u now queued", qlen);	if (qlen == 1 && vap->iv_set_tim != NULL)		vap->iv_set_tim(ni, 1);}/* * Handle power-save state change in ap/ibss mode. */voidieee80211_node_pwrsave(struct ieee80211_node *ni, int enable){	struct ieee80211vap *vap = ni->ni_vap;	KASSERT(vap->iv_opmode == IEEE80211_M_HOSTAP ||		vap->iv_opmode == IEEE80211_M_IBSS,		("unexpected operating mode %u", vap->iv_opmode));	if (enable) {		if ((ni->ni_flags & IEEE80211_NODE_PWR_MGT) == 0)			vap->iv_ps_sta++;		ni->ni_flags |= IEEE80211_NODE_PWR_MGT;		IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,			"power save mode on, %u sta's in ps mode",			vap->iv_ps_sta);		return;	}	if ((ni->ni_flags & IEEE80211_NODE_PWR_MGT))		vap->iv_ps_sta--;	ni->ni_flags &= ~IEEE80211_NODE_PWR_MGT;	IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,		"power save mode off, %u sta's in ps mode", vap->iv_ps_sta);	/* XXX if no stations in ps mode, flush mc frames */	/*	 * Flush queued unicast frames.	 */	if (IEEE80211_NODE_SAVEQ_QLEN(ni) == 0) {		if (vap->iv_set_tim != NULL)			vap->iv_set_tim(ni, 0);		/* just in case */		return;	}	IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,		"flush ps queue, %u packets queued",		IEEE80211_NODE_SAVEQ_QLEN(ni));	for (;;) {		struct sk_buff *skb;		int qlen;		IEEE80211_NODE_SAVEQ_LOCK(ni);		IEEE80211_NODE_SAVEQ_DEQUEUE(ni, skb, qlen);		IEEE80211_NODE_SAVEQ_UNLOCK(ni);		if (skb == NULL)			break;		/* 		 * If this is the last packet, turn off the TIM bit.		 *		 * Set the M_PWR_SAV bit on skb to allow encap to test for		 * adding MORE_DATA bit to wh.		 *		 * The 802.11 MAC Spec says we should only set MORE_DATA for 		 * unicast packets when the STA is in PS mode (7.1.3.1.8);		 * which it isn't.		 */		// M_PWR_SAV_SET(skb);#ifdef ATH_SUPERG_XR		/*		 * if it is a XR vap, send the data to associated normal net		 * device. XR vap has a net device which is not registered with		 * OS. 		 */		if (vap->iv_xrvap && vap->iv_flags & IEEE80211_F_XR)			skb->dev = vap->iv_xrvap->iv_dev;		else			skb->dev = vap->iv_dev;		/* XXX? unnecessary */#endif				ieee80211_parent_queue_xmit(skb);	}	vap->iv_set_tim(ni, 0);}/* * Handle power-save state change in station mode. */voidieee80211_sta_pwrsave(struct ieee80211vap *vap, int enable){	struct ieee80211_node *ni = vap->iv_bss;	int qlen;	if (!((enable != 0) ^ ((ni->ni_flags & IEEE80211_NODE_PWR_MGT) != 0)))		return;	IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,		"sta power save mode %s", enable ? "on" : "off");	if (!enable) {		ni->ni_flags &= ~IEEE80211_NODE_PWR_MGT;		ieee80211_send_nulldata(ieee80211_ref_node(ni));		/*		 * Flush any queued frames; we can do this immediately		 * because we know they'll be queued behind the null		 * data frame we send the ap.		 * XXX can we use a data frame to take us out of ps?		 */		qlen = IEEE80211_NODE_SAVEQ_QLEN(ni);		if (qlen != 0) {			IEEE80211_NOTE(vap, IEEE80211_MSG_POWER, ni,				"flush ps queue, %u packets queued", qlen);			for (;;) {				struct sk_buff *skb;				IEEE80211_NODE_SAVEQ_LOCK(ni);				skb = __skb_dequeue(&ni->ni_savedq);				IEEE80211_NODE_SAVEQ_UNLOCK(ni);				if (skb == NULL)					break;				ieee80211_parent_queue_xmit(skb);			}		}	} else {		ni->ni_flags |= IEEE80211_NODE_PWR_MGT;		ieee80211_send_nulldata(ieee80211_ref_node(ni));	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美剧情片在线观看| 日韩一级免费一区| 日韩三级精品电影久久久| 国产网红主播福利一区二区| 亚洲国产欧美另类丝袜| 不卡的电影网站| 久久亚洲一级片| 日欧美一区二区| 欧美亚洲高清一区| 亚洲天堂精品在线观看| 国产成人在线视频网址| 日韩欧美亚洲另类制服综合在线 | 91亚洲男人天堂| 久久综合久久鬼色| 麻豆91免费观看| 欧美区视频在线观看| 一区二区三区视频在线看| 不卡一区中文字幕| 日本一二三四高清不卡| 久久电影网电视剧免费观看| 5月丁香婷婷综合| 午夜电影网一区| 欧美日本国产视频| 日韩经典中文字幕一区| 在线91免费看| 日韩电影网1区2区| 在线不卡a资源高清| 亚洲超碰97人人做人人爱| 91国模大尺度私拍在线视频| 亚洲精品伦理在线| 欧美亚洲一区二区在线| 亚洲网友自拍偷拍| 欧美日韩不卡视频| 日本欧美一区二区| 日韩欧美国产午夜精品| 精品亚洲国产成人av制服丝袜| 亚洲精品在线免费观看视频| 国产在线不卡一卡二卡三卡四卡| 337p粉嫩大胆噜噜噜噜噜91av| 激情久久五月天| 久久久国产精华| 成人av在线影院| 一区二区免费在线| 欧美丰满嫩嫩电影| 国产一区二区三区国产| 国产欧美精品在线观看| 91污片在线观看| 午夜精品爽啪视频| 精品福利一区二区三区免费视频| 国产精品一区二区不卡| ...xxx性欧美| 欧美日韩精品一区二区| 久久精品国产99国产| 国产女主播视频一区二区| 一道本成人在线| 亚洲第一久久影院| 久久久美女毛片| 91捆绑美女网站| 视频一区在线视频| 中文字幕不卡三区| 欧美日韩国产123区| 久久99国产精品麻豆| 中文字幕亚洲在| 91精品在线免费观看| 国产成人精品一区二| 亚洲影视资源网| 精品嫩草影院久久| 欧美性猛片xxxx免费看久爱| 经典三级在线一区| 亚洲综合免费观看高清完整版| 日韩精品专区在线| 91麻豆福利精品推荐| 久久福利视频一区二区| 一区二区三区精品在线观看| 欧美mv日韩mv| 欧美午夜片在线观看| 国产精品自产自拍| 人禽交欧美网站| 中文字幕日韩精品一区 | 精品一区二区三区不卡| 亚洲人成伊人成综合网小说| 精品毛片乱码1区2区3区| 色婷婷亚洲精品| 成人一区二区三区视频| 久久国产精品露脸对白| 亚洲国产日韩精品| ...xxx性欧美| 国产精品私人自拍| www亚洲一区| 欧美一区二区精美| 欧美日韩一卡二卡| 色94色欧美sute亚洲线路二| 成人一区二区三区在线观看| 国产一区二区三区免费在线观看| 偷拍一区二区三区四区| 一区二区三区在线视频免费观看| 中文在线一区二区| 精品三级av在线| 日韩欧美一级在线播放| 在线综合亚洲欧美在线视频| 色婷婷综合久久久久中文一区二区| 国产一区二区精品久久99| 毛片av一区二区三区| 婷婷开心久久网| 亚洲成a人在线观看| 一区二区三区欧美激情| 一区二区三区中文在线| 亚洲精品成人在线| 一区二区三区日本| 亚洲精品视频在线观看免费| 亚洲欧美日韩久久| 亚洲欧洲精品天堂一级| 一区在线观看免费| 亚洲精品免费在线播放| 亚洲综合久久av| 日韩中文字幕亚洲一区二区va在线| 亚洲精品视频在线观看免费| 亚洲综合男人的天堂| 亚洲影院免费观看| 日韩—二三区免费观看av| 日韩影视精彩在线| 午夜精品久久久久久久久久| 日本免费新一区视频| 另类人妖一区二区av| 国产一区二区主播在线| 国产suv精品一区二区6| 91免费国产在线| 欧美色视频在线观看| 天天色图综合网| 中文字幕制服丝袜成人av| 久久亚洲综合色| 久久亚洲二区三区| 国产亚洲欧美激情| 国产精品高潮呻吟| 亚洲乱码国产乱码精品精的特点| 国产精品污污网站在线观看| 337p粉嫩大胆色噜噜噜噜亚洲| 久久综合狠狠综合久久综合88| 欧美一二三四区在线| 日韩欧美一级片| 中文字幕+乱码+中文字幕一区| 26uuuu精品一区二区| 精品久久五月天| 国产精品女主播在线观看| 综合av第一页| 亚洲精品乱码久久久久久久久 | 色国产综合视频| 欧美一区二区成人| 亚洲天堂久久久久久久| 精品欧美黑人一区二区三区| 精品噜噜噜噜久久久久久久久试看| 中文字幕在线不卡一区二区三区| 欧美男女性生活在线直播观看| 日韩成人精品在线观看| 国产精品一区三区| 成人aa视频在线观看| 欧美日韩色综合| 国产午夜亚洲精品羞羞网站| 亚洲国产aⅴ成人精品无吗| 国产精品系列在线播放| 51精品国自产在线| 亚洲日穴在线视频| 国产电影精品久久禁18| 欧美老肥妇做.爰bbww| 国产精品免费看片| 九九视频精品免费| 欧美亚一区二区| 国产精品乱人伦中文| 久久国产人妖系列| 欧美日韩一区二区三区在线看| 中文字幕不卡三区| 国精产品一区一区三区mba桃花| 91成人看片片| 国产精品二三区| 国产精品99久久久久久似苏梦涵| 91精品欧美一区二区三区综合在| 亚洲精品免费看| 成人a级免费电影| 国产午夜亚洲精品不卡| 毛片基地黄久久久久久天堂| 欧美美女bb生活片| 一区二区三区色| 色综合 综合色| 中文字幕av一区 二区| 国产一区二区主播在线| 欧美mv日韩mv国产网站app| 日韩精品电影在线观看| 欧美三级中文字| 亚洲靠逼com| 在线影院国内精品| 亚洲精品国产无天堂网2021| 99久久综合99久久综合网站| 国产精品久久久久影院老司| 成人综合激情网| 国产精品拍天天在线| 99精品视频在线观看| 国产精品久久久久久妇女6080 | 国产伦精品一区二区三区免费迷 | 一本色道久久综合亚洲91| 亚洲欧洲色图综合|