mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-04-03 08:22:10 +00:00
Merge branch 'upstream-davem' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6
This commit is contained in:
commit
b793b3a75e
@ -1172,7 +1172,7 @@ config ETH16I
|
|||||||
|
|
||||||
config NE2000
|
config NE2000
|
||||||
tristate "NE2000/NE1000 support"
|
tristate "NE2000/NE1000 support"
|
||||||
depends on NET_ISA || (Q40 && m) || M32R || TOSHIBA_RBTX4927 || TOSHIBA_RBTX4938
|
depends on NET_ISA || (Q40 && m) || M32R || MACH_TX49XX
|
||||||
select CRC32
|
select CRC32
|
||||||
---help---
|
---help---
|
||||||
If you have a network (Ethernet) card of this type, say Y and read
|
If you have a network (Ethernet) card of this type, say Y and read
|
||||||
|
@ -52,7 +52,6 @@
|
|||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/moduleparam.h>
|
#include <linux/moduleparam.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/errno.h>
|
#include <linux/errno.h>
|
||||||
#include <linux/ioport.h>
|
#include <linux/ioport.h>
|
||||||
|
@ -551,7 +551,7 @@ static int eth_poll(struct napi_struct *napi, int budget)
|
|||||||
if ((skb = netdev_alloc_skb(dev, RX_BUFF_SIZE))) {
|
if ((skb = netdev_alloc_skb(dev, RX_BUFF_SIZE))) {
|
||||||
phys = dma_map_single(&dev->dev, skb->data,
|
phys = dma_map_single(&dev->dev, skb->data,
|
||||||
RX_BUFF_SIZE, DMA_FROM_DEVICE);
|
RX_BUFF_SIZE, DMA_FROM_DEVICE);
|
||||||
if (dma_mapping_error(phys)) {
|
if (dma_mapping_error(&dev->dev, phys)) {
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
skb = NULL;
|
skb = NULL;
|
||||||
}
|
}
|
||||||
@ -698,7 +698,7 @@ static int eth_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
phys = dma_map_single(&dev->dev, mem, bytes, DMA_TO_DEVICE);
|
phys = dma_map_single(&dev->dev, mem, bytes, DMA_TO_DEVICE);
|
||||||
if (dma_mapping_error(phys)) {
|
if (dma_mapping_error(&dev->dev, phys)) {
|
||||||
#ifdef __ARMEB__
|
#ifdef __ARMEB__
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
#else
|
#else
|
||||||
@ -883,7 +883,7 @@ static int init_queues(struct port *port)
|
|||||||
desc->buf_len = MAX_MRU;
|
desc->buf_len = MAX_MRU;
|
||||||
desc->data = dma_map_single(&port->netdev->dev, data,
|
desc->data = dma_map_single(&port->netdev->dev, data,
|
||||||
RX_BUFF_SIZE, DMA_FROM_DEVICE);
|
RX_BUFF_SIZE, DMA_FROM_DEVICE);
|
||||||
if (dma_mapping_error(desc->data)) {
|
if (dma_mapping_error(&port->netdev->dev, desc->data)) {
|
||||||
free_buffer(buff);
|
free_buffer(buff);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
@ -355,7 +355,7 @@ static int atl1e_set_wol(struct net_device *netdev, struct ethtool_wolinfo *wol)
|
|||||||
struct atl1e_adapter *adapter = netdev_priv(netdev);
|
struct atl1e_adapter *adapter = netdev_priv(netdev);
|
||||||
|
|
||||||
if (wol->wolopts & (WAKE_ARP | WAKE_MAGICSECURE |
|
if (wol->wolopts & (WAKE_ARP | WAKE_MAGICSECURE |
|
||||||
WAKE_MCAST | WAKE_BCAST | WAKE_MCAST))
|
WAKE_UCAST | WAKE_MCAST | WAKE_BCAST))
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
/* these settings will always override what we currently have */
|
/* these settings will always override what we currently have */
|
||||||
adapter->wol = 0;
|
adapter->wol = 0;
|
||||||
|
@ -807,7 +807,7 @@ err_out:
|
|||||||
static int au1000_init(struct net_device *dev)
|
static int au1000_init(struct net_device *dev)
|
||||||
{
|
{
|
||||||
struct au1000_private *aup = (struct au1000_private *) dev->priv;
|
struct au1000_private *aup = (struct au1000_private *) dev->priv;
|
||||||
u32 flags;
|
unsigned long flags;
|
||||||
int i;
|
int i;
|
||||||
u32 control;
|
u32 control;
|
||||||
|
|
||||||
|
@ -554,7 +554,7 @@ static int ax_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|||||||
|
|
||||||
spin_lock_irqsave(&ax->mii_lock, flags);
|
spin_lock_irqsave(&ax->mii_lock, flags);
|
||||||
mii_ethtool_gset(&ax->mii, cmd);
|
mii_ethtool_gset(&ax->mii, cmd);
|
||||||
spin_lock_irqsave(&ax->mii_lock, flags);
|
spin_unlock_irqrestore(&ax->mii_lock, flags);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -567,7 +567,7 @@ static int ax_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
|
|||||||
|
|
||||||
spin_lock_irqsave(&ax->mii_lock, flags);
|
spin_lock_irqsave(&ax->mii_lock, flags);
|
||||||
rc = mii_ethtool_sset(&ax->mii, cmd);
|
rc = mii_ethtool_sset(&ax->mii, cmd);
|
||||||
spin_lock_irqsave(&ax->mii_lock, flags);
|
spin_unlock_irqrestore(&ax->mii_lock, flags);
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,6 @@
|
|||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/ethtool.h>
|
#include <linux/ethtool.h>
|
||||||
#include <linux/mutex.h>
|
#include <linux/mutex.h>
|
||||||
#include <linux/version.h>
|
|
||||||
|
|
||||||
#include "bnx2x_reg.h"
|
#include "bnx2x_reg.h"
|
||||||
#include "bnx2x_fw_defs.h"
|
#include "bnx2x_fw_defs.h"
|
||||||
|
@ -44,7 +44,6 @@
|
|||||||
#include <net/ip.h>
|
#include <net/ip.h>
|
||||||
#include <net/tcp.h>
|
#include <net/tcp.h>
|
||||||
#include <net/checksum.h>
|
#include <net/checksum.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <net/ip6_checksum.h>
|
#include <net/ip6_checksum.h>
|
||||||
#include <linux/workqueue.h>
|
#include <linux/workqueue.h>
|
||||||
#include <linux/crc32.h>
|
#include <linux/crc32.h>
|
||||||
|
@ -26,7 +26,6 @@
|
|||||||
#include <linux/errno.h>
|
#include <linux/errno.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/version.h>
|
|
||||||
|
|
||||||
#include <linux/netdevice.h>
|
#include <linux/netdevice.h>
|
||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
|
@ -389,7 +389,7 @@
|
|||||||
|
|
||||||
/* Interrupt Cause Set */
|
/* Interrupt Cause Set */
|
||||||
#define E1000_ICS_LSC E1000_ICR_LSC /* Link Status Change */
|
#define E1000_ICS_LSC E1000_ICR_LSC /* Link Status Change */
|
||||||
#define E1000_ICS_RXDMT0 E1000_ICR_RXDMT0 /* rx desc min. threshold */
|
#define E1000_ICS_RXSEQ E1000_ICR_RXSEQ /* Rx sequence error */
|
||||||
#define E1000_ICS_RXDMT0 E1000_ICR_RXDMT0 /* Rx desc min. threshold */
|
#define E1000_ICS_RXDMT0 E1000_ICR_RXDMT0 /* Rx desc min. threshold */
|
||||||
|
|
||||||
/* Transmit Descriptor Control */
|
/* Transmit Descriptor Control */
|
||||||
|
@ -326,6 +326,7 @@ struct e1000_info {
|
|||||||
#define FLAG_RX_CSUM_ENABLED (1 << 28)
|
#define FLAG_RX_CSUM_ENABLED (1 << 28)
|
||||||
#define FLAG_TSO_FORCE (1 << 29)
|
#define FLAG_TSO_FORCE (1 << 29)
|
||||||
#define FLAG_RX_RESTART_NOW (1 << 30)
|
#define FLAG_RX_RESTART_NOW (1 << 30)
|
||||||
|
#define FLAG_MSI_TEST_FAILED (1 << 31)
|
||||||
|
|
||||||
#define E1000_RX_DESC_PS(R, i) \
|
#define E1000_RX_DESC_PS(R, i) \
|
||||||
(&(((union e1000_rx_desc_packet_split *)((R).desc))[i]))
|
(&(((union e1000_rx_desc_packet_split *)((R).desc))[i]))
|
||||||
|
@ -177,7 +177,7 @@ static u32 e1000_get_link(struct net_device *netdev)
|
|||||||
u32 status;
|
u32 status;
|
||||||
|
|
||||||
status = er32(STATUS);
|
status = er32(STATUS);
|
||||||
return (status & E1000_STATUS_LU);
|
return (status & E1000_STATUS_LU) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int e1000_set_spd_dplx(struct e1000_adapter *adapter, u16 spddplx)
|
static int e1000_set_spd_dplx(struct e1000_adapter *adapter, u16 spddplx)
|
||||||
|
@ -510,9 +510,12 @@ static bool e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
|||||||
netdev_alloc_skb(netdev, length + NET_IP_ALIGN);
|
netdev_alloc_skb(netdev, length + NET_IP_ALIGN);
|
||||||
if (new_skb) {
|
if (new_skb) {
|
||||||
skb_reserve(new_skb, NET_IP_ALIGN);
|
skb_reserve(new_skb, NET_IP_ALIGN);
|
||||||
memcpy(new_skb->data - NET_IP_ALIGN,
|
skb_copy_to_linear_data_offset(new_skb,
|
||||||
skb->data - NET_IP_ALIGN,
|
-NET_IP_ALIGN,
|
||||||
length + NET_IP_ALIGN);
|
(skb->data -
|
||||||
|
NET_IP_ALIGN),
|
||||||
|
(length +
|
||||||
|
NET_IP_ALIGN));
|
||||||
/* save the skb in buffer_info as good */
|
/* save the skb in buffer_info as good */
|
||||||
buffer_info->skb = skb;
|
buffer_info->skb = skb;
|
||||||
skb = new_skb;
|
skb = new_skb;
|
||||||
@ -1233,26 +1236,36 @@ static irqreturn_t e1000_intr(int irq, void *data)
|
|||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* e1000_request_irq - initialize interrupts
|
||||||
|
*
|
||||||
|
* Attempts to configure interrupts using the best available
|
||||||
|
* capabilities of the hardware and kernel.
|
||||||
|
**/
|
||||||
static int e1000_request_irq(struct e1000_adapter *adapter)
|
static int e1000_request_irq(struct e1000_adapter *adapter)
|
||||||
{
|
{
|
||||||
struct net_device *netdev = adapter->netdev;
|
struct net_device *netdev = adapter->netdev;
|
||||||
irq_handler_t handler = e1000_intr;
|
|
||||||
int irq_flags = IRQF_SHARED;
|
int irq_flags = IRQF_SHARED;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (!pci_enable_msi(adapter->pdev)) {
|
if (!(adapter->flags & FLAG_MSI_TEST_FAILED)) {
|
||||||
adapter->flags |= FLAG_MSI_ENABLED;
|
err = pci_enable_msi(adapter->pdev);
|
||||||
handler = e1000_intr_msi;
|
if (!err) {
|
||||||
irq_flags = 0;
|
adapter->flags |= FLAG_MSI_ENABLED;
|
||||||
|
irq_flags = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = request_irq(adapter->pdev->irq, handler, irq_flags, netdev->name,
|
err = request_irq(adapter->pdev->irq,
|
||||||
netdev);
|
((adapter->flags & FLAG_MSI_ENABLED) ?
|
||||||
|
&e1000_intr_msi : &e1000_intr),
|
||||||
|
irq_flags, netdev->name, netdev);
|
||||||
if (err) {
|
if (err) {
|
||||||
e_err("Unable to allocate %s interrupt (return: %d)\n",
|
if (adapter->flags & FLAG_MSI_ENABLED) {
|
||||||
adapter->flags & FLAG_MSI_ENABLED ? "MSI":"INTx", err);
|
|
||||||
if (adapter->flags & FLAG_MSI_ENABLED)
|
|
||||||
pci_disable_msi(adapter->pdev);
|
pci_disable_msi(adapter->pdev);
|
||||||
|
adapter->flags &= ~FLAG_MSI_ENABLED;
|
||||||
|
}
|
||||||
|
e_err("Unable to allocate interrupt, Error: %d\n", err);
|
||||||
}
|
}
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
@ -2591,6 +2604,135 @@ err:
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* e1000_intr_msi_test - Interrupt Handler
|
||||||
|
* @irq: interrupt number
|
||||||
|
* @data: pointer to a network interface device structure
|
||||||
|
**/
|
||||||
|
static irqreturn_t e1000_intr_msi_test(int irq, void *data)
|
||||||
|
{
|
||||||
|
struct net_device *netdev = data;
|
||||||
|
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||||
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
|
u32 icr = er32(ICR);
|
||||||
|
|
||||||
|
e_dbg("%s: icr is %08X\n", netdev->name, icr);
|
||||||
|
if (icr & E1000_ICR_RXSEQ) {
|
||||||
|
adapter->flags &= ~FLAG_MSI_TEST_FAILED;
|
||||||
|
wmb();
|
||||||
|
}
|
||||||
|
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* e1000_test_msi_interrupt - Returns 0 for successful test
|
||||||
|
* @adapter: board private struct
|
||||||
|
*
|
||||||
|
* code flow taken from tg3.c
|
||||||
|
**/
|
||||||
|
static int e1000_test_msi_interrupt(struct e1000_adapter *adapter)
|
||||||
|
{
|
||||||
|
struct net_device *netdev = adapter->netdev;
|
||||||
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
/* poll_enable hasn't been called yet, so don't need disable */
|
||||||
|
/* clear any pending events */
|
||||||
|
er32(ICR);
|
||||||
|
|
||||||
|
/* free the real vector and request a test handler */
|
||||||
|
e1000_free_irq(adapter);
|
||||||
|
|
||||||
|
/* Assume that the test fails, if it succeeds then the test
|
||||||
|
* MSI irq handler will unset this flag */
|
||||||
|
adapter->flags |= FLAG_MSI_TEST_FAILED;
|
||||||
|
|
||||||
|
err = pci_enable_msi(adapter->pdev);
|
||||||
|
if (err)
|
||||||
|
goto msi_test_failed;
|
||||||
|
|
||||||
|
err = request_irq(adapter->pdev->irq, &e1000_intr_msi_test, 0,
|
||||||
|
netdev->name, netdev);
|
||||||
|
if (err) {
|
||||||
|
pci_disable_msi(adapter->pdev);
|
||||||
|
goto msi_test_failed;
|
||||||
|
}
|
||||||
|
|
||||||
|
wmb();
|
||||||
|
|
||||||
|
e1000_irq_enable(adapter);
|
||||||
|
|
||||||
|
/* fire an unusual interrupt on the test handler */
|
||||||
|
ew32(ICS, E1000_ICS_RXSEQ);
|
||||||
|
e1e_flush();
|
||||||
|
msleep(50);
|
||||||
|
|
||||||
|
e1000_irq_disable(adapter);
|
||||||
|
|
||||||
|
rmb();
|
||||||
|
|
||||||
|
if (adapter->flags & FLAG_MSI_TEST_FAILED) {
|
||||||
|
err = -EIO;
|
||||||
|
e_info("MSI interrupt test failed!\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
free_irq(adapter->pdev->irq, netdev);
|
||||||
|
pci_disable_msi(adapter->pdev);
|
||||||
|
|
||||||
|
if (err == -EIO)
|
||||||
|
goto msi_test_failed;
|
||||||
|
|
||||||
|
/* okay so the test worked, restore settings */
|
||||||
|
e_dbg("%s: MSI interrupt test succeeded!\n", netdev->name);
|
||||||
|
msi_test_failed:
|
||||||
|
/* restore the original vector, even if it failed */
|
||||||
|
e1000_request_irq(adapter);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* e1000_test_msi - Returns 0 if MSI test succeeds or INTx mode is restored
|
||||||
|
* @adapter: board private struct
|
||||||
|
*
|
||||||
|
* code flow taken from tg3.c, called with e1000 interrupts disabled.
|
||||||
|
**/
|
||||||
|
static int e1000_test_msi(struct e1000_adapter *adapter)
|
||||||
|
{
|
||||||
|
int err;
|
||||||
|
u16 pci_cmd;
|
||||||
|
|
||||||
|
if (!(adapter->flags & FLAG_MSI_ENABLED))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* disable SERR in case the MSI write causes a master abort */
|
||||||
|
pci_read_config_word(adapter->pdev, PCI_COMMAND, &pci_cmd);
|
||||||
|
pci_write_config_word(adapter->pdev, PCI_COMMAND,
|
||||||
|
pci_cmd & ~PCI_COMMAND_SERR);
|
||||||
|
|
||||||
|
err = e1000_test_msi_interrupt(adapter);
|
||||||
|
|
||||||
|
/* restore previous setting of command word */
|
||||||
|
pci_write_config_word(adapter->pdev, PCI_COMMAND, pci_cmd);
|
||||||
|
|
||||||
|
/* success ! */
|
||||||
|
if (!err)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* EIO means MSI test failed */
|
||||||
|
if (err != -EIO)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
/* back to INTx mode */
|
||||||
|
e_warn("MSI interrupt test failed, using legacy interrupt.\n");
|
||||||
|
|
||||||
|
e1000_free_irq(adapter);
|
||||||
|
|
||||||
|
err = e1000_request_irq(adapter);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* e1000_open - Called when a network interface is made active
|
* e1000_open - Called when a network interface is made active
|
||||||
* @netdev: network interface device structure
|
* @netdev: network interface device structure
|
||||||
@ -2649,6 +2791,19 @@ static int e1000_open(struct net_device *netdev)
|
|||||||
if (err)
|
if (err)
|
||||||
goto err_req_irq;
|
goto err_req_irq;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Work around PCIe errata with MSI interrupts causing some chipsets to
|
||||||
|
* ignore e1000e MSI messages, which means we need to test our MSI
|
||||||
|
* interrupt now
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
err = e1000_test_msi(adapter);
|
||||||
|
if (err) {
|
||||||
|
e_err("Interrupt allocation failed\n");
|
||||||
|
goto err_req_irq;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* From here on the code is the same as e1000e_up() */
|
/* From here on the code is the same as e1000e_up() */
|
||||||
clear_bit(__E1000_DOWN, &adapter->state);
|
clear_bit(__E1000_DOWN, &adapter->state);
|
||||||
|
|
||||||
@ -3055,7 +3210,7 @@ static void e1000_watchdog_task(struct work_struct *work)
|
|||||||
case SPEED_10:
|
case SPEED_10:
|
||||||
txb2b = 0;
|
txb2b = 0;
|
||||||
netdev->tx_queue_len = 10;
|
netdev->tx_queue_len = 10;
|
||||||
adapter->tx_timeout_factor = 14;
|
adapter->tx_timeout_factor = 16;
|
||||||
break;
|
break;
|
||||||
case SPEED_100:
|
case SPEED_100:
|
||||||
txb2b = 0;
|
txb2b = 0;
|
||||||
@ -3721,7 +3876,7 @@ static int e1000_change_mtu(struct net_device *netdev, int new_mtu)
|
|||||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||||
int max_frame = new_mtu + ETH_HLEN + ETH_FCS_LEN;
|
int max_frame = new_mtu + ETH_HLEN + ETH_FCS_LEN;
|
||||||
|
|
||||||
if ((max_frame < ETH_ZLEN + ETH_FCS_LEN) ||
|
if ((new_mtu < ETH_ZLEN + ETH_FCS_LEN + VLAN_HLEN) ||
|
||||||
(max_frame > MAX_JUMBO_FRAME_SIZE)) {
|
(max_frame > MAX_JUMBO_FRAME_SIZE)) {
|
||||||
e_err("Invalid MTU setting\n");
|
e_err("Invalid MTU setting\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -324,14 +324,27 @@ void __devinit e1000e_check_options(struct e1000_adapter *adapter)
|
|||||||
adapter->itr = 20000;
|
adapter->itr = 20000;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
e1000_validate_option(&adapter->itr, &opt,
|
|
||||||
adapter);
|
|
||||||
/*
|
/*
|
||||||
* save the setting, because the dynamic bits
|
* Save the setting, because the dynamic bits
|
||||||
* change itr. clear the lower two bits
|
* change itr.
|
||||||
* because they are used as control
|
|
||||||
*/
|
*/
|
||||||
adapter->itr_setting = adapter->itr & ~3;
|
if (e1000_validate_option(&adapter->itr, &opt,
|
||||||
|
adapter) &&
|
||||||
|
(adapter->itr == 3)) {
|
||||||
|
/*
|
||||||
|
* In case of invalid user value,
|
||||||
|
* default to conservative mode.
|
||||||
|
*/
|
||||||
|
adapter->itr_setting = adapter->itr;
|
||||||
|
adapter->itr = 20000;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Clear the lower two bits because
|
||||||
|
* they are used as control.
|
||||||
|
*/
|
||||||
|
adapter->itr_setting =
|
||||||
|
adapter->itr & ~3;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -134,9 +134,7 @@ static int gfar_process_frame(struct net_device *dev, struct sk_buff *skb, int l
|
|||||||
static void gfar_vlan_rx_register(struct net_device *netdev,
|
static void gfar_vlan_rx_register(struct net_device *netdev,
|
||||||
struct vlan_group *grp);
|
struct vlan_group *grp);
|
||||||
void gfar_halt(struct net_device *dev);
|
void gfar_halt(struct net_device *dev);
|
||||||
#ifdef CONFIG_PM
|
|
||||||
static void gfar_halt_nodisable(struct net_device *dev);
|
static void gfar_halt_nodisable(struct net_device *dev);
|
||||||
#endif
|
|
||||||
void gfar_start(struct net_device *dev);
|
void gfar_start(struct net_device *dev);
|
||||||
static void gfar_clear_exact_match(struct net_device *dev);
|
static void gfar_clear_exact_match(struct net_device *dev);
|
||||||
static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr);
|
static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr);
|
||||||
@ -631,7 +629,6 @@ static void init_registers(struct net_device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
|
||||||
/* Halt the receive and transmit queues */
|
/* Halt the receive and transmit queues */
|
||||||
static void gfar_halt_nodisable(struct net_device *dev)
|
static void gfar_halt_nodisable(struct net_device *dev)
|
||||||
{
|
{
|
||||||
@ -657,7 +654,6 @@ static void gfar_halt_nodisable(struct net_device *dev)
|
|||||||
cpu_relax();
|
cpu_relax();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Halt the receive and transmit queues */
|
/* Halt the receive and transmit queues */
|
||||||
void gfar_halt(struct net_device *dev)
|
void gfar_halt(struct net_device *dev)
|
||||||
@ -666,6 +662,8 @@ void gfar_halt(struct net_device *dev)
|
|||||||
struct gfar __iomem *regs = priv->regs;
|
struct gfar __iomem *regs = priv->regs;
|
||||||
u32 tempval;
|
u32 tempval;
|
||||||
|
|
||||||
|
gfar_halt_nodisable(dev);
|
||||||
|
|
||||||
/* Disable Rx and Tx */
|
/* Disable Rx and Tx */
|
||||||
tempval = gfar_read(®s->maccfg1);
|
tempval = gfar_read(®s->maccfg1);
|
||||||
tempval &= ~(MACCFG1_RX_EN | MACCFG1_TX_EN);
|
tempval &= ~(MACCFG1_RX_EN | MACCFG1_TX_EN);
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
|
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/version.h>
|
|
||||||
|
|
||||||
#include "gianfar.h"
|
#include "gianfar.h"
|
||||||
|
|
||||||
|
@ -7,7 +7,6 @@
|
|||||||
#ifndef __LINUX_IPG_H
|
#ifndef __LINUX_IPG_H
|
||||||
#define __LINUX_IPG_H
|
#define __LINUX_IPG_H
|
||||||
|
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
@ -21,7 +20,6 @@
|
|||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/skbuff.h>
|
#include <linux/skbuff.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <asm/bitops.h>
|
#include <asm/bitops.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -190,6 +190,7 @@ static enum ixgbe_media_type ixgbe_get_media_type_82598(struct ixgbe_hw *hw)
|
|||||||
case IXGBE_DEV_ID_82598AF_DUAL_PORT:
|
case IXGBE_DEV_ID_82598AF_DUAL_PORT:
|
||||||
case IXGBE_DEV_ID_82598AF_SINGLE_PORT:
|
case IXGBE_DEV_ID_82598AF_SINGLE_PORT:
|
||||||
case IXGBE_DEV_ID_82598EB_CX4:
|
case IXGBE_DEV_ID_82598EB_CX4:
|
||||||
|
case IXGBE_DEV_ID_82598_CX4_DUAL_PORT:
|
||||||
media_type = ixgbe_media_type_fiber;
|
media_type = ixgbe_media_type_fiber;
|
||||||
break;
|
break;
|
||||||
case IXGBE_DEV_ID_82598AT_DUAL_PORT:
|
case IXGBE_DEV_ID_82598AT_DUAL_PORT:
|
||||||
|
@ -48,7 +48,7 @@ char ixgbe_driver_name[] = "ixgbe";
|
|||||||
static const char ixgbe_driver_string[] =
|
static const char ixgbe_driver_string[] =
|
||||||
"Intel(R) 10 Gigabit PCI Express Network Driver";
|
"Intel(R) 10 Gigabit PCI Express Network Driver";
|
||||||
|
|
||||||
#define DRV_VERSION "1.3.18-k2"
|
#define DRV_VERSION "1.3.18-k4"
|
||||||
const char ixgbe_driver_version[] = DRV_VERSION;
|
const char ixgbe_driver_version[] = DRV_VERSION;
|
||||||
static const char ixgbe_copyright[] =
|
static const char ixgbe_copyright[] =
|
||||||
"Copyright (c) 1999-2007 Intel Corporation.";
|
"Copyright (c) 1999-2007 Intel Corporation.";
|
||||||
@ -72,6 +72,8 @@ static struct pci_device_id ixgbe_pci_tbl[] = {
|
|||||||
board_82598 },
|
board_82598 },
|
||||||
{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598EB_CX4),
|
{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598EB_CX4),
|
||||||
board_82598 },
|
board_82598 },
|
||||||
|
{PCI_VDEVICE(INTEL, IXGBE_DEV_ID_82598_CX4_DUAL_PORT),
|
||||||
|
board_82598 },
|
||||||
|
|
||||||
/* required last entry */
|
/* required last entry */
|
||||||
{0, }
|
{0, }
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
#define IXGBE_DEV_ID_82598AF_SINGLE_PORT 0x10C7
|
#define IXGBE_DEV_ID_82598AF_SINGLE_PORT 0x10C7
|
||||||
#define IXGBE_DEV_ID_82598AT_DUAL_PORT 0x10C8
|
#define IXGBE_DEV_ID_82598AT_DUAL_PORT 0x10C8
|
||||||
#define IXGBE_DEV_ID_82598EB_CX4 0x10DD
|
#define IXGBE_DEV_ID_82598EB_CX4 0x10DD
|
||||||
|
#define IXGBE_DEV_ID_82598_CX4_DUAL_PORT 0x10EC
|
||||||
|
|
||||||
/* General Registers */
|
/* General Registers */
|
||||||
#define IXGBE_CTRL 0x00000
|
#define IXGBE_CTRL 0x00000
|
||||||
|
@ -3548,7 +3548,11 @@ static void myri10ge_probe_slices(struct myri10ge_priv *mgp)
|
|||||||
|
|
||||||
/* try to load the slice aware rss firmware */
|
/* try to load the slice aware rss firmware */
|
||||||
old_fw = mgp->fw_name;
|
old_fw = mgp->fw_name;
|
||||||
if (old_fw == myri10ge_fw_aligned)
|
if (myri10ge_fw_name != NULL) {
|
||||||
|
dev_info(&mgp->pdev->dev, "overriding rss firmware to %s\n",
|
||||||
|
myri10ge_fw_name);
|
||||||
|
mgp->fw_name = myri10ge_fw_name;
|
||||||
|
} else if (old_fw == myri10ge_fw_aligned)
|
||||||
mgp->fw_name = myri10ge_fw_rss_aligned;
|
mgp->fw_name = myri10ge_fw_rss_aligned;
|
||||||
else
|
else
|
||||||
mgp->fw_name = myri10ge_fw_rss_unaligned;
|
mgp->fw_name = myri10ge_fw_rss_unaligned;
|
||||||
|
@ -118,7 +118,7 @@ bad_clone_list[] __initdata = {
|
|||||||
{"E-LAN100", "E-LAN200", {0x00, 0x00, 0x5d}}, /* Broken ne1000 clones */
|
{"E-LAN100", "E-LAN200", {0x00, 0x00, 0x5d}}, /* Broken ne1000 clones */
|
||||||
{"PCM-4823", "PCM-4823", {0x00, 0xc0, 0x6c}}, /* Broken Advantech MoBo */
|
{"PCM-4823", "PCM-4823", {0x00, 0xc0, 0x6c}}, /* Broken Advantech MoBo */
|
||||||
{"REALTEK", "RTL8019", {0x00, 0x00, 0xe8}}, /* no-name with Realtek chip */
|
{"REALTEK", "RTL8019", {0x00, 0x00, 0xe8}}, /* no-name with Realtek chip */
|
||||||
#if defined(CONFIG_TOSHIBA_RBTX4927) || defined(CONFIG_TOSHIBA_RBTX4938)
|
#ifdef CONFIG_MACH_TX49XX
|
||||||
{"RBHMA4X00-RTL8019", "RBHMA4X00/RTL8019", {0x00, 0x60, 0x0a}}, /* Toshiba built-in */
|
{"RBHMA4X00-RTL8019", "RBHMA4X00/RTL8019", {0x00, 0x60, 0x0a}}, /* Toshiba built-in */
|
||||||
#endif
|
#endif
|
||||||
{"LCS-8834", "LCS-8836", {0x04, 0x04, 0x37}}, /* ShinyNet (SET) */
|
{"LCS-8834", "LCS-8836", {0x04, 0x04, 0x37}}, /* ShinyNet (SET) */
|
||||||
@ -142,7 +142,7 @@ bad_clone_list[] __initdata = {
|
|||||||
#if defined(CONFIG_PLAT_MAPPI)
|
#if defined(CONFIG_PLAT_MAPPI)
|
||||||
# define DCR_VAL 0x4b
|
# define DCR_VAL 0x4b
|
||||||
#elif defined(CONFIG_PLAT_OAKS32R) || \
|
#elif defined(CONFIG_PLAT_OAKS32R) || \
|
||||||
defined(CONFIG_TOSHIBA_RBTX4927) || defined(CONFIG_TOSHIBA_RBTX4938)
|
defined(CONFIG_MACH_TX49XX)
|
||||||
# define DCR_VAL 0x48 /* 8-bit mode */
|
# define DCR_VAL 0x48 /* 8-bit mode */
|
||||||
#else
|
#else
|
||||||
# define DCR_VAL 0x49
|
# define DCR_VAL 0x49
|
||||||
|
@ -66,8 +66,8 @@
|
|||||||
|
|
||||||
#define _NETXEN_NIC_LINUX_MAJOR 4
|
#define _NETXEN_NIC_LINUX_MAJOR 4
|
||||||
#define _NETXEN_NIC_LINUX_MINOR 0
|
#define _NETXEN_NIC_LINUX_MINOR 0
|
||||||
#define _NETXEN_NIC_LINUX_SUBVERSION 0
|
#define _NETXEN_NIC_LINUX_SUBVERSION 11
|
||||||
#define NETXEN_NIC_LINUX_VERSIONID "4.0.0"
|
#define NETXEN_NIC_LINUX_VERSIONID "4.0.11"
|
||||||
|
|
||||||
#define NETXEN_VERSION_CODE(a, b, c) (((a) << 16) + ((b) << 8) + (c))
|
#define NETXEN_VERSION_CODE(a, b, c) (((a) << 16) + ((b) << 8) + (c))
|
||||||
|
|
||||||
@ -1615,7 +1615,8 @@ dma_watchdog_wakeup(struct netxen_adapter *adapter)
|
|||||||
|
|
||||||
|
|
||||||
int netxen_is_flash_supported(struct netxen_adapter *adapter);
|
int netxen_is_flash_supported(struct netxen_adapter *adapter);
|
||||||
int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, __le64 mac[]);
|
int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, __le64 *mac);
|
||||||
|
int netxen_p3_get_mac_addr(struct netxen_adapter *adapter, __le64 *mac);
|
||||||
extern void netxen_change_ringparam(struct netxen_adapter *adapter);
|
extern void netxen_change_ringparam(struct netxen_adapter *adapter);
|
||||||
extern int netxen_rom_fast_read(struct netxen_adapter *adapter, int addr,
|
extern int netxen_rom_fast_read(struct netxen_adapter *adapter, int addr,
|
||||||
int *valp);
|
int *valp);
|
||||||
|
@ -733,31 +733,56 @@ static int netxen_get_flash_block(struct netxen_adapter *adapter, int base,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, __le64 mac[])
|
int netxen_get_flash_mac_addr(struct netxen_adapter *adapter, __le64 *mac)
|
||||||
{
|
{
|
||||||
__le32 *pmac = (__le32 *) & mac[0];
|
__le32 *pmac = (__le32 *) mac;
|
||||||
|
u32 offset;
|
||||||
|
|
||||||
if (netxen_get_flash_block(adapter,
|
offset = NETXEN_USER_START +
|
||||||
NETXEN_USER_START +
|
offsetof(struct netxen_new_user_info, mac_addr) +
|
||||||
offsetof(struct netxen_new_user_info,
|
adapter->portnum * sizeof(u64);
|
||||||
mac_addr),
|
|
||||||
FLASH_NUM_PORTS * sizeof(u64), pmac) == -1) {
|
if (netxen_get_flash_block(adapter, offset, sizeof(u64), pmac) == -1)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
if (*mac == cpu_to_le64(~0ULL)) {
|
if (*mac == cpu_to_le64(~0ULL)) {
|
||||||
|
|
||||||
|
offset = NETXEN_USER_START_OLD +
|
||||||
|
offsetof(struct netxen_user_old_info, mac_addr) +
|
||||||
|
adapter->portnum * sizeof(u64);
|
||||||
|
|
||||||
if (netxen_get_flash_block(adapter,
|
if (netxen_get_flash_block(adapter,
|
||||||
NETXEN_USER_START_OLD +
|
offset, sizeof(u64), pmac) == -1)
|
||||||
offsetof(struct netxen_user_old_info,
|
|
||||||
mac_addr),
|
|
||||||
FLASH_NUM_PORTS * sizeof(u64),
|
|
||||||
pmac) == -1)
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (*mac == cpu_to_le64(~0ULL))
|
if (*mac == cpu_to_le64(~0ULL))
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int netxen_p3_get_mac_addr(struct netxen_adapter *adapter, __le64 *mac)
|
||||||
|
{
|
||||||
|
uint32_t crbaddr, mac_hi, mac_lo;
|
||||||
|
int pci_func = adapter->ahw.pci_func;
|
||||||
|
|
||||||
|
crbaddr = CRB_MAC_BLOCK_START +
|
||||||
|
(4 * ((pci_func/2) * 3)) + (4 * (pci_func & 1));
|
||||||
|
|
||||||
|
adapter->hw_read_wx(adapter, crbaddr, &mac_lo, 4);
|
||||||
|
adapter->hw_read_wx(adapter, crbaddr+4, &mac_hi, 4);
|
||||||
|
|
||||||
|
mac_hi = cpu_to_le32(mac_hi);
|
||||||
|
mac_lo = cpu_to_le32(mac_lo);
|
||||||
|
|
||||||
|
if (pci_func & 1)
|
||||||
|
*mac = ((mac_lo >> 16) | ((u64)mac_hi << 16));
|
||||||
|
else
|
||||||
|
*mac = ((mac_lo) | ((u64)mac_hi << 32));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#define CRB_WIN_LOCK_TIMEOUT 100000000
|
#define CRB_WIN_LOCK_TIMEOUT 100000000
|
||||||
|
|
||||||
static int crb_win_lock(struct netxen_adapter *adapter)
|
static int crb_win_lock(struct netxen_adapter *adapter)
|
||||||
@ -2183,10 +2208,10 @@ void netxen_nic_flash_print(struct netxen_adapter *adapter)
|
|||||||
if (adapter->portnum == 0) {
|
if (adapter->portnum == 0) {
|
||||||
get_brd_name_by_type(board_info->board_type, brd_name);
|
get_brd_name_by_type(board_info->board_type, brd_name);
|
||||||
|
|
||||||
printk("NetXen %s Board S/N %s Chip id 0x%x\n",
|
printk(KERN_INFO "NetXen %s Board S/N %s Chip rev 0x%x\n",
|
||||||
brd_name, serial_num, board_info->chip_id);
|
brd_name, serial_num, adapter->ahw.revision_id);
|
||||||
printk("NetXen Firmware version %d.%d.%d\n", fw_major,
|
printk(KERN_INFO "NetXen Firmware version %d.%d.%d\n",
|
||||||
fw_minor, fw_build);
|
fw_major, fw_minor, fw_build);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (NETXEN_VERSION_CODE(fw_major, fw_minor, fw_build) <
|
if (NETXEN_VERSION_CODE(fw_major, fw_minor, fw_build) <
|
||||||
|
@ -1079,10 +1079,12 @@ int netxen_initialize_adapter_offload(struct netxen_adapter *adapter)
|
|||||||
|
|
||||||
void netxen_free_adapter_offload(struct netxen_adapter *adapter)
|
void netxen_free_adapter_offload(struct netxen_adapter *adapter)
|
||||||
{
|
{
|
||||||
int i;
|
int i = 100;
|
||||||
|
|
||||||
if (adapter->dummy_dma.addr) {
|
if (!adapter->dummy_dma.addr)
|
||||||
i = 100;
|
return;
|
||||||
|
|
||||||
|
if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) {
|
||||||
do {
|
do {
|
||||||
if (dma_watchdog_shutdown_request(adapter) == 1)
|
if (dma_watchdog_shutdown_request(adapter) == 1)
|
||||||
break;
|
break;
|
||||||
@ -1090,17 +1092,17 @@ void netxen_free_adapter_offload(struct netxen_adapter *adapter)
|
|||||||
if (dma_watchdog_shutdown_poll_result(adapter) == 1)
|
if (dma_watchdog_shutdown_poll_result(adapter) == 1)
|
||||||
break;
|
break;
|
||||||
} while (--i);
|
} while (--i);
|
||||||
|
}
|
||||||
|
|
||||||
if (i) {
|
if (i) {
|
||||||
pci_free_consistent(adapter->pdev,
|
pci_free_consistent(adapter->pdev,
|
||||||
NETXEN_HOST_DUMMY_DMA_SIZE,
|
NETXEN_HOST_DUMMY_DMA_SIZE,
|
||||||
adapter->dummy_dma.addr,
|
adapter->dummy_dma.addr,
|
||||||
adapter->dummy_dma.phys_addr);
|
adapter->dummy_dma.phys_addr);
|
||||||
adapter->dummy_dma.addr = NULL;
|
adapter->dummy_dma.addr = NULL;
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_ERR "%s: dma_watchdog_shutdown failed\n",
|
printk(KERN_ERR "%s: dma_watchdog_shutdown failed\n",
|
||||||
adapter->netdev->name);
|
adapter->netdev->name);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,76 +149,18 @@ static uint32_t msi_tgt_status[8] = {
|
|||||||
|
|
||||||
static struct netxen_legacy_intr_set legacy_intr[] = NX_LEGACY_INTR_CONFIG;
|
static struct netxen_legacy_intr_set legacy_intr[] = NX_LEGACY_INTR_CONFIG;
|
||||||
|
|
||||||
static void netxen_nic_disable_int(struct netxen_adapter *adapter)
|
static inline void netxen_nic_disable_int(struct netxen_adapter *adapter)
|
||||||
{
|
{
|
||||||
u32 mask = 0x7ff;
|
adapter->pci_write_normalize(adapter, adapter->crb_intr_mask, 0);
|
||||||
int retries = 32;
|
|
||||||
int pci_fn = adapter->ahw.pci_func;
|
|
||||||
|
|
||||||
if (adapter->msi_mode != MSI_MODE_MULTIFUNC)
|
|
||||||
adapter->pci_write_normalize(adapter,
|
|
||||||
adapter->crb_intr_mask, 0);
|
|
||||||
|
|
||||||
if (adapter->intr_scheme != -1 &&
|
|
||||||
adapter->intr_scheme != INTR_SCHEME_PERPORT)
|
|
||||||
adapter->pci_write_immediate(adapter, ISR_INT_MASK, mask);
|
|
||||||
|
|
||||||
if (!NETXEN_IS_MSI_FAMILY(adapter)) {
|
|
||||||
do {
|
|
||||||
adapter->pci_write_immediate(adapter,
|
|
||||||
adapter->legacy_intr.tgt_status_reg,
|
|
||||||
0xffffffff);
|
|
||||||
mask = adapter->pci_read_immediate(adapter,
|
|
||||||
ISR_INT_VECTOR);
|
|
||||||
if (!(mask & 0x80))
|
|
||||||
break;
|
|
||||||
udelay(10);
|
|
||||||
} while (--retries);
|
|
||||||
|
|
||||||
if (!retries) {
|
|
||||||
printk(KERN_NOTICE "%s: Failed to disable interrupt\n",
|
|
||||||
netxen_nic_driver_name);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (adapter->msi_mode == MSI_MODE_MULTIFUNC) {
|
|
||||||
adapter->pci_write_immediate(adapter,
|
|
||||||
msi_tgt_status[pci_fn], 0xffffffff);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void netxen_nic_enable_int(struct netxen_adapter *adapter)
|
static inline void netxen_nic_enable_int(struct netxen_adapter *adapter)
|
||||||
{
|
{
|
||||||
u32 mask;
|
|
||||||
|
|
||||||
if (adapter->intr_scheme != -1 &&
|
|
||||||
adapter->intr_scheme != INTR_SCHEME_PERPORT) {
|
|
||||||
switch (adapter->ahw.board_type) {
|
|
||||||
case NETXEN_NIC_GBE:
|
|
||||||
mask = 0x77b;
|
|
||||||
break;
|
|
||||||
case NETXEN_NIC_XGBE:
|
|
||||||
mask = 0x77f;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
mask = 0x7ff;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
adapter->pci_write_immediate(adapter, ISR_INT_MASK, mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
adapter->pci_write_normalize(adapter, adapter->crb_intr_mask, 0x1);
|
adapter->pci_write_normalize(adapter, adapter->crb_intr_mask, 0x1);
|
||||||
|
|
||||||
if (!NETXEN_IS_MSI_FAMILY(adapter)) {
|
if (!NETXEN_IS_MSI_FAMILY(adapter))
|
||||||
mask = 0xbff;
|
adapter->pci_write_immediate(adapter,
|
||||||
if (adapter->intr_scheme == INTR_SCHEME_PERPORT)
|
adapter->legacy_intr.tgt_mask_reg, 0xfbff);
|
||||||
adapter->pci_write_immediate(adapter,
|
|
||||||
adapter->legacy_intr.tgt_mask_reg, mask);
|
|
||||||
else
|
|
||||||
adapter->pci_write_normalize(adapter,
|
|
||||||
CRB_INT_VECTOR, 0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nx_set_dma_mask(struct netxen_adapter *adapter, uint8_t revision_id)
|
static int nx_set_dma_mask(struct netxen_adapter *adapter, uint8_t revision_id)
|
||||||
@ -501,6 +443,44 @@ static void netxen_init_msix_entries(struct netxen_adapter *adapter)
|
|||||||
adapter->msix_entries[i].entry = i;
|
adapter->msix_entries[i].entry = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
netxen_read_mac_addr(struct netxen_adapter *adapter)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
unsigned char *p;
|
||||||
|
__le64 mac_addr;
|
||||||
|
DECLARE_MAC_BUF(mac);
|
||||||
|
struct net_device *netdev = adapter->netdev;
|
||||||
|
struct pci_dev *pdev = adapter->pdev;
|
||||||
|
|
||||||
|
if (netxen_is_flash_supported(adapter) != 0)
|
||||||
|
return -EIO;
|
||||||
|
|
||||||
|
if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) {
|
||||||
|
if (netxen_p3_get_mac_addr(adapter, &mac_addr) != 0)
|
||||||
|
return -EIO;
|
||||||
|
} else {
|
||||||
|
if (netxen_get_flash_mac_addr(adapter, &mac_addr) != 0)
|
||||||
|
return -EIO;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = (unsigned char *)&mac_addr;
|
||||||
|
for (i = 0; i < 6; i++)
|
||||||
|
netdev->dev_addr[i] = *(p + 5 - i);
|
||||||
|
|
||||||
|
memcpy(netdev->perm_addr, netdev->dev_addr, netdev->addr_len);
|
||||||
|
|
||||||
|
/* set station address */
|
||||||
|
|
||||||
|
if (!is_valid_ether_addr(netdev->perm_addr)) {
|
||||||
|
dev_warn(&pdev->dev, "Bad MAC address %s.\n",
|
||||||
|
print_mac(mac, netdev->dev_addr));
|
||||||
|
} else
|
||||||
|
adapter->macaddr_set(adapter, netdev->dev_addr);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* netxen_nic_probe()
|
* netxen_nic_probe()
|
||||||
*
|
*
|
||||||
@ -529,10 +509,8 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
|||||||
unsigned long mem_base, mem_len, db_base, db_len, pci_len0 = 0;
|
unsigned long mem_base, mem_len, db_base, db_len, pci_len0 = 0;
|
||||||
int i = 0, err;
|
int i = 0, err;
|
||||||
int first_driver, first_boot;
|
int first_driver, first_boot;
|
||||||
__le64 mac_addr[FLASH_NUM_PORTS + 1];
|
|
||||||
u32 val;
|
u32 val;
|
||||||
int pci_func_id = PCI_FUNC(pdev->devfn);
|
int pci_func_id = PCI_FUNC(pdev->devfn);
|
||||||
DECLARE_MAC_BUF(mac);
|
|
||||||
struct netxen_legacy_intr_set *legacy_intrp;
|
struct netxen_legacy_intr_set *legacy_intrp;
|
||||||
uint8_t revision_id;
|
uint8_t revision_id;
|
||||||
|
|
||||||
@ -545,6 +523,13 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pdev->revision >= NX_P3_A0 && pdev->revision < NX_P3_B1) {
|
||||||
|
printk(KERN_WARNING "NetXen chip revisions between 0x%x-0x%x"
|
||||||
|
"will not be enabled.\n",
|
||||||
|
NX_P3_A0, NX_P3_B1);
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
if ((err = pci_enable_device(pdev)))
|
if ((err = pci_enable_device(pdev)))
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
@ -898,34 +883,14 @@ request_msi:
|
|||||||
goto err_out_disable_msi;
|
goto err_out_disable_msi;
|
||||||
|
|
||||||
init_timer(&adapter->watchdog_timer);
|
init_timer(&adapter->watchdog_timer);
|
||||||
adapter->ahw.linkup = 0;
|
|
||||||
adapter->watchdog_timer.function = &netxen_watchdog;
|
adapter->watchdog_timer.function = &netxen_watchdog;
|
||||||
adapter->watchdog_timer.data = (unsigned long)adapter;
|
adapter->watchdog_timer.data = (unsigned long)adapter;
|
||||||
INIT_WORK(&adapter->watchdog_task, netxen_watchdog_task);
|
INIT_WORK(&adapter->watchdog_task, netxen_watchdog_task);
|
||||||
INIT_WORK(&adapter->tx_timeout_task, netxen_tx_timeout_task);
|
INIT_WORK(&adapter->tx_timeout_task, netxen_tx_timeout_task);
|
||||||
|
|
||||||
if (netxen_is_flash_supported(adapter) == 0 &&
|
err = netxen_read_mac_addr(adapter);
|
||||||
netxen_get_flash_mac_addr(adapter, mac_addr) == 0) {
|
if (err)
|
||||||
unsigned char *p;
|
dev_warn(&pdev->dev, "failed to read mac addr\n");
|
||||||
|
|
||||||
p = (unsigned char *)&mac_addr[adapter->portnum];
|
|
||||||
netdev->dev_addr[0] = *(p + 5);
|
|
||||||
netdev->dev_addr[1] = *(p + 4);
|
|
||||||
netdev->dev_addr[2] = *(p + 3);
|
|
||||||
netdev->dev_addr[3] = *(p + 2);
|
|
||||||
netdev->dev_addr[4] = *(p + 1);
|
|
||||||
netdev->dev_addr[5] = *(p + 0);
|
|
||||||
|
|
||||||
memcpy(netdev->perm_addr, netdev->dev_addr,
|
|
||||||
netdev->addr_len);
|
|
||||||
if (!is_valid_ether_addr(netdev->perm_addr)) {
|
|
||||||
printk(KERN_ERR "%s: Bad MAC address %s.\n",
|
|
||||||
netxen_nic_driver_name,
|
|
||||||
print_mac(mac, netdev->dev_addr));
|
|
||||||
} else {
|
|
||||||
adapter->macaddr_set(adapter, netdev->dev_addr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
netif_carrier_off(netdev);
|
netif_carrier_off(netdev);
|
||||||
netif_stop_queue(netdev);
|
netif_stop_queue(netdev);
|
||||||
@ -1000,6 +965,7 @@ static void __devexit netxen_nic_remove(struct pci_dev *pdev)
|
|||||||
|
|
||||||
if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) {
|
if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) {
|
||||||
netxen_free_hw_resources(adapter);
|
netxen_free_hw_resources(adapter);
|
||||||
|
netxen_release_rx_buffers(adapter);
|
||||||
netxen_free_sw_resources(adapter);
|
netxen_free_sw_resources(adapter);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1069,6 +1035,15 @@ static int netxen_nic_open(struct net_device *netdev)
|
|||||||
goto err_out_free_sw;
|
goto err_out_free_sw;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((adapter->msi_mode != MSI_MODE_MULTIFUNC) ||
|
||||||
|
(adapter->intr_scheme != INTR_SCHEME_PERPORT)) {
|
||||||
|
printk(KERN_ERR "%s: Firmware interrupt scheme is "
|
||||||
|
"incompatible with driver\n",
|
||||||
|
netdev->name);
|
||||||
|
adapter->driver_mismatch = 1;
|
||||||
|
goto err_out_free_hw;
|
||||||
|
}
|
||||||
|
|
||||||
if (adapter->fw_major < 4) {
|
if (adapter->fw_major < 4) {
|
||||||
adapter->crb_addr_cmd_producer =
|
adapter->crb_addr_cmd_producer =
|
||||||
crb_cmd_producer[adapter->portnum];
|
crb_cmd_producer[adapter->portnum];
|
||||||
@ -1094,7 +1069,7 @@ static int netxen_nic_open(struct net_device *netdev)
|
|||||||
flags, netdev->name, adapter);
|
flags, netdev->name, adapter);
|
||||||
if (err) {
|
if (err) {
|
||||||
printk(KERN_ERR "request_irq failed with: %d\n", err);
|
printk(KERN_ERR "request_irq failed with: %d\n", err);
|
||||||
goto err_out_free_hw;
|
goto err_out_free_rxbuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
adapter->is_up = NETXEN_ADAPTER_UP_MAGIC;
|
adapter->is_up = NETXEN_ADAPTER_UP_MAGIC;
|
||||||
@ -1116,6 +1091,7 @@ static int netxen_nic_open(struct net_device *netdev)
|
|||||||
if (adapter->set_mtu)
|
if (adapter->set_mtu)
|
||||||
adapter->set_mtu(adapter, netdev->mtu);
|
adapter->set_mtu(adapter, netdev->mtu);
|
||||||
|
|
||||||
|
adapter->ahw.linkup = 0;
|
||||||
mod_timer(&adapter->watchdog_timer, jiffies);
|
mod_timer(&adapter->watchdog_timer, jiffies);
|
||||||
|
|
||||||
napi_enable(&adapter->napi);
|
napi_enable(&adapter->napi);
|
||||||
@ -1127,6 +1103,8 @@ static int netxen_nic_open(struct net_device *netdev)
|
|||||||
|
|
||||||
err_out_free_irq:
|
err_out_free_irq:
|
||||||
free_irq(adapter->irq, adapter);
|
free_irq(adapter->irq, adapter);
|
||||||
|
err_out_free_rxbuf:
|
||||||
|
netxen_release_rx_buffers(adapter);
|
||||||
err_out_free_hw:
|
err_out_free_hw:
|
||||||
netxen_free_hw_resources(adapter);
|
netxen_free_hw_resources(adapter);
|
||||||
err_out_free_sw:
|
err_out_free_sw:
|
||||||
@ -1152,10 +1130,8 @@ static int netxen_nic_close(struct net_device *netdev)
|
|||||||
|
|
||||||
netxen_release_tx_buffers(adapter);
|
netxen_release_tx_buffers(adapter);
|
||||||
|
|
||||||
if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) {
|
FLUSH_SCHEDULED_WORK();
|
||||||
FLUSH_SCHEDULED_WORK();
|
del_timer_sync(&adapter->watchdog_timer);
|
||||||
del_timer_sync(&adapter->watchdog_timer);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1458,7 +1434,8 @@ void netxen_watchdog_task(struct work_struct *work)
|
|||||||
|
|
||||||
netxen_nic_handle_phy_intr(adapter);
|
netxen_nic_handle_phy_intr(adapter);
|
||||||
|
|
||||||
mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ);
|
if (netif_running(adapter->netdev))
|
||||||
|
mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void netxen_tx_timeout(struct net_device *netdev)
|
static void netxen_tx_timeout(struct net_device *netdev)
|
||||||
@ -1518,18 +1495,9 @@ struct net_device_stats *netxen_nic_get_stats(struct net_device *netdev)
|
|||||||
return stats;
|
return stats;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
|
||||||
netxen_handle_int(struct netxen_adapter *adapter)
|
|
||||||
{
|
|
||||||
netxen_nic_disable_int(adapter);
|
|
||||||
napi_schedule(&adapter->napi);
|
|
||||||
}
|
|
||||||
|
|
||||||
static irqreturn_t netxen_intr(int irq, void *data)
|
static irqreturn_t netxen_intr(int irq, void *data)
|
||||||
{
|
{
|
||||||
struct netxen_adapter *adapter = data;
|
struct netxen_adapter *adapter = data;
|
||||||
u32 our_int = 0;
|
|
||||||
|
|
||||||
u32 status = 0;
|
u32 status = 0;
|
||||||
|
|
||||||
status = adapter->pci_read_immediate(adapter, ISR_INT_VECTOR);
|
status = adapter->pci_read_immediate(adapter, ISR_INT_VECTOR);
|
||||||
@ -1544,22 +1512,32 @@ static irqreturn_t netxen_intr(int irq, void *data)
|
|||||||
if (!ISR_LEGACY_INT_TRIGGERED(status))
|
if (!ISR_LEGACY_INT_TRIGGERED(status))
|
||||||
return IRQ_NONE;
|
return IRQ_NONE;
|
||||||
|
|
||||||
} else if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) {
|
} else {
|
||||||
|
unsigned long our_int = 0;
|
||||||
|
|
||||||
our_int = adapter->pci_read_normalize(adapter, CRB_INT_VECTOR);
|
our_int = adapter->pci_read_normalize(adapter, CRB_INT_VECTOR);
|
||||||
|
|
||||||
/* not our interrupt */
|
/* not our interrupt */
|
||||||
if ((our_int & (0x80 << adapter->portnum)) == 0)
|
if (!test_and_clear_bit((7 + adapter->portnum), &our_int))
|
||||||
return IRQ_NONE;
|
return IRQ_NONE;
|
||||||
|
|
||||||
if (adapter->intr_scheme == INTR_SCHEME_PERPORT) {
|
/* claim interrupt */
|
||||||
/* claim interrupt */
|
adapter->pci_write_normalize(adapter,
|
||||||
adapter->pci_write_normalize(adapter,
|
CRB_INT_VECTOR, (our_int & 0xffffffff));
|
||||||
CRB_INT_VECTOR,
|
|
||||||
our_int & ~((u32)(0x80 << adapter->portnum)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
netxen_handle_int(adapter);
|
/* clear interrupt */
|
||||||
|
if (adapter->fw_major < 4)
|
||||||
|
netxen_nic_disable_int(adapter);
|
||||||
|
|
||||||
|
adapter->pci_write_immediate(adapter,
|
||||||
|
adapter->legacy_intr.tgt_status_reg,
|
||||||
|
0xffffffff);
|
||||||
|
/* read twice to ensure write is flushed */
|
||||||
|
adapter->pci_read_immediate(adapter, ISR_INT_VECTOR);
|
||||||
|
adapter->pci_read_immediate(adapter, ISR_INT_VECTOR);
|
||||||
|
|
||||||
|
napi_schedule(&adapter->napi);
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
@ -1568,7 +1546,11 @@ static irqreturn_t netxen_msi_intr(int irq, void *data)
|
|||||||
{
|
{
|
||||||
struct netxen_adapter *adapter = data;
|
struct netxen_adapter *adapter = data;
|
||||||
|
|
||||||
netxen_handle_int(adapter);
|
/* clear interrupt */
|
||||||
|
adapter->pci_write_immediate(adapter,
|
||||||
|
msi_tgt_status[adapter->ahw.pci_func], 0xffffffff);
|
||||||
|
|
||||||
|
napi_schedule(&adapter->napi);
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,6 +125,8 @@
|
|||||||
#define CRB_SW_INT_MASK_2 NETXEN_NIC_REG(0x1e4)
|
#define CRB_SW_INT_MASK_2 NETXEN_NIC_REG(0x1e4)
|
||||||
#define CRB_SW_INT_MASK_3 NETXEN_NIC_REG(0x1e8)
|
#define CRB_SW_INT_MASK_3 NETXEN_NIC_REG(0x1e8)
|
||||||
|
|
||||||
|
#define CRB_MAC_BLOCK_START NETXEN_CAM_RAM(0x1c0)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* capabilities register, can be used to selectively enable/disable features
|
* capabilities register, can be used to selectively enable/disable features
|
||||||
* for backward compability
|
* for backward compability
|
||||||
|
@ -46,7 +46,6 @@
|
|||||||
#include <linux/err.h>
|
#include <linux/err.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
|
@ -61,7 +61,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/list.h>
|
#include <linux/list.h>
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
|
@ -24,7 +24,6 @@
|
|||||||
|
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/moduleparam.h>
|
#include <linux/moduleparam.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/timer.h>
|
#include <linux/timer.h>
|
||||||
|
@ -20,7 +20,6 @@
|
|||||||
* the file called "COPYING".
|
* the file called "COPYING".
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/dma-mapping.h>
|
#include <linux/dma-mapping.h>
|
||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
|
@ -24,7 +24,6 @@
|
|||||||
|
|
||||||
#include <linux/crc32.h>
|
#include <linux/crc32.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/netdevice.h>
|
#include <linux/netdevice.h>
|
||||||
#include <linux/dma-mapping.h>
|
#include <linux/dma-mapping.h>
|
||||||
@ -666,11 +665,16 @@ static void sky2_phy_power_down(struct sky2_hw *hw, unsigned port)
|
|||||||
|
|
||||||
if (hw->chip_id != CHIP_ID_YUKON_EC) {
|
if (hw->chip_id != CHIP_ID_YUKON_EC) {
|
||||||
if (hw->chip_id == CHIP_ID_YUKON_EC_U) {
|
if (hw->chip_id == CHIP_ID_YUKON_EC_U) {
|
||||||
ctrl = gm_phy_read(hw, port, PHY_MARV_PHY_CTRL);
|
/* select page 2 to access MAC control register */
|
||||||
|
gm_phy_write(hw, port, PHY_MARV_EXT_ADR, 2);
|
||||||
|
|
||||||
|
ctrl = gm_phy_read(hw, port, PHY_MARV_PHY_CTRL);
|
||||||
/* enable Power Down */
|
/* enable Power Down */
|
||||||
ctrl |= PHY_M_PC_POW_D_ENA;
|
ctrl |= PHY_M_PC_POW_D_ENA;
|
||||||
gm_phy_write(hw, port, PHY_MARV_PHY_CTRL, ctrl);
|
gm_phy_write(hw, port, PHY_MARV_PHY_CTRL, ctrl);
|
||||||
|
|
||||||
|
/* set page register back to 0 */
|
||||||
|
gm_phy_write(hw, port, PHY_MARV_EXT_ADR, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* set IEEE compatible Power Down Mode (dev. #4.99) */
|
/* set IEEE compatible Power Down Mode (dev. #4.99) */
|
||||||
|
@ -27,7 +27,6 @@
|
|||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/tty.h>
|
#include <linux/tty.h>
|
||||||
#include <linux/if_vlan.h>
|
#include <linux/if_vlan.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/interrupt.h>
|
#include <linux/interrupt.h>
|
||||||
#include <linux/vmalloc.h>
|
#include <linux/vmalloc.h>
|
||||||
#include <asm/byteorder.h>
|
#include <asm/byteorder.h>
|
||||||
|
@ -360,8 +360,8 @@ TLan_GetSKB( const struct tlan_list_tag *tag)
|
|||||||
{
|
{
|
||||||
unsigned long addr;
|
unsigned long addr;
|
||||||
|
|
||||||
addr = tag->buffer[8].address;
|
addr = tag->buffer[9].address;
|
||||||
addr |= (tag->buffer[9].address << 16) << 16;
|
addr |= (tag->buffer[8].address << 16) << 16;
|
||||||
return (struct sk_buff *) addr;
|
return (struct sk_buff *) addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1984,7 +1984,6 @@ static void TLan_ResetLists( struct net_device *dev )
|
|||||||
TLanList *list;
|
TLanList *list;
|
||||||
dma_addr_t list_phys;
|
dma_addr_t list_phys;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
void *t = NULL;
|
|
||||||
|
|
||||||
priv->txHead = 0;
|
priv->txHead = 0;
|
||||||
priv->txTail = 0;
|
priv->txTail = 0;
|
||||||
@ -2022,7 +2021,8 @@ static void TLan_ResetLists( struct net_device *dev )
|
|||||||
}
|
}
|
||||||
|
|
||||||
skb_reserve( skb, NET_IP_ALIGN );
|
skb_reserve( skb, NET_IP_ALIGN );
|
||||||
list->buffer[0].address = pci_map_single(priv->pciDev, t,
|
list->buffer[0].address = pci_map_single(priv->pciDev,
|
||||||
|
skb->data,
|
||||||
TLAN_MAX_FRAME_SIZE,
|
TLAN_MAX_FRAME_SIZE,
|
||||||
PCI_DMA_FROMDEVICE);
|
PCI_DMA_FROMDEVICE);
|
||||||
TLan_StoreSKB(list, skb);
|
TLan_StoreSKB(list, skb);
|
||||||
|
@ -128,7 +128,6 @@ static const int multicast_filter_limit = 32;
|
|||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
#include <linux/in6.h>
|
#include <linux/in6.h>
|
||||||
#include <linux/version.h>
|
|
||||||
#include <linux/dma-mapping.h>
|
#include <linux/dma-mapping.h>
|
||||||
|
|
||||||
#include "typhoon.h"
|
#include "typhoon.h"
|
||||||
|
@ -154,17 +154,6 @@ config USB_NET_AX8817X
|
|||||||
This driver creates an interface named "ethX", where X depends on
|
This driver creates an interface named "ethX", where X depends on
|
||||||
what other networking devices you have in use.
|
what other networking devices you have in use.
|
||||||
|
|
||||||
config USB_HSO
|
|
||||||
tristate "Option USB High Speed Mobile Devices"
|
|
||||||
depends on USB && RFKILL
|
|
||||||
default n
|
|
||||||
help
|
|
||||||
Choose this option if you have an Option HSDPA/HSUPA card.
|
|
||||||
These cards support downlink speeds of 7.2Mbps or greater.
|
|
||||||
|
|
||||||
To compile this driver as a module, choose M here: the
|
|
||||||
module will be called hso.
|
|
||||||
|
|
||||||
config USB_NET_CDCETHER
|
config USB_NET_CDCETHER
|
||||||
tristate "CDC Ethernet support (smart devices such as cable modems)"
|
tristate "CDC Ethernet support (smart devices such as cable modems)"
|
||||||
depends on USB_USBNET
|
depends on USB_USBNET
|
||||||
@ -337,5 +326,15 @@ config USB_NET_ZAURUS
|
|||||||
really need this non-conformant variant of CDC Ethernet (or in
|
really need this non-conformant variant of CDC Ethernet (or in
|
||||||
some cases CDC MDLM) protocol, not "g_ether".
|
some cases CDC MDLM) protocol, not "g_ether".
|
||||||
|
|
||||||
|
config USB_HSO
|
||||||
|
tristate "Option USB High Speed Mobile Devices"
|
||||||
|
depends on USB && RFKILL
|
||||||
|
default n
|
||||||
|
help
|
||||||
|
Choose this option if you have an Option HSDPA/HSUPA card.
|
||||||
|
These cards support downlink speeds of 7.2Mbps or greater.
|
||||||
|
|
||||||
|
To compile this driver as a module, choose M here: the
|
||||||
|
module will be called hso.
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
@ -102,8 +102,12 @@
|
|||||||
|
|
||||||
#define MAX_RX_URBS 2
|
#define MAX_RX_URBS 2
|
||||||
|
|
||||||
#define get_serial_by_tty(x) \
|
static inline struct hso_serial *get_serial_by_tty(struct tty_struct *tty)
|
||||||
(x ? (struct hso_serial *)x->driver_data : NULL)
|
{
|
||||||
|
if (tty)
|
||||||
|
return tty->driver_data;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
/* Debugging functions */
|
/* Debugging functions */
|
||||||
@ -294,24 +298,25 @@ static int hso_get_activity(struct hso_device *hso_dev);
|
|||||||
|
|
||||||
/* #define DEBUG */
|
/* #define DEBUG */
|
||||||
|
|
||||||
#define dev2net(x) (x->port_data.dev_net)
|
static inline struct hso_net *dev2net(struct hso_device *hso_dev)
|
||||||
#define dev2ser(x) (x->port_data.dev_serial)
|
{
|
||||||
|
return hso_dev->port_data.dev_net;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline struct hso_serial *dev2ser(struct hso_device *hso_dev)
|
||||||
|
{
|
||||||
|
return hso_dev->port_data.dev_serial;
|
||||||
|
}
|
||||||
|
|
||||||
/* Debugging functions */
|
/* Debugging functions */
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
static void dbg_dump(int line_count, const char *func_name, unsigned char *buf,
|
static void dbg_dump(int line_count, const char *func_name, unsigned char *buf,
|
||||||
unsigned int len)
|
unsigned int len)
|
||||||
{
|
{
|
||||||
u8 i = 0;
|
static char name[255];
|
||||||
|
|
||||||
printk(KERN_DEBUG "[%d:%s]: len %d", line_count, func_name, len);
|
sprintf(name, "hso[%d:%s]", line_count, func_name);
|
||||||
|
print_hex_dump_bytes(name, DUMP_PREFIX_NONE, buf, len);
|
||||||
for (i = 0; i < len; i++) {
|
|
||||||
if (!(i % 16))
|
|
||||||
printk("\n 0x%03x: ", i);
|
|
||||||
printk("%02x ", (unsigned char)buf[i]);
|
|
||||||
}
|
|
||||||
printk("\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define DUMP(buf_, len_) \
|
#define DUMP(buf_, len_) \
|
||||||
@ -528,13 +533,12 @@ static struct hso_serial *get_serial_by_shared_int_and_type(
|
|||||||
|
|
||||||
static struct hso_serial *get_serial_by_index(unsigned index)
|
static struct hso_serial *get_serial_by_index(unsigned index)
|
||||||
{
|
{
|
||||||
struct hso_serial *serial;
|
struct hso_serial *serial = NULL;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
if (!serial_table[index])
|
|
||||||
return NULL;
|
|
||||||
spin_lock_irqsave(&serial_table_lock, flags);
|
spin_lock_irqsave(&serial_table_lock, flags);
|
||||||
serial = dev2ser(serial_table[index]);
|
if (serial_table[index])
|
||||||
|
serial = dev2ser(serial_table[index]);
|
||||||
spin_unlock_irqrestore(&serial_table_lock, flags);
|
spin_unlock_irqrestore(&serial_table_lock, flags);
|
||||||
|
|
||||||
return serial;
|
return serial;
|
||||||
@ -561,6 +565,7 @@ static int get_free_serial_index(void)
|
|||||||
static void set_serial_by_index(unsigned index, struct hso_serial *serial)
|
static void set_serial_by_index(unsigned index, struct hso_serial *serial)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
spin_lock_irqsave(&serial_table_lock, flags);
|
spin_lock_irqsave(&serial_table_lock, flags);
|
||||||
if (serial)
|
if (serial)
|
||||||
serial_table[index] = serial->parent;
|
serial_table[index] = serial->parent;
|
||||||
@ -569,7 +574,7 @@ static void set_serial_by_index(unsigned index, struct hso_serial *serial)
|
|||||||
spin_unlock_irqrestore(&serial_table_lock, flags);
|
spin_unlock_irqrestore(&serial_table_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* log a meaningfull explanation of an USB status */
|
/* log a meaningful explanation of an USB status */
|
||||||
static void log_usb_status(int status, const char *function)
|
static void log_usb_status(int status, const char *function)
|
||||||
{
|
{
|
||||||
char *explanation;
|
char *explanation;
|
||||||
@ -1103,8 +1108,8 @@ static void hso_serial_close(struct tty_struct *tty, struct file *filp)
|
|||||||
/* reset the rts and dtr */
|
/* reset the rts and dtr */
|
||||||
/* do the actual close */
|
/* do the actual close */
|
||||||
serial->open_count--;
|
serial->open_count--;
|
||||||
|
kref_put(&serial->parent->ref, hso_serial_ref_free);
|
||||||
if (serial->open_count <= 0) {
|
if (serial->open_count <= 0) {
|
||||||
kref_put(&serial->parent->ref, hso_serial_ref_free);
|
|
||||||
serial->open_count = 0;
|
serial->open_count = 0;
|
||||||
if (serial->tty) {
|
if (serial->tty) {
|
||||||
serial->tty->driver_data = NULL;
|
serial->tty->driver_data = NULL;
|
||||||
@ -1467,7 +1472,8 @@ static void hso_std_serial_write_bulk_callback(struct urb *urb)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
hso_put_activity(serial->parent);
|
hso_put_activity(serial->parent);
|
||||||
tty_wakeup(serial->tty);
|
if (serial->tty)
|
||||||
|
tty_wakeup(serial->tty);
|
||||||
hso_kick_transmit(serial);
|
hso_kick_transmit(serial);
|
||||||
|
|
||||||
D1(" ");
|
D1(" ");
|
||||||
@ -1538,7 +1544,8 @@ static void ctrl_callback(struct urb *urb)
|
|||||||
clear_bit(HSO_SERIAL_FLAG_RX_SENT, &serial->flags);
|
clear_bit(HSO_SERIAL_FLAG_RX_SENT, &serial->flags);
|
||||||
} else {
|
} else {
|
||||||
hso_put_activity(serial->parent);
|
hso_put_activity(serial->parent);
|
||||||
tty_wakeup(serial->tty);
|
if (serial->tty)
|
||||||
|
tty_wakeup(serial->tty);
|
||||||
/* response to a write command */
|
/* response to a write command */
|
||||||
hso_kick_transmit(serial);
|
hso_kick_transmit(serial);
|
||||||
}
|
}
|
||||||
@ -2652,7 +2659,7 @@ static void hso_free_interface(struct usb_interface *interface)
|
|||||||
hso_stop_net_device(network_table[i]);
|
hso_stop_net_device(network_table[i]);
|
||||||
cancel_work_sync(&network_table[i]->async_put_intf);
|
cancel_work_sync(&network_table[i]->async_put_intf);
|
||||||
cancel_work_sync(&network_table[i]->async_get_intf);
|
cancel_work_sync(&network_table[i]->async_get_intf);
|
||||||
if(rfk)
|
if (rfk)
|
||||||
rfkill_unregister(rfk);
|
rfkill_unregister(rfk);
|
||||||
hso_free_net_device(network_table[i]);
|
hso_free_net_device(network_table[i]);
|
||||||
}
|
}
|
||||||
@ -2723,7 +2730,7 @@ static int hso_mux_submit_intr_urb(struct hso_shared_int *shared_int,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* operations setup of the serial interface */
|
/* operations setup of the serial interface */
|
||||||
static struct tty_operations hso_serial_ops = {
|
static const struct tty_operations hso_serial_ops = {
|
||||||
.open = hso_serial_open,
|
.open = hso_serial_open,
|
||||||
.close = hso_serial_close,
|
.close = hso_serial_close,
|
||||||
.write = hso_serial_write,
|
.write = hso_serial_write,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user