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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rtmp_info.c

?? RT73_Linux_STA_Drv1.0.3.6 linux系統(tǒng)下
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*
 ***************************************************************************
 * Ralink Tech Inc.
 * 4F, No. 2 Technology 5th Rd.
 * Science-based Industrial Park
 * Hsin-chu, Taiwan, R.O.C.
 *
 * (c) Copyright 2002-2006, Ralink Technology, Inc.
 *
 * This program is free software; you can redistribute it and/or modify  * 
 * it under the terms of the GNU General Public License as published by  * 
 * the Free Software Foundation; either version 2 of the License, or     * 
 * (at your option) any later version.                                   * 
 *                                                                       * 
 * This program is distributed in the hope that it will be useful,       * 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of        * 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * 
 * GNU General Public License for more details.                          * 
 *                                                                       * 
 * You should have received a copy of the GNU General Public License     * 
 * along with this program; if not, write to the                         * 
 * Free Software Foundation, Inc.,                                       * 
 * 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             * 
 *                                                                       * 
 ************************************************************************

	Module Name:
	rtmp_info.c

	Abstract:
	IOCTL related subroutines

	Revision History:
	Who 		When		  What
	--------	----------	  ----------------------------------------------
	Rory Chen	01-03-2003	  created
	Rory Chen	02-14-2005	  modify to support RT61
*/

#include	"rt_config.h"
#include <net/iw_handler.h>

#ifdef DBG
extern ULONG	RTDebugLevel;
#endif

#ifndef IW_ESSID_MAX_SIZE
/* Maximum size of the ESSID and NICKN strings */
#define IW_ESSID_MAX_SIZE	32
#endif

extern UCHAR	CipherWpa2Template[];
extern UCHAR	CipherWpa2TemplateLen;
extern UCHAR	CipherWpaPskTkip[];
extern UCHAR	CipherWpaPskTkipLen;

#define NR_WEP_KEYS 4
//#define WEP_SMALL_KEY_LEN (40/8)  //move to rtmp_def.h
//#define WEP_LARGE_KEY_LEN (104/8)


struct iw_priv_args privtab[] = {
{ RTPRIV_IOCTL_SET, 
  IW_PRIV_TYPE_CHAR | 1024, 0,
  "set"},
  
#ifdef DBG
{ RTPRIV_IOCTL_BBP,
  IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024,
  "bbp"},
{ RTPRIV_IOCTL_MAC,
  IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024,
  "mac"},
#endif

{ RTPRIV_IOCTL_STATISTICS,
  IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024,
  "stat"}, 
{ RTPRIV_IOCTL_GSITESURVEY,
  IW_PRIV_TYPE_CHAR | 1024, IW_PRIV_TYPE_CHAR | 1024 ,
  "get_site_survey"},
{ RTPRIV_IOCTL_GETRAAPCFG,  IW_PRIV_TYPE_CHAR | 1024, 0,  
  "get_RaAP_Cfg"},
#if 1 
{ RTPRIV_IOCTL_AUTH, 
  IW_PRIV_TYPE_INT	|1, 0,	
  "auth"},
{ RTPRIV_IOCTL_WEPSTATUS, 
  IW_PRIV_TYPE_INT	|1, 0,	
  "enc"},  
{ RTPRIV_IOCTL_WPAPSK, 
  IW_PRIV_TYPE_CHAR |64, 0,  
  "wpapsk"},
{ RTPRIV_IOCTL_PSM, 
 IW_PRIV_TYPE_INT  |1, 0,  
 "psm"},
#endif
};

static struct {
	CHAR *name;
	INT (*set_proc)(PRTMP_ADAPTER pAdapter, PUCHAR arg);
} *PRTMP_PRIVATE_SET_PROC, RTMP_PRIVATE_SUPPORT_PROC[] = {
	{"DriverVersion",				Set_DriverVersion_Proc},
	{"CountryRegion",				Set_CountryRegion_Proc},	
	{"CountryRegionABand",			Set_CountryRegionABand_Proc},	   
	{"SSID",						Set_SSID_Proc}, 
	{"WirelessMode",				Set_WirelessMode_Proc}, 	  
	{"TxRate",						Set_TxRate_Proc},			  
	{"Channel",						Set_Channel_Proc},			  
	{"BGProtection",				Set_BGProtection_Proc},
	{"TxPreamble",					Set_TxPreamble_Proc},		  
	{"RTSThreshold",				Set_RTSThreshold_Proc}, 	  
	{"FragThreshold",				Set_FragThreshold_Proc},	  
	{"TxBurst",						Set_TxBurst_Proc},
	{"AdhocOfdm",					Set_AdhocModeRate_Proc},
#ifdef AGGREGATION_SUPPORT
	{"PktAggregate",				Set_PktAggregate_Proc}, 	  
#endif
	{"TurboRate",					Set_TurboRate_Proc},		  
#if 0
	{"WmmCapable",					Set_WmmCapable_Proc},		  		   
#endif	
	{"IEEE80211H",					Set_IEEE80211H_Proc},
	{"NetworkType", 				Set_NetworkType_Proc},		  
	{"AuthMode",					Set_AuthMode_Proc}, 		  
	{"EncrypType",					Set_EncrypType_Proc},		  
	{"DefaultKeyID",				Set_DefaultKeyID_Proc}, 	  
	{"Key1",						Set_Key1_Proc}, 			  
	{"Key2",						Set_Key2_Proc}, 			  
	{"Key3",						Set_Key3_Proc}, 			  
	{"Key4",						Set_Key4_Proc}, 			  
	{"WPAPSK",						Set_WPAPSK_Proc},
	{"ResetCounter",				Set_ResetStatCounter_Proc},
	{"PSMode",						Set_PSMode_Proc},
#ifdef DBG
	{"Debug",						Set_Debug_Proc},			 
#endif			
	{NULL,}
};

char * rtstrchr(const char * s, int c)
{
	for(; *s != (char) c; ++s)
		if (*s == '\0')
			return NULL;
	return (char *) s;
}

/*
This is required for LinEX2004/kernel2.6.7 to provide iwlist scanning function
*/

int
rt_ioctl_giwname(struct net_device *dev,
		   struct iw_request_info *info,
		   char *name, char *extra)
{
	strncpy(name, "RT73 WLAN", IFNAMSIZ);
	return 0;
}

int rt_ioctl_siwfreq(struct net_device *dev,
			struct iw_request_info *info,
			struct iw_freq *freq, char *extra)
{
	PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;
	int 	chan = -1;
	
    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;

	if (freq->e > 1)
		return -EINVAL;

	if((freq->e == 0) && (freq->m <= 1000))
		chan = freq->m;	// Setting by channel number 
	else
		MAP_KHZ_TO_CHANNEL_ID( (freq->m /100) , chan); // Setting by frequency - search the table , like 2.412G, 2.422G, 
	pAdapter->PortCfg.Channel = chan;
	DBGPRINT(RT_DEBUG_ERROR, "==>rt_ioctl_siwfreq::SIOCSIWFREQ[cmd=0x%x] (Channel=%d)\n", SIOCSIWFREQ, pAdapter->PortCfg.Channel);


	return 0;
}
int rt_ioctl_giwfreq(struct net_device *dev,
		   struct iw_request_info *info,
		   struct iw_freq *freq, char *extra)
{
	PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;
	ULONG	m;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;

	DBGPRINT(RT_DEBUG_TRACE,"==>rt_ioctl_giwfreq  %d\n",pAdapter->PortCfg.Channel);
	
	MAP_CHANNEL_ID_TO_KHZ(pAdapter->PortCfg.Channel, m);
	freq->m = pAdapter->PortCfg.Channel;
	freq->e = 0;
	freq->i = 0;
	return 0;
}

int rt_ioctl_siwmode(struct net_device *dev,
		   struct iw_request_info *info,
		   __u32 *mode, char *extra)
{
	PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;

	switch (*mode)
	{
		case IW_MODE_ADHOC:
			if (pAdapter->PortCfg.BssType != BSS_ADHOC)
			{	
				// Config has changed
				if (INFRA_ON(pAdapter))
				{
					RTUSBEnqueueInternalCmd(pAdapter, RT_OID_LINK_DOWN);
					// First cancel linkdown timer
					DBGPRINT(RT_DEBUG_TRACE, "NDIS_STATUS_MEDIA_DISCONNECT Event BB!\n");							
				}

			}
			pAdapter->PortCfg.BssType = BSS_ADHOC;
			DBGPRINT(RT_DEBUG_TRACE, "===>rt_ioctl_siwmode::SIOCSIWMODE (AD-HOC)\n");
			break;
		case IW_MODE_INFRA:
			if (pAdapter->PortCfg.BssType != BSS_INFRA)
			{
				// Config has changed
				if (ADHOC_ON(pAdapter)) 						  
					RTUSBEnqueueInternalCmd(pAdapter, RT_OID_LINK_DOWN);
			}
			pAdapter->PortCfg.BssType = BSS_INFRA;
			DBGPRINT(RT_DEBUG_TRACE, "===>rt_ioctl_siwmode::SIOCSIWMODE (INFRA)\n");
			break;
		default:
			DBGPRINT(RT_DEBUG_TRACE, "===>rt_ioctl_siwmode::SIOCSIWMODE (unknown)\n");
			return -EINVAL;
	}
	
	// Reset Ralink supplicant to not use, it will be set to start when UI set PMK key
	pAdapter->PortCfg.WpaState = SS_NOTUSE;

	return 0;
}

int rt_ioctl_giwmode(struct net_device *dev,
		   struct iw_request_info *info,
		   __u32 *mode, char *extra)
{
	PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;
        
	if (ADHOC_ON(pAdapter))
		*mode = IW_MODE_ADHOC;
	else if (INFRA_ON(pAdapter))
		*mode = IW_MODE_INFRA;
	else
		*mode = IW_MODE_AUTO;

	DBGPRINT(RT_DEBUG_TRACE,"==>rt_ioctl_giwmode\n");		
	return 0;
}

int rt_ioctl_siwsens(struct net_device *dev,
		   struct iw_request_info *info,
		   char *name, char *extra)
{
    PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;

	return 0;
}

int rt_ioctl_giwsens(struct net_device *dev,
		   struct iw_request_info *info,
		   char *name, char *extra)
{
    PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;
        
	return 0;
}

int rt_ioctl_giwrange(struct net_device *dev,
		   struct iw_request_info *info,
		   struct iw_point *data, char *extra)
{
	PRTMP_ADAPTER pAdapter = (PRTMP_ADAPTER) dev->priv;
	struct iw_range *range = (struct iw_range *) extra;
	u16 val;
	int i;

    //check if the interface is down
    if (pAdapter->RTUSBCmdThr_pid < 0)
        return -ENETDOWN;

	DBGPRINT(RT_DEBUG_TRACE,"===>rt_ioctl_giwrange\n");		
	data->length = sizeof(struct iw_range);
	memset(range, 0, sizeof(struct iw_range));

	range->txpower_capa = IW_TXPOW_DBM;

	if (INFRA_ON(pAdapter)||ADHOC_ON(pAdapter))
	{
		range->min_pmp = 1 * 1024;
		range->max_pmp = 65535 * 1024;
		range->min_pmt = 1 * 1024;
		range->max_pmt = 1000 * 1024;
		range->pmp_flags = IW_POWER_PERIOD;
		range->pmt_flags = IW_POWER_TIMEOUT;
		range->pm_capa = IW_POWER_PERIOD | IW_POWER_TIMEOUT |
			IW_POWER_UNICAST_R | IW_POWER_ALL_R;
	}

	range->we_version_compiled = WIRELESS_EXT;
	range->we_version_source = 14;

	range->retry_capa = IW_RETRY_LIMIT;
	range->retry_flags = IW_RETRY_LIMIT;
	range->min_retry = 0;
	range->max_retry = 255;

	range->num_channels =  pAdapter->ChannelListNum;

	val = 0;
	for (i = 0; i < pAdapter->PortCfg.SupRateLen; i++) {
			range->freq[val].i =(pAdapter->PortCfg.SupRate[i] & 0x7f)/2;
			range->freq[val].m = (pAdapter->PortCfg.SupRate[i] & 0x7f)/2 * 100000;
			range->freq[val].e = 1;
			val++;
		if (val == IW_MAX_FREQUENCIES)
			break;
	}
	range->num_frequency = val;

	range->max_qual.qual = 100; /* what is correct max? This was not
                                * documented exactly. At least
					            * 69 has been observed. */
	range->max_qual.level = 0; /* dB */
	range->max_qual.noise = 0; /* dB */

	/* What would be suitable values for "average/typical" qual? */
	range->avg_qual.qual = 20;
	range->avg_qual.level = -60;
	range->avg_qual.noise = -95;
	range->sensitivity = 3;

	range->max_encoding_tokens = NR_WEP_KEYS;
	range->num_encoding_sizes = 2;
	range->encoding_size[0] = 5;
	range->encoding_size[1] = 13;

#if 0
	over2 = 0;
	len = prism2_get_datarates(dev, rates);
	range->num_bitrates = 0;
	for (i = 0; i < len; i++) {
		if (range->num_bitrates < IW_MAX_BITRATES) {
			range->bitrate[range->num_bitrates] =
				rates[i] * 500000;
			range->num_bitrates++;
		}
		if (rates[i] == 0x0b || rates[i] == 0x16)
			over2 = 1;
	}
	/* estimated maximum TCP throughput values (bps) */
	range->throughput = over2 ? 5500000 : 1500000;
#endif
	range->min_rts = 0;
	range->max_rts = 2347;
	range->min_frag = 256;
	range->max_frag = 2346;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久噜噜噜久噜久久综合| 欧美日韩亚洲另类| 黑人巨大精品欧美一区| 欧美国产日韩a欧美在线观看| 一本大道久久a久久精二百 | 中文字幕中文乱码欧美一区二区| 欧美三级韩国三级日本三斤| 丁香亚洲综合激情啪啪综合| 日本在线播放一区二区三区| 日韩一区在线看| 精品国产伦一区二区三区观看方式 | 91高清在线观看| 国产呦萝稀缺另类资源| 五月天欧美精品| 一区二区三区国产精品| 亚洲欧洲日韩一区二区三区| 久久九九全国免费| 欧美va亚洲va| 日韩欧美一二区| 555www色欧美视频| 欧美视频你懂的| 色婷婷综合在线| www.激情成人| 成年人午夜久久久| 国产成人午夜精品影院观看视频| 蜜臀av性久久久久蜜臀aⅴ| 亚洲国产精品人人做人人爽| 亚洲精品国产成人久久av盗摄 | 欧美在线不卡一区| zzijzzij亚洲日本少妇熟睡| 国产不卡一区视频| 高清shemale亚洲人妖| 国产激情精品久久久第一区二区| 久久精品国产免费| 久久精品99国产精品日本| 91片黄在线观看| 成人激情视频网站| jlzzjlzz亚洲日本少妇| 成a人片亚洲日本久久| 成a人片国产精品| 99精品视频在线播放观看| 成人免费av在线| 成人app在线| av不卡免费电影| 色婷婷综合久色| 91行情网站电视在线观看高清版| 色婷婷精品久久二区二区蜜臂av | 久久麻豆一区二区| 2020国产精品久久精品美国| 久久夜色精品一区| 国产日产精品1区| 日韩一区在线免费观看| 夜夜揉揉日日人人青青一国产精品| 一区二区三区中文免费| 日韩高清不卡一区| 精品一区二区三区欧美| 成人一区二区三区中文字幕| 色综合色狠狠天天综合色| 欧美三区免费完整视频在线观看| 欧美美女一区二区在线观看| 欧美videos大乳护士334| 国产亚洲视频系列| 成人免费一区二区三区在线观看| 综合久久久久综合| 五月天一区二区三区| 经典三级视频一区| 99久久婷婷国产| 欧美成人女星排行榜| 国产视频不卡一区| 亚洲精品中文字幕乱码三区| 午夜久久久久久久久久一区二区| 久久国产人妖系列| 99久久久无码国产精品| 欧美精品在线观看播放| 国产亚洲视频系列| 亚洲高清在线精品| 国产精品 日产精品 欧美精品| 色诱亚洲精品久久久久久| 欧美一区二区三区免费视频| 国产精品情趣视频| 午夜影院久久久| 国产成人综合自拍| 在线不卡欧美精品一区二区三区| 久久精品亚洲乱码伦伦中文| 亚洲在线观看免费视频| 国产一区二区中文字幕| 色老综合老女人久久久| 久久天堂av综合合色蜜桃网| 亚洲精品国产视频| 国产伦精品一区二区三区免费| 91麻豆免费观看| www国产精品av| 亚洲不卡av一区二区三区| 成人午夜激情视频| 日韩一区二区不卡| 亚洲美女视频在线| 国产成人综合在线观看| 欧美日韩高清在线播放| 视频精品一区二区| 97精品超碰一区二区三区| 精品美女被调教视频大全网站| 一区二区三区 在线观看视频| 国产精品伊人色| 91精品国产综合久久香蕉麻豆| 自拍偷自拍亚洲精品播放| 国产一区视频网站| 69堂成人精品免费视频| 亚洲精品久久久蜜桃| 成人激情小说乱人伦| 久久色在线观看| 日本不卡视频在线| 欧美在线制服丝袜| 国产精品久线在线观看| 国产一区二区三区黄视频| 欧美美女黄视频| 亚洲大片在线观看| 色综合视频在线观看| 国产精品久久久久久久第一福利| 韩国欧美国产1区| 日韩免费在线观看| 男女男精品网站| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 丁香婷婷综合激情五月色| 日韩视频一区二区| 婷婷亚洲久悠悠色悠在线播放| 一本一本大道香蕉久在线精品| 国产精品三级av在线播放| 国产乱人伦精品一区二区在线观看 | 一本色道久久综合亚洲精品按摩| 久久精品一区二区三区不卡牛牛| 在线免费观看视频一区| 亚洲三级小视频| 91在线一区二区| 亚洲视频一区二区在线观看| 91麻豆国产自产在线观看| 亚洲欧洲精品天堂一级| 91色乱码一区二区三区| 中文字幕一区二区日韩精品绯色| 成人免费福利片| 中文字幕欧美一| 色呦呦国产精品| 亚洲一区二区视频在线观看| 欧美亚洲一区二区在线观看| 亚洲自拍偷拍九九九| 欧美日本韩国一区二区三区视频 | 99精品久久99久久久久| 日韩美女视频一区二区| 色播五月激情综合网| 亚洲永久精品大片| 欧美电影在线免费观看| 久草精品在线观看| 亚洲国产激情av| 日本韩国一区二区三区| 亚洲国产精品久久人人爱| 欧美精品v日韩精品v韩国精品v| 天使萌一区二区三区免费观看| 日韩欧美国产一区二区在线播放| 国产一区二区在线观看免费| 国产精品久久久久久久久快鸭| 色综合久久久久网| 五月综合激情日本mⅴ| 久久久久久久综合日本| 91麻豆自制传媒国产之光| 天天综合天天综合色| 2021中文字幕一区亚洲| 92精品国产成人观看免费 | 国产在线不卡一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久综合资源网| 色香蕉成人二区免费| 日本成人在线看| 中文字幕欧美激情| 欧美色窝79yyyycom| 国产美女久久久久| 亚洲黄色av一区| 欧美成人精品3d动漫h| 成人av资源网站| 日本中文在线一区| 中文字幕不卡的av| 在线播放欧美女士性生活| 粉嫩绯色av一区二区在线观看| 一区二区在线观看视频| 精品欧美一区二区三区精品久久 | 亚洲精品ww久久久久久p站| 日韩一级在线观看| 波多野结衣91| 久久99精品国产.久久久久久| 亚洲欧美激情视频在线观看一区二区三区| 欧美喷潮久久久xxxxx| 丁香一区二区三区| 蜜臀久久99精品久久久久宅男| 欧美国产欧美综合| 欧美一区二区免费观在线| 99久久久久免费精品国产| 久久99日本精品| 午夜天堂影视香蕉久久| 亚洲人精品午夜| 久久精品免费在线观看| 亚洲人快播电影网| 2021久久国产精品不只是精品|