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

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

?? ixgbe_main.c

?? linux 內核源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*******************************************************************************  Intel 10 Gigabit PCI Express Linux driver  Copyright(c) 1999 - 2007 Intel Corporation.  This program is free software; you can redistribute it and/or modify it  under the terms and conditions of the GNU General Public License,  version 2, as published by the Free Software Foundation.  This program is distributed in the hope 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.,  51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.  The full GNU General Public License is included in this distribution in  the file called "COPYING".  Contact Information:  Linux NICS <linux.nics@intel.com>  e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>  Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497*******************************************************************************/#include <linux/types.h>#include <linux/module.h>#include <linux/pci.h>#include <linux/netdevice.h>#include <linux/vmalloc.h>#include <linux/string.h>#include <linux/in.h>#include <linux/ip.h>#include <linux/tcp.h>#include <linux/ipv6.h>#include <net/checksum.h>#include <net/ip6_checksum.h>#include <linux/ethtool.h>#include <linux/if_vlan.h>#include "ixgbe.h"#include "ixgbe_common.h"char ixgbe_driver_name[] = "ixgbe";static const char ixgbe_driver_string[] =	"Intel(R) 10 Gigabit PCI Express Network Driver";#define DRV_VERSION "1.1.18"const char ixgbe_driver_version[] = DRV_VERSION;static const char ixgbe_copyright[] =	 "Copyright (c) 1999-2007 Intel Corporation.";static const struct ixgbe_info *ixgbe_info_tbl[] = {	[board_82598AF]			= &ixgbe_82598AF_info,	[board_82598EB]			= &ixgbe_82598EB_info,	[board_82598AT]			= &ixgbe_82598AT_info,};/* ixgbe_pci_tbl - PCI Device ID Table * * Wildcard entries (PCI_ANY_ID) should come last * Last entry must be all 0s * * { Vendor ID, Device ID, SubVendor ID, SubDevice ID, *   Class, Class Mask, private data (not used) } */static struct pci_device_id ixgbe_pci_tbl[] = {	{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598AF_DUAL_PORT),	 board_82598AF },	{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598AF_SINGLE_PORT),	 board_82598AF },	{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598AT_DUAL_PORT),	 board_82598AT },	{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598EB_CX4),	 board_82598EB },	/* required last entry */	{0, }};MODULE_DEVICE_TABLE(pci, ixgbe_pci_tbl);MODULE_AUTHOR("Intel Corporation, <linux.nics@intel.com>");MODULE_DESCRIPTION("Intel(R) 10 Gigabit PCI Express Network Driver");MODULE_LICENSE("GPL");MODULE_VERSION(DRV_VERSION);#define DEFAULT_DEBUG_LEVEL_SHIFT 3#ifdef DEBUG/** * ixgbe_get_hw_dev_name - return device name string * used by hardware layer to print debugging information **/char *ixgbe_get_hw_dev_name(struct ixgbe_hw *hw){	struct ixgbe_adapter *adapter = hw->back;	struct net_device *netdev = adapter->netdev;	return netdev->name;}#endifstatic void ixgbe_set_ivar(struct ixgbe_adapter *adapter, u16 int_alloc_entry,			   u8 msix_vector){	u32 ivar, index;	msix_vector |= IXGBE_IVAR_ALLOC_VAL;	index = (int_alloc_entry >> 2) & 0x1F;	ivar = IXGBE_READ_REG(&adapter->hw, IXGBE_IVAR(index));	ivar &= ~(0xFF << (8 * (int_alloc_entry & 0x3)));	ivar |= (msix_vector << (8 * (int_alloc_entry & 0x3)));	IXGBE_WRITE_REG(&adapter->hw, IXGBE_IVAR(index), ivar);}static void ixgbe_unmap_and_free_tx_resource(struct ixgbe_adapter *adapter,					     struct ixgbe_tx_buffer					     *tx_buffer_info){	if (tx_buffer_info->dma) {		pci_unmap_page(adapter->pdev,			       tx_buffer_info->dma,			       tx_buffer_info->length, PCI_DMA_TODEVICE);		tx_buffer_info->dma = 0;	}	if (tx_buffer_info->skb) {		dev_kfree_skb_any(tx_buffer_info->skb);		tx_buffer_info->skb = NULL;	}	/* tx_buffer_info must be completely set up in the transmit path */}static inline bool ixgbe_check_tx_hang(struct ixgbe_adapter *adapter,				       struct ixgbe_ring *tx_ring,				       unsigned int eop,				       union ixgbe_adv_tx_desc *eop_desc){	/* Detect a transmit hang in hardware, this serializes the	 * check with the clearing of time_stamp and movement of i */	adapter->detect_tx_hung = false;	if (tx_ring->tx_buffer_info[eop].dma &&	    time_after(jiffies, tx_ring->tx_buffer_info[eop].time_stamp + HZ) &&	    !(IXGBE_READ_REG(&adapter->hw, IXGBE_TFCS) & IXGBE_TFCS_TXOFF)) {		/* detected Tx unit hang */		DPRINTK(DRV, ERR, "Detected Tx Unit Hang\n"			"  TDH                  <%x>\n"			"  TDT                  <%x>\n"			"  next_to_use          <%x>\n"			"  next_to_clean        <%x>\n"			"tx_buffer_info[next_to_clean]\n"			"  time_stamp           <%lx>\n"			"  next_to_watch        <%x>\n"			"  jiffies              <%lx>\n"			"  next_to_watch.status <%x>\n",			readl(adapter->hw.hw_addr + tx_ring->head),			readl(adapter->hw.hw_addr + tx_ring->tail),			tx_ring->next_to_use,			tx_ring->next_to_clean,			tx_ring->tx_buffer_info[eop].time_stamp,			eop, jiffies, eop_desc->wb.status);		return true;	}	return false;}/** * ixgbe_clean_tx_irq - Reclaim resources after transmit completes * @adapter: board private structure **/static bool ixgbe_clean_tx_irq(struct ixgbe_adapter *adapter,				    struct ixgbe_ring *tx_ring){	struct net_device *netdev = adapter->netdev;	union ixgbe_adv_tx_desc *tx_desc, *eop_desc;	struct ixgbe_tx_buffer *tx_buffer_info;	unsigned int i, eop;	bool cleaned = false;	int count = 0;	i = tx_ring->next_to_clean;	eop = tx_ring->tx_buffer_info[i].next_to_watch;	eop_desc = IXGBE_TX_DESC_ADV(*tx_ring, eop);	while (eop_desc->wb.status & cpu_to_le32(IXGBE_TXD_STAT_DD)) {		for (cleaned = false; !cleaned;) {			tx_desc = IXGBE_TX_DESC_ADV(*tx_ring, i);			tx_buffer_info = &tx_ring->tx_buffer_info[i];			cleaned = (i == eop);			tx_ring->stats.bytes += tx_buffer_info->length;			ixgbe_unmap_and_free_tx_resource(adapter,							 tx_buffer_info);			tx_desc->wb.status = 0;			i++;			if (i == tx_ring->count)				i = 0;		}		tx_ring->stats.packets++;		eop = tx_ring->tx_buffer_info[i].next_to_watch;		eop_desc = IXGBE_TX_DESC_ADV(*tx_ring, eop);		/* weight of a sort for tx, avoid endless transmit cleanup */		if (count++ >= tx_ring->work_limit)			break;	}	tx_ring->next_to_clean = i;#define TX_WAKE_THRESHOLD 32	spin_lock(&tx_ring->tx_lock);	if (cleaned && netif_carrier_ok(netdev) &&	    (IXGBE_DESC_UNUSED(tx_ring) >= TX_WAKE_THRESHOLD) &&	    !test_bit(__IXGBE_DOWN, &adapter->state))		netif_wake_queue(netdev);	spin_unlock(&tx_ring->tx_lock);	if (adapter->detect_tx_hung)		if (ixgbe_check_tx_hang(adapter, tx_ring, eop, eop_desc))			netif_stop_queue(netdev);	if (count >= tx_ring->work_limit)		IXGBE_WRITE_REG(&adapter->hw, IXGBE_EICS, tx_ring->eims_value);	return cleaned;}/** * ixgbe_receive_skb - Send a completed packet up the stack * @adapter: board private structure * @skb: packet to send up * @is_vlan: packet has a VLAN tag * @tag: VLAN tag from descriptor **/static void ixgbe_receive_skb(struct ixgbe_adapter *adapter,			      struct sk_buff *skb, bool is_vlan,			      u16 tag){	if (!(adapter->flags & IXGBE_FLAG_IN_NETPOLL)) {		if (adapter->vlgrp && is_vlan)			vlan_hwaccel_receive_skb(skb, adapter->vlgrp, tag);		else			netif_receive_skb(skb);	} else {		if (adapter->vlgrp && is_vlan)			vlan_hwaccel_rx(skb, adapter->vlgrp, tag);		else			netif_rx(skb);	}}static inline void ixgbe_rx_checksum(struct ixgbe_adapter *adapter,					 u32 status_err,					 struct sk_buff *skb){	skb->ip_summed = CHECKSUM_NONE;	/* Ignore Checksum bit is set */	if ((status_err & IXGBE_RXD_STAT_IXSM) ||		     !(adapter->flags & IXGBE_FLAG_RX_CSUM_ENABLED))		return;	/* TCP/UDP checksum error bit is set */	if (status_err & (IXGBE_RXDADV_ERR_TCPE | IXGBE_RXDADV_ERR_IPE)) {		/* let the stack verify checksum errors */		adapter->hw_csum_rx_error++;		return;	}	/* It must be a TCP or UDP packet with a valid checksum */	if (status_err & (IXGBE_RXD_STAT_L4CS | IXGBE_RXD_STAT_UDPCS))		skb->ip_summed = CHECKSUM_UNNECESSARY;	adapter->hw_csum_rx_good++;}/** * ixgbe_alloc_rx_buffers - Replace used receive buffers; packet split * @adapter: address of board private structure **/static void ixgbe_alloc_rx_buffers(struct ixgbe_adapter *adapter,				       struct ixgbe_ring *rx_ring,				       int cleaned_count){	struct net_device *netdev = adapter->netdev;	struct pci_dev *pdev = adapter->pdev;	union ixgbe_adv_rx_desc *rx_desc;	struct ixgbe_rx_buffer *rx_buffer_info;	struct sk_buff *skb;	unsigned int i;	unsigned int bufsz = adapter->rx_buf_len + NET_IP_ALIGN;	i = rx_ring->next_to_use;	rx_buffer_info = &rx_ring->rx_buffer_info[i];	while (cleaned_count--) {		rx_desc = IXGBE_RX_DESC_ADV(*rx_ring, i);		if (!rx_buffer_info->page &&				(adapter->flags & IXGBE_FLAG_RX_PS_ENABLED)) {			rx_buffer_info->page = alloc_page(GFP_ATOMIC);			if (!rx_buffer_info->page) {				adapter->alloc_rx_page_failed++;				goto no_buffers;			}			rx_buffer_info->page_dma =			    pci_map_page(pdev, rx_buffer_info->page,					 0, PAGE_SIZE, PCI_DMA_FROMDEVICE);		}		if (!rx_buffer_info->skb) {			skb = netdev_alloc_skb(netdev, bufsz);			if (!skb) {				adapter->alloc_rx_buff_failed++;				goto no_buffers;			}			/*			 * Make buffer alignment 2 beyond a 16 byte boundary			 * this will result in a 16 byte aligned IP header after			 * the 14 byte MAC header is removed			 */			skb_reserve(skb, NET_IP_ALIGN);			rx_buffer_info->skb = skb;			rx_buffer_info->dma = pci_map_single(pdev, skb->data,							  bufsz,							  PCI_DMA_FROMDEVICE);		}		/* Refresh the desc even if buffer_addrs didn't change because		 * each write-back erases this info. */		if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) {			rx_desc->read.pkt_addr =			    cpu_to_le64(rx_buffer_info->page_dma);			rx_desc->read.hdr_addr =					cpu_to_le64(rx_buffer_info->dma);		} else {			rx_desc->read.pkt_addr =					cpu_to_le64(rx_buffer_info->dma);		}		i++;		if (i == rx_ring->count)			i = 0;		rx_buffer_info = &rx_ring->rx_buffer_info[i];	}no_buffers:	if (rx_ring->next_to_use != i) {		rx_ring->next_to_use = i;		if (i-- == 0)			i = (rx_ring->count - 1);		/*		 * Force memory writes to complete before letting h/w		 * know there are new descriptors to fetch.  (Only		 * applicable for weak-ordered memory model archs,		 * such as IA-64).		 */		wmb();		writel(i, adapter->hw.hw_addr + rx_ring->tail);	}}static bool ixgbe_clean_rx_irq(struct ixgbe_adapter *adapter,			       struct ixgbe_ring *rx_ring,			       int *work_done, int work_to_do){	struct net_device *netdev = adapter->netdev;	struct pci_dev *pdev = adapter->pdev;	union ixgbe_adv_rx_desc *rx_desc, *next_rxd;	struct ixgbe_rx_buffer *rx_buffer_info, *next_buffer;	struct sk_buff *skb;	unsigned int i;	u32 upper_len, len, staterr;	u16 hdr_info, vlan_tag;	bool is_vlan, cleaned = false;	int cleaned_count = 0;	i = rx_ring->next_to_clean;	upper_len = 0;	rx_desc = IXGBE_RX_DESC_ADV(*rx_ring, i);	staterr = le32_to_cpu(rx_desc->wb.upper.status_error);	rx_buffer_info = &rx_ring->rx_buffer_info[i];	is_vlan = (staterr & IXGBE_RXD_STAT_VP);	vlan_tag = le16_to_cpu(rx_desc->wb.upper.vlan);	while (staterr & IXGBE_RXD_STAT_DD) {		if (*work_done >= work_to_do)			break;		(*work_done)++;		if (adapter->flags & IXGBE_FLAG_RX_PS_ENABLED) {			hdr_info =			    le16_to_cpu(rx_desc->wb.lower.lo_dword.hdr_info);			len =			    ((hdr_info & IXGBE_RXDADV_HDRBUFLEN_MASK) >>			     IXGBE_RXDADV_HDRBUFLEN_SHIFT);			if (hdr_info & IXGBE_RXDADV_SPH)				adapter->rx_hdr_split++;			if (len > IXGBE_RX_HDR_SIZE)				len = IXGBE_RX_HDR_SIZE;			upper_len = le16_to_cpu(rx_desc->wb.upper.length);		} else			len = le16_to_cpu(rx_desc->wb.upper.length);		cleaned = true;		skb = rx_buffer_info->skb;		prefetch(skb->data - NET_IP_ALIGN);		rx_buffer_info->skb = NULL;		if (len && !skb_shinfo(skb)->nr_frags) {			pci_unmap_single(pdev, rx_buffer_info->dma,					 adapter->rx_buf_len + NET_IP_ALIGN,					 PCI_DMA_FROMDEVICE);			skb_put(skb, len);		}		if (upper_len) {			pci_unmap_page(pdev, rx_buffer_info->page_dma,				       PAGE_SIZE, PCI_DMA_FROMDEVICE);			rx_buffer_info->page_dma = 0;			skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags,					   rx_buffer_info->page, 0, upper_len);			rx_buffer_info->page = NULL;			skb->len += upper_len;			skb->data_len += upper_len;			skb->truesize += upper_len;		}		i++;		if (i == rx_ring->count)			i = 0;		next_buffer = &rx_ring->rx_buffer_info[i];		next_rxd = IXGBE_RX_DESC_ADV(*rx_ring, i);		prefetch(next_rxd);		cleaned_count++;		if (staterr & IXGBE_RXD_STAT_EOP) {			rx_ring->stats.packets++;			rx_ring->stats.bytes += skb->len;		} else {			rx_buffer_info->skb = next_buffer->skb;			rx_buffer_info->dma = next_buffer->dma;			next_buffer->skb = skb;			adapter->non_eop_descs++;			goto next_desc;		}		if (staterr & IXGBE_RXDADV_ERR_FRAME_ERR_MASK) {			dev_kfree_skb_irq(skb);			goto next_desc;		}		ixgbe_rx_checksum(adapter, staterr, skb);		skb->protocol = eth_type_trans(skb, netdev);		ixgbe_receive_skb(adapter, skb, is_vlan, vlan_tag);		netdev->last_rx = jiffies;next_desc:		rx_desc->wb.upper.status_error = 0;		/* return some buffers to hardware, one at a time is too slow */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美www视频| 国产精品伦理一区二区| 欧美日韩激情一区二区| 日韩一区二区电影| 国产精品你懂的| 亚洲国产色一区| 韩国v欧美v日本v亚洲v| 丁香天五香天堂综合| 色综合久久久久久久久久久| 欧美三级在线播放| 久久新电视剧免费观看| 一区二区三区在线视频观看58| 美女网站一区二区| 91久久精品国产91性色tv| 久久天堂av综合合色蜜桃网| 一区二区三区自拍| 成人黄色av电影| 久久九九影视网| 国产在线播精品第三| 欧美午夜电影在线播放| 国产精品成人免费在线| 国产乱码字幕精品高清av | 国产精品色哟哟网站| 免费观看一级特黄欧美大片| 在线看国产一区| 亚洲精品成人a在线观看| 成人中文字幕合集| 国产午夜精品久久| 欧美日韩免费电影| 亚洲精品久久7777| 在线观看91视频| 亚洲成a人片在线不卡一二三区| 99久久精品情趣| 亚洲免费三区一区二区| 97久久超碰国产精品| 中文字幕中文乱码欧美一区二区| 国产成人高清在线| 国产精品国产a| 色天使色偷偷av一区二区| 一区二区三区在线观看欧美| 欧洲国产伦久久久久久久| 亚洲综合一区在线| 91精品国产综合久久国产大片| 首页国产欧美久久| 久久影音资源网| av一区二区三区| 日日嗨av一区二区三区四区| 91精品国产一区二区三区| 黄色日韩网站视频| 一区二区不卡在线视频 午夜欧美不卡在| 99久久精品国产网站| 午夜欧美大尺度福利影院在线看| 欧美一区2区视频在线观看| 国内一区二区视频| 亚洲一区二区三区中文字幕在线| 欧美久久久久久蜜桃| 成人免费va视频| 奇米精品一区二区三区在线观看一| 91精品国产一区二区人妖| 天天做天天摸天天爽国产一区| 欧美日本乱大交xxxxx| 精品伊人久久久久7777人| 久久先锋影音av| 在线日韩一区二区| 日本不卡一区二区| 综合色天天鬼久久鬼色| 欧美午夜精品一区| 国产成人高清视频| 亚洲最大的成人av| 亚洲国产精品二十页| 欧美日韩一级片在线观看| 国产乱理伦片在线观看夜一区| 国产精品国产三级国产普通话蜜臀| 欧美在线免费视屏| 成人精品国产福利| 美国十次综合导航| 日本不卡123| 亚洲18女电影在线观看| 中文字幕精品一区二区三区精品| 欧美精品xxxxbbbb| 91福利国产精品| 91影视在线播放| 成人h动漫精品| 国产精品一区二区视频| 国产真实精品久久二三区| 亚洲成人一区二区| 美女视频一区二区三区| 另类的小说在线视频另类成人小视频在线 | 婷婷国产在线综合| 一区二区三区国产精品| 中文欧美字幕免费| 国产精品国产精品国产专区不片 | 亚洲电影一级黄| 亚洲一区二区综合| 亚洲亚洲人成综合网络| 亚洲永久免费视频| 爽爽淫人综合网网站| 香港成人在线视频| 国产一区二区三区综合| 国产九九视频一区二区三区| 不卡av免费在线观看| 99久久精品免费看国产免费软件| www..com久久爱| 欧美精品vⅰdeose4hd| 精品少妇一区二区三区在线播放| 欧美大黄免费观看| 中文字幕一区二区三区乱码在线 | 91搞黄在线观看| 69久久夜色精品国产69蝌蚪网| 久久亚洲捆绑美女| 亚洲国产精品尤物yw在线观看| 精品在线观看免费| 在线视频你懂得一区二区三区| 久久久久久久久久久久久夜| 亚洲一区二区美女| 色综合久久88色综合天天| 精品国精品国产尤物美女| 亚洲无人区一区| 91极品美女在线| 亚洲狠狠爱一区二区三区| 色综合天天综合狠狠| 久久久久久久久蜜桃| 精品无码三级在线观看视频| 欧美色图在线观看| 亚洲电影一区二区| 欧美精选午夜久久久乱码6080| 亚洲最大的成人av| 欧美日韩国产a| 麻豆91在线看| 国产亚洲欧美日韩俺去了| 不卡在线视频中文字幕| 亚洲欧美日韩国产手机在线 | 亚洲一区二区三区中文字幕| 色天使久久综合网天天| 丝袜亚洲另类欧美| 精品国产髙清在线看国产毛片| 精品午夜久久福利影院| 国产精品美女久久久久aⅴ| 色八戒一区二区三区| 丝袜美腿亚洲一区二区图片| 日韩欧美成人激情| 成人精品视频一区| 日韩精品一级二级| 国产亚洲一区二区三区四区| 91麻豆国产福利精品| 麻豆精品精品国产自在97香蕉| 日本一区二区三区久久久久久久久不| 成人综合激情网| 亚洲va欧美va人人爽| 一色桃子久久精品亚洲| 日韩三级中文字幕| 色狠狠av一区二区三区| 国产成都精品91一区二区三| 亚洲高清不卡在线观看| 国产精品你懂的| 亚洲成av人片在线观看| 亚洲少妇最新在线视频| 精品欧美乱码久久久久久| 色悠悠亚洲一区二区| 国产伦精一区二区三区| 蜜桃av噜噜一区二区三区小说| 青娱乐精品视频在线| 午夜视频一区二区| 亚洲成人午夜影院| 亚洲最大成人综合| 亚洲一区二区三区不卡国产欧美| 国产精品毛片久久久久久久| 国产精品久久久久影院色老大| 国产亚洲欧美激情| 欧美激情一区二区三区四区| 久久久国产午夜精品 | 日本vs亚洲vs韩国一区三区| 视频一区视频二区中文字幕| 亚洲国产成人高清精品| 亚洲精品一二三四区| 亚洲美女电影在线| 一区二区三区四区视频精品免费 | 成人国产电影网| 91丝袜美女网| 欧美日韩aaa| 亚洲精品一区二区三区在线观看| 欧美成人精品高清在线播放| 久久久久久久久久久久久久久99 | 国产成人av自拍| 欧美日韩免费不卡视频一区二区三区 | 欧美片网站yy| 久久久亚洲高清| 一区二区在线观看免费| 免费观看30秒视频久久| 丁香桃色午夜亚洲一区二区三区| 欧洲在线/亚洲| 国产三级精品三级在线专区| 亚洲五码中文字幕| zzijzzij亚洲日本少妇熟睡| 欧美日韩国产成人在线91 | 精品在线观看免费| 欧美日韩国产电影| 日韩一区欧美一区| 九色综合国产一区二区三区| 欧美写真视频网站|