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

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

?? atmel.c

?? linux 內核源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
	struct timer_list management_timer;	struct net_device *dev;	struct device *sys_dev;	struct iw_statistics wstats;	struct net_device_stats	stats;	// device stats	spinlock_t irqlock, timerlock;	// spinlocks	enum { BUS_TYPE_PCCARD, BUS_TYPE_PCI } bus_type;	enum {		CARD_TYPE_PARALLEL_FLASH,		CARD_TYPE_SPI_FLASH,		CARD_TYPE_EEPROM	} card_type;	int do_rx_crc; /* If we need to CRC incoming packets */	int probe_crc; /* set if we don't yet know */	int crc_ok_cnt, crc_ko_cnt; /* counters for probing */	u16 rx_desc_head;	u16 tx_desc_free, tx_desc_head, tx_desc_tail, tx_desc_previous;	u16 tx_free_mem, tx_buff_head, tx_buff_tail;	u16 frag_seq, frag_len, frag_no;	u8 frag_source[6];	u8 wep_is_on, default_key, exclude_unencrypted, encryption_level;	u8 group_cipher_suite, pairwise_cipher_suite;	u8 wep_keys[MAX_ENCRYPTION_KEYS][MAX_ENCRYPTION_KEY_SIZE];	int wep_key_len[MAX_ENCRYPTION_KEYS];	int use_wpa, radio_on_broken; /* firmware dependent stuff. */	u16 host_info_base;	struct host_info_struct {		/* NB this is matched to the hardware, don't change. */		u8 volatile int_status;		u8 volatile int_mask;		u8 volatile lockout_host;		u8 volatile lockout_mac;		u16 tx_buff_pos;		u16 tx_buff_size;		u16 tx_desc_pos;		u16 tx_desc_count;		u16 rx_buff_pos;		u16 rx_buff_size;		u16 rx_desc_pos;		u16 rx_desc_count;		u16 build_version;		u16 command_pos;		u16 major_version;		u16 minor_version;		u16 func_ctrl;		u16 mac_status;		u16 generic_IRQ_type;		u8  reserved[2];	} host_info;	enum {		STATION_STATE_SCANNING,		STATION_STATE_JOINNING,		STATION_STATE_AUTHENTICATING,		STATION_STATE_ASSOCIATING,		STATION_STATE_READY,		STATION_STATE_REASSOCIATING,		STATION_STATE_DOWN,		STATION_STATE_MGMT_ERROR	} station_state;	int operating_mode, power_mode;	time_t last_qual;	int beacons_this_sec;	int channel;	int reg_domain, config_reg_domain;	int tx_rate;	int auto_tx_rate;	int rts_threshold;	int frag_threshold;	int long_retry, short_retry;	int preamble;	int default_beacon_period, beacon_period, listen_interval;	int CurrentAuthentTransactionSeqNum, ExpectedAuthentTransactionSeqNum;	int AuthenticationRequestRetryCnt, AssociationRequestRetryCnt, ReAssociationRequestRetryCnt;	enum {		SITE_SURVEY_IDLE,		SITE_SURVEY_IN_PROGRESS,		SITE_SURVEY_COMPLETED	} site_survey_state;	time_t last_survey;	int station_was_associated, station_is_associated;	int fast_scan;	struct bss_info {		int channel;		int SSIDsize;		int RSSI;		int UsingWEP;		int preamble;		int beacon_period;		int BSStype;		u8 BSSID[6];		u8 SSID[MAX_SSID_LENGTH];	} BSSinfo[MAX_BSS_ENTRIES];	int BSS_list_entries, current_BSS;	int connect_to_any_BSS;	int SSID_size, new_SSID_size;	u8 CurrentBSSID[6], BSSID[6];	u8 SSID[MAX_SSID_LENGTH], new_SSID[MAX_SSID_LENGTH];	u64 last_beacon_timestamp;	u8 rx_buf[MAX_WIRELESS_BODY];};static u8 atmel_basic_rates[4] = {0x82,0x84,0x0b,0x16};static const struct {	int reg_domain;	int min, max;	char *name;} channel_table[] = { { REG_DOMAIN_FCC, 1, 11, "USA" },		      { REG_DOMAIN_DOC, 1, 11, "Canada" },		      { REG_DOMAIN_ETSI, 1, 13, "Europe" },		      { REG_DOMAIN_SPAIN, 10, 11, "Spain" },		      { REG_DOMAIN_FRANCE, 10, 13, "France" },		      { REG_DOMAIN_MKK, 14, 14, "MKK" },		      { REG_DOMAIN_MKK1, 1, 14, "MKK1" },		      { REG_DOMAIN_ISRAEL, 3, 9, "Israel"} };static void build_wpa_mib(struct atmel_private *priv);static int atmel_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);static void atmel_copy_to_card(struct net_device *dev, u16 dest,			       unsigned char *src, u16 len);static void atmel_copy_to_host(struct net_device *dev, unsigned char *dest,			       u16 src, u16 len);static void atmel_set_gcr(struct net_device *dev, u16 mask);static void atmel_clear_gcr(struct net_device *dev, u16 mask);static int atmel_lock_mac(struct atmel_private *priv);static void atmel_wmem32(struct atmel_private *priv, u16 pos, u32 data);static void atmel_command_irq(struct atmel_private *priv);static int atmel_validate_channel(struct atmel_private *priv, int channel);static void atmel_management_frame(struct atmel_private *priv,				   struct ieee80211_hdr_4addr *header,				   u16 frame_len, u8 rssi);static void atmel_management_timer(u_long a);static void atmel_send_command(struct atmel_private *priv, int command,			       void *cmd, int cmd_size);static int atmel_send_command_wait(struct atmel_private *priv, int command,				   void *cmd, int cmd_size);static void atmel_transmit_management_frame(struct atmel_private *priv,					    struct ieee80211_hdr_4addr *header,					    u8 *body, int body_len);static u8 atmel_get_mib8(struct atmel_private *priv, u8 type, u8 index);static void atmel_set_mib8(struct atmel_private *priv, u8 type, u8 index,			   u8 data);static void atmel_set_mib16(struct atmel_private *priv, u8 type, u8 index,			    u16 data);static void atmel_set_mib(struct atmel_private *priv, u8 type, u8 index,			  u8 *data, int data_len);static void atmel_get_mib(struct atmel_private *priv, u8 type, u8 index,			  u8 *data, int data_len);static void atmel_scan(struct atmel_private *priv, int specific_ssid);static void atmel_join_bss(struct atmel_private *priv, int bss_index);static void atmel_smooth_qual(struct atmel_private *priv);static void atmel_writeAR(struct net_device *dev, u16 data);static int probe_atmel_card(struct net_device *dev);static int reset_atmel_card(struct net_device *dev);static void atmel_enter_state(struct atmel_private *priv, int new_state);int atmel_open (struct net_device *dev);static inline u16 atmel_hi(struct atmel_private *priv, u16 offset){	return priv->host_info_base + offset;}static inline u16 atmel_co(struct atmel_private *priv, u16 offset){	return priv->host_info.command_pos + offset;}static inline u16 atmel_rx(struct atmel_private *priv, u16 offset, u16 desc){	return priv->host_info.rx_desc_pos + (sizeof(struct rx_desc) * desc) + offset;}static inline u16 atmel_tx(struct atmel_private *priv, u16 offset, u16 desc){	return priv->host_info.tx_desc_pos + (sizeof(struct tx_desc) * desc) + offset;}static inline u8 atmel_read8(struct net_device *dev, u16 offset){	return inb(dev->base_addr + offset);}static inline void atmel_write8(struct net_device *dev, u16 offset, u8 data){	outb(data, dev->base_addr + offset);}static inline u16 atmel_read16(struct net_device *dev, u16 offset){	return inw(dev->base_addr + offset);}static inline void atmel_write16(struct net_device *dev, u16 offset, u16 data){	outw(data, dev->base_addr + offset);}static inline u8 atmel_rmem8(struct atmel_private *priv, u16 pos){	atmel_writeAR(priv->dev, pos);	return atmel_read8(priv->dev, DR);}static inline void atmel_wmem8(struct atmel_private *priv, u16 pos, u16 data){	atmel_writeAR(priv->dev, pos);	atmel_write8(priv->dev, DR, data);}static inline u16 atmel_rmem16(struct atmel_private *priv, u16 pos){	atmel_writeAR(priv->dev, pos);	return atmel_read16(priv->dev, DR);}static inline void atmel_wmem16(struct atmel_private *priv, u16 pos, u16 data){	atmel_writeAR(priv->dev, pos);	atmel_write16(priv->dev, DR, data);}static const struct iw_handler_def atmel_handler_def;static void tx_done_irq(struct atmel_private *priv){	int i;	for (i = 0;	     atmel_rmem8(priv, atmel_tx(priv, TX_DESC_FLAGS_OFFSET, priv->tx_desc_head)) == TX_DONE &&		     i < priv->host_info.tx_desc_count;	     i++) {		u8 status = atmel_rmem8(priv, atmel_tx(priv, TX_DESC_STATUS_OFFSET, priv->tx_desc_head));		u16 msdu_size = atmel_rmem16(priv, atmel_tx(priv, TX_DESC_SIZE_OFFSET, priv->tx_desc_head));		u8 type = atmel_rmem8(priv, atmel_tx(priv, TX_DESC_PACKET_TYPE_OFFSET, priv->tx_desc_head));		atmel_wmem8(priv, atmel_tx(priv, TX_DESC_FLAGS_OFFSET, priv->tx_desc_head), 0);		priv->tx_free_mem += msdu_size;		priv->tx_desc_free++;		if (priv->tx_buff_head + msdu_size > (priv->host_info.tx_buff_pos + priv->host_info.tx_buff_size))			priv->tx_buff_head = 0;		else			priv->tx_buff_head += msdu_size;		if (priv->tx_desc_head < (priv->host_info.tx_desc_count - 1))			priv->tx_desc_head++ ;		else			priv->tx_desc_head = 0;		if (type == TX_PACKET_TYPE_DATA) {			if (status == TX_STATUS_SUCCESS)				priv->stats.tx_packets++;			else				priv->stats.tx_errors++;			netif_wake_queue(priv->dev);		}	}}static u16 find_tx_buff(struct atmel_private *priv, u16 len){	u16 bottom_free = priv->host_info.tx_buff_size - priv->tx_buff_tail;	if (priv->tx_desc_free == 3 || priv->tx_free_mem < len)		return 0;	if (bottom_free >= len)		return priv->host_info.tx_buff_pos + priv->tx_buff_tail;	if (priv->tx_free_mem - bottom_free >= len) {		priv->tx_buff_tail = 0;		return priv->host_info.tx_buff_pos;	}	return 0;}static void tx_update_descriptor(struct atmel_private *priv, int is_bcast,				 u16 len, u16 buff, u8 type){	atmel_wmem16(priv, atmel_tx(priv, TX_DESC_POS_OFFSET, priv->tx_desc_tail), buff);	atmel_wmem16(priv, atmel_tx(priv, TX_DESC_SIZE_OFFSET, priv->tx_desc_tail), len);	if (!priv->use_wpa)		atmel_wmem16(priv, atmel_tx(priv, TX_DESC_HOST_LENGTH_OFFSET, priv->tx_desc_tail), len);	atmel_wmem8(priv, atmel_tx(priv, TX_DESC_PACKET_TYPE_OFFSET, priv->tx_desc_tail), type);	atmel_wmem8(priv, atmel_tx(priv, TX_DESC_RATE_OFFSET, priv->tx_desc_tail), priv->tx_rate);	atmel_wmem8(priv, atmel_tx(priv, TX_DESC_RETRY_OFFSET, priv->tx_desc_tail), 0);	if (priv->use_wpa) {		int cipher_type, cipher_length;		if (is_bcast) {			cipher_type = priv->group_cipher_suite;			if (cipher_type == CIPHER_SUITE_WEP_64 ||			    cipher_type == CIPHER_SUITE_WEP_128)				cipher_length = 8;			else if (cipher_type == CIPHER_SUITE_TKIP)				cipher_length = 12;			else if (priv->pairwise_cipher_suite == CIPHER_SUITE_WEP_64 ||				 priv->pairwise_cipher_suite == CIPHER_SUITE_WEP_128) {				cipher_type = priv->pairwise_cipher_suite;				cipher_length = 8;			} else {				cipher_type = CIPHER_SUITE_NONE;				cipher_length = 0;			}		} else {			cipher_type = priv->pairwise_cipher_suite;			if (cipher_type == CIPHER_SUITE_WEP_64 ||			    cipher_type == CIPHER_SUITE_WEP_128)				cipher_length = 8;			else if (cipher_type == CIPHER_SUITE_TKIP)				cipher_length = 12;			else if (priv->group_cipher_suite == CIPHER_SUITE_WEP_64 ||				 priv->group_cipher_suite == CIPHER_SUITE_WEP_128) {				cipher_type = priv->group_cipher_suite;				cipher_length = 8;			} else {				cipher_type = CIPHER_SUITE_NONE;				cipher_length = 0;			}		}		atmel_wmem8(priv, atmel_tx(priv, TX_DESC_CIPHER_TYPE_OFFSET, priv->tx_desc_tail),			    cipher_type);		atmel_wmem8(priv, atmel_tx(priv, TX_DESC_CIPHER_LENGTH_OFFSET, priv->tx_desc_tail),			    cipher_length);	}	atmel_wmem32(priv, atmel_tx(priv, TX_DESC_NEXT_OFFSET, priv->tx_desc_tail), 0x80000000L);	atmel_wmem8(priv, atmel_tx(priv, TX_DESC_FLAGS_OFFSET, priv->tx_desc_tail), TX_FIRM_OWN);	if (priv->tx_desc_previous != priv->tx_desc_tail)		atmel_wmem32(priv, atmel_tx(priv, TX_DESC_NEXT_OFFSET, priv->tx_desc_previous), 0);	priv->tx_desc_previous = priv->tx_desc_tail;	if (priv->tx_desc_tail < (priv->host_info.tx_desc_count - 1))		priv->tx_desc_tail++;	else		priv->tx_desc_tail = 0;	priv->tx_desc_free--;	priv->tx_free_mem -= len;}static int start_tx(struct sk_buff *skb, struct net_device *dev){	static const u8 SNAP_RFC1024[6] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };	struct atmel_private *priv = netdev_priv(dev);	struct ieee80211_hdr_4addr header;	unsigned long flags;	u16 buff, frame_ctl, len = (ETH_ZLEN < skb->len) ? skb->len : ETH_ZLEN;	if (priv->card && priv->present_callback &&	    !(*priv->present_callback)(priv->card)) {		priv->stats.tx_errors++;		dev_kfree_skb(skb);		return 0;	}	if (priv->station_state != STATION_STATE_READY) {		priv->stats.tx_errors++;		dev_kfree_skb(skb);		return 0;	}	/* first ensure the timer func cannot run */	spin_lock_bh(&priv->timerlock);	/* then stop the hardware ISR */	spin_lock_irqsave(&priv->irqlock, flags);	/* nb doing the above in the opposite order will deadlock */	/* The Wireless Header is 30 bytes. In the Ethernet packet we "cut" the	   12 first bytes (containing DA/SA) and put them in the appropriate	   fields of the Wireless Header. Thus the packet length is then the	   initial + 18 (+30-12) */	if (!(buff = find_tx_buff(priv, len + 18))) {		priv->stats.tx_dropped++;		spin_unlock_irqrestore(&priv->irqlock, flags);		spin_unlock_bh(&priv->timerlock);		netif_stop_queue(dev);		return 1;	}	frame_ctl = IEEE80211_FTYPE_DATA;	header.duration_id = 0;	header.seq_ctl = 0;	if (priv->wep_is_on)		frame_ctl |= IEEE80211_FCTL_PROTECTED;	if (priv->operating_mode == IW_MODE_ADHOC) {		skb_copy_from_linear_data(skb, &header.addr1, 6);		memcpy(&header.addr2, dev->dev_addr, 6);		memcpy(&header.addr3, priv->BSSID, 6);	} else {		frame_ctl |= IEEE80211_FCTL_TODS;		memcpy(&header.addr1, priv->CurrentBSSID, 6);		memcpy(&header.addr2, dev->dev_addr, 6);		skb_copy_from_linear_data(skb, &header.addr3, 6);	}	if (priv->use_wpa)		memcpy(&header.addr4, SNAP_RFC1024, 6);	header.frame_ctl = cpu_to_le16(frame_ctl);	/* Copy the wireless header into the card */	atmel_copy_to_card(dev, buff, (unsigned char *)&header, DATA_FRAME_WS_HEADER_SIZE);	/* Copy the packet sans its 802.3 header addresses which have been replaced */	atmel_copy_to_card(dev, buff + DATA_FRAME_WS_HEADER_SIZE, skb->data + 12, len - 12);	priv->tx_buff_tail += len - 12 + DATA_FRAME_WS_HEADER_SIZE;	/* low bit of first byte of destination tells us if broadcast */	tx_update_descriptor(priv, *(skb->data) & 0x01, len + 18, buff, TX_PACKET_TYPE_DATA);	dev->trans_start = jiffies;	priv->stats.tx_bytes += len;	spin_unlock_irqrestore(&priv->irqlock, flags);	spin_unlock_bh(&priv->timerlock);	dev_kfree_skb(skb);	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区精品3399| 国产三区在线成人av| 亚洲国产wwwccc36天堂| 欧美日韩精品二区第二页| 亚洲永久精品国产| 欧美一区二区三区在线观看 | 亚洲精品一区二区三区四区高清| 久久国产成人午夜av影院| 久久久综合网站| 91在线porny国产在线看| 亚洲影院久久精品| 欧美videos中文字幕| 高清久久久久久| 亚洲精品日日夜夜| 欧美xfplay| 91小视频免费看| 美腿丝袜亚洲一区| 国产精品私人影院| 欧美美女bb生活片| 国产成人午夜精品5599| 樱桃视频在线观看一区| 欧美一二三四在线| 99精品视频在线观看| 日本欧美一区二区三区| 中文欧美字幕免费| 欧美日韩一本到| 国产成人免费高清| 亚洲国产精品久久艾草纯爱| 久久嫩草精品久久久久| 欧美性大战久久| 狠狠色狠狠色综合| 亚洲精品老司机| 精品国产一区二区三区av性色 | 欧美视频一区二区三区在线观看| 免费的成人av| 亚洲日本护士毛茸茸| 欧美精品电影在线播放| 成人国产视频在线观看| 裸体在线国模精品偷拍| 亚洲日本在线看| 久久久久久久av麻豆果冻| 在线观看日韩一区| 成人av资源在线观看| 首页国产欧美日韩丝袜| 国产精品国产自产拍高清av王其| 欧美一区二区二区| 在线观看免费视频综合| 成人午夜电影网站| 久久精品国产99| 亚洲va欧美va国产va天堂影院| 欧美激情在线看| 欧美tickling网站挠脚心| 欧美日韩一区二区三区四区| 99re成人精品视频| 国产a精品视频| 美女诱惑一区二区| 污片在线观看一区二区| 亚洲女爱视频在线| 国产精品国产三级国产普通话蜜臀 | 国产视频一区二区在线| 日韩一级免费一区| 欧美福利视频导航| 欧美三区免费完整视频在线观看| 99久久久精品免费观看国产蜜| 国产激情91久久精品导航 | 精品国产人成亚洲区| 777xxx欧美| 欧美人与性动xxxx| 欧美性大战久久| 色婷婷av一区二区三区大白胸| 成人动漫在线一区| aaa国产一区| 99re在线视频这里只有精品| 不卡的av网站| www.视频一区| 91最新地址在线播放| 成人av综合在线| 99麻豆久久久国产精品免费 | 欧美精品一区男女天堂| 日韩精品中午字幕| 精品少妇一区二区三区免费观看| 欧美一区二区三区视频免费播放| 欧美精品久久天天躁| 日韩一区二区麻豆国产| 日韩精品一区二区三区视频播放 | 成人app软件下载大全免费| av亚洲精华国产精华精| 99精品久久免费看蜜臀剧情介绍| a在线欧美一区| 色婷婷综合视频在线观看| 在线亚洲欧美专区二区| 欧美三级欧美一级| 91精品视频网| 久久综合久久久久88| 国产亚洲一区二区三区四区 | 国内精品第一页| 国产精品一区二区在线观看不卡| 国产精品系列在线观看| 成人黄色av电影| 欧美午夜电影在线播放| 欧美精品九九99久久| 精品国产免费人成在线观看| 国产日韩欧美一区二区三区乱码 | 日本一区二区视频在线观看| 亚洲三级理论片| 日本欧美一区二区| 国产乱码一区二区三区| 91亚洲精品久久久蜜桃网站 | 老司机免费视频一区二区三区| 国产精品一级黄| 色哟哟国产精品| 日韩精品一区在线观看| 国产精品免费av| 亚洲444eee在线观看| 国产福利一区在线| 在线一区二区三区四区五区| 日韩午夜在线播放| 自拍偷自拍亚洲精品播放| 蜜臀va亚洲va欧美va天堂| 成人久久18免费网站麻豆| 欧美疯狂做受xxxx富婆| 国产欧美一区二区三区在线老狼| 亚洲人成7777| 国产在线不卡一区| 欧美性色欧美a在线播放| 久久先锋影音av鲁色资源| 亚洲成在人线在线播放| 国产精品一色哟哟哟| 91精品国产入口| 亚洲另类中文字| 国产精品亚洲专一区二区三区| 欧美日韩成人综合天天影院| 国产精品丝袜一区| 久久狠狠亚洲综合| 欧美午夜精品一区| 亚洲人精品午夜| 国产成人一级电影| 日韩欧美色电影| 亚洲成人动漫精品| 在线精品视频免费播放| 国产精品三级久久久久三级| 精品一区二区三区在线播放| 欧美日韩成人一区二区| 亚洲情趣在线观看| 成人aa视频在线观看| 久久精品视频在线看| 美国欧美日韩国产在线播放| 欧美亚洲自拍偷拍| 一区二区三区在线免费观看| 不卡视频在线观看| 国产精品美女视频| 国产成人精品亚洲日本在线桃色| 日韩欧美国产一区二区三区| 亚洲国产精品麻豆| 日本久久电影网| 一区二区三区在线观看网站| youjizz久久| 亚洲欧美在线视频| thepron国产精品| 中文字幕高清一区| 懂色av一区二区三区蜜臀| 2020国产精品久久精品美国| 九一九一国产精品| 欧美videos中文字幕| 精品在线亚洲视频| 久久久久久久久久久久久夜| 国产综合久久久久影院| 精品国产凹凸成av人导航| 久久国产尿小便嘘嘘尿| 欧美zozo另类异族| 国产激情视频一区二区三区欧美| 国产色婷婷亚洲99精品小说| 成人免费的视频| 亚洲男人的天堂av| 欧美亚洲动漫另类| 日韩av不卡一区二区| 欧美变态tickling挠脚心| 国产一区二区三区不卡在线观看| 久久一日本道色综合| 东方aⅴ免费观看久久av| 国产精品免费丝袜| 欧美午夜影院一区| 日韩不卡在线观看日韩不卡视频| 日韩一级二级三级| 国产成人在线影院| 一区二区三区丝袜| 在线电影院国产精品| 激情欧美日韩一区二区| 国产精品网曝门| 欧美亚洲另类激情小说| 日本美女一区二区三区| 久久久久久97三级| 91小视频在线免费看| 视频一区视频二区中文| 久久亚洲精品国产精品紫薇| 99久久综合色| 视频一区二区不卡| 欧美精彩视频一区二区三区| 日本精品一区二区三区四区的功能| 日本伊人色综合网|