|
@@ -51,7 +51,7 @@ char ixgbevf_driver_name[] = "ixgbevf";
|
|
|
static const char ixgbevf_driver_string[] =
|
|
|
"Intel(R) 82599 Virtual Function";
|
|
|
|
|
|
-#define DRV_VERSION "1.0.19-k0"
|
|
|
+#define DRV_VERSION "1.1.0-k0"
|
|
|
const char ixgbevf_driver_version[] = DRV_VERSION;
|
|
|
static char ixgbevf_copyright[] =
|
|
|
"Copyright (c) 2009 - 2010 Intel Corporation.";
|
|
@@ -107,7 +107,7 @@ static inline void ixgbevf_release_rx_desc(struct ixgbe_hw *hw,
|
|
|
}
|
|
|
|
|
|
/*
|
|
|
- * ixgbe_set_ivar - set the IVAR registers, mapping interrupt causes to vectors
|
|
|
+ * ixgbevf_set_ivar - set IVAR registers - maps interrupt causes to vectors
|
|
|
* @adapter: pointer to adapter struct
|
|
|
* @direction: 0 for Rx, 1 for Tx, -1 for other causes
|
|
|
* @queue: queue to map the corresponding interrupt to
|
|
@@ -1017,7 +1017,7 @@ static irqreturn_t ixgbevf_msix_clean_tx(int irq, void *data)
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * ixgbe_msix_clean_rx - single unshared vector rx clean (all queues)
|
|
|
+ * ixgbevf_msix_clean_rx - single unshared vector rx clean (all queues)
|
|
|
* @irq: unused
|
|
|
* @data: pointer to our q_vector struct for this interrupt vector
|
|
|
**/
|
|
@@ -1665,6 +1665,11 @@ static int ixgbevf_up_complete(struct ixgbevf_adapter *adapter)
|
|
|
j = adapter->rx_ring[i].reg_idx;
|
|
|
rxdctl = IXGBE_READ_REG(hw, IXGBE_VFRXDCTL(j));
|
|
|
rxdctl |= IXGBE_RXDCTL_ENABLE;
|
|
|
+ if (hw->mac.type == ixgbe_mac_X540_vf) {
|
|
|
+ rxdctl &= ~IXGBE_RXDCTL_RLPMLMASK;
|
|
|
+ rxdctl |= ((netdev->mtu + ETH_HLEN + ETH_FCS_LEN) |
|
|
|
+ IXGBE_RXDCTL_RLPML_EN);
|
|
|
+ }
|
|
|
IXGBE_WRITE_REG(hw, IXGBE_VFRXDCTL(j), rxdctl);
|
|
|
ixgbevf_rx_desc_queue_enable(adapter, i);
|
|
|
}
|
|
@@ -1967,7 +1972,7 @@ static void ixgbevf_acquire_msix_vectors(struct ixgbevf_adapter *adapter,
|
|
|
}
|
|
|
|
|
|
/*
|
|
|
- * ixgbe_set_num_queues: Allocate queues for device, feature dependant
|
|
|
+ * ixgbevf_set_num_queues: Allocate queues for device, feature dependant
|
|
|
* @adapter: board private structure to initialize
|
|
|
*
|
|
|
* This is the top level queue allocation routine. The order here is very
|
|
@@ -3217,10 +3222,16 @@ static int ixgbevf_set_mac(struct net_device *netdev, void *p)
|
|
|
static int ixgbevf_change_mtu(struct net_device *netdev, int new_mtu)
|
|
|
{
|
|
|
struct ixgbevf_adapter *adapter = netdev_priv(netdev);
|
|
|
+ struct ixgbe_hw *hw = &adapter->hw;
|
|
|
int max_frame = new_mtu + ETH_HLEN + ETH_FCS_LEN;
|
|
|
+ int max_possible_frame = MAXIMUM_ETHERNET_VLAN_SIZE;
|
|
|
+ u32 msg[2];
|
|
|
+
|
|
|
+ if (adapter->hw.mac.type == ixgbe_mac_X540_vf)
|
|
|
+ max_possible_frame = IXGBE_MAX_JUMBO_FRAME_SIZE;
|
|
|
|
|
|
/* MTU < 68 is an error and causes problems on some kernels */
|
|
|
- if ((new_mtu < 68) || (max_frame > MAXIMUM_ETHERNET_VLAN_SIZE))
|
|
|
+ if ((new_mtu < 68) || (max_frame > max_possible_frame))
|
|
|
return -EINVAL;
|
|
|
|
|
|
hw_dbg(&adapter->hw, "changing MTU from %d to %d\n",
|
|
@@ -3228,6 +3239,10 @@ static int ixgbevf_change_mtu(struct net_device *netdev, int new_mtu)
|
|
|
/* must set new MTU before calling down or up */
|
|
|
netdev->mtu = new_mtu;
|
|
|
|
|
|
+ msg[0] = IXGBE_VF_SET_LPE;
|
|
|
+ msg[1] = max_frame;
|
|
|
+ hw->mbx.ops.write_posted(hw, msg, 2);
|
|
|
+
|
|
|
if (netif_running(netdev))
|
|
|
ixgbevf_reinit_locked(adapter);
|
|
|
|
|
@@ -3519,9 +3534,9 @@ static struct pci_driver ixgbevf_driver = {
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
- * ixgbe_init_module - Driver Registration Routine
|
|
|
+ * ixgbevf_init_module - Driver Registration Routine
|
|
|
*
|
|
|
- * ixgbe_init_module is the first routine called when the driver is
|
|
|
+ * ixgbevf_init_module is the first routine called when the driver is
|
|
|
* loaded. All it does is register with the PCI subsystem.
|
|
|
**/
|
|
|
static int __init ixgbevf_init_module(void)
|
|
@@ -3539,9 +3554,9 @@ static int __init ixgbevf_init_module(void)
|
|
|
module_init(ixgbevf_init_module);
|
|
|
|
|
|
/**
|
|
|
- * ixgbe_exit_module - Driver Exit Cleanup Routine
|
|
|
+ * ixgbevf_exit_module - Driver Exit Cleanup Routine
|
|
|
*
|
|
|
- * ixgbe_exit_module is called just before the driver is removed
|
|
|
+ * ixgbevf_exit_module is called just before the driver is removed
|
|
|
* from memory.
|
|
|
**/
|
|
|
static void __exit ixgbevf_exit_module(void)
|
|
@@ -3551,7 +3566,7 @@ static void __exit ixgbevf_exit_module(void)
|
|
|
|
|
|
#ifdef DEBUG
|
|
|
/**
|
|
|
- * ixgbe_get_hw_dev_name - return device name string
|
|
|
+ * ixgbevf_get_hw_dev_name - return device name string
|
|
|
* used by hardware layer to print debugging information
|
|
|
**/
|
|
|
char *ixgbevf_get_hw_dev_name(struct ixgbe_hw *hw)
|