|
@@ -123,8 +123,10 @@ static void e1000_clean_rx_ring(struct e1000_adapter *adapter,
|
|
|
struct e1000_rx_ring *rx_ring);
|
|
|
static void e1000_set_rx_mode(struct net_device *netdev);
|
|
|
static void e1000_update_phy_info(unsigned long data);
|
|
|
+static void e1000_update_phy_info_task(struct work_struct *work);
|
|
|
static void e1000_watchdog(unsigned long data);
|
|
|
static void e1000_82547_tx_fifo_stall(unsigned long data);
|
|
|
+static void e1000_82547_tx_fifo_stall_task(struct work_struct *work);
|
|
|
static netdev_tx_t e1000_xmit_frame(struct sk_buff *skb,
|
|
|
struct net_device *netdev);
|
|
|
static struct net_device_stats * e1000_get_stats(struct net_device *netdev);
|
|
@@ -1047,7 +1049,9 @@ static int __devinit e1000_probe(struct pci_dev *pdev,
|
|
|
adapter->phy_info_timer.function = e1000_update_phy_info;
|
|
|
adapter->phy_info_timer.data = (unsigned long)adapter;
|
|
|
|
|
|
+ INIT_WORK(&adapter->fifo_stall_task, e1000_82547_tx_fifo_stall_task);
|
|
|
INIT_WORK(&adapter->reset_task, e1000_reset_task);
|
|
|
+ INIT_WORK(&adapter->phy_info_task, e1000_update_phy_info_task);
|
|
|
|
|
|
e1000_check_options(adapter);
|
|
|
|
|
@@ -2234,6 +2238,14 @@ static void e1000_set_rx_mode(struct net_device *netdev)
|
|
|
static void e1000_update_phy_info(unsigned long data)
|
|
|
{
|
|
|
struct e1000_adapter *adapter = (struct e1000_adapter *)data;
|
|
|
+ schedule_work(&adapter->phy_info_task);
|
|
|
+}
|
|
|
+
|
|
|
+static void e1000_update_phy_info_task(struct work_struct *work)
|
|
|
+{
|
|
|
+ struct e1000_adapter *adapter = container_of(work,
|
|
|
+ struct e1000_adapter,
|
|
|
+ phy_info_task);
|
|
|
struct e1000_hw *hw = &adapter->hw;
|
|
|
e1000_phy_get_info(hw, &adapter->phy_info);
|
|
|
}
|
|
@@ -2242,10 +2254,21 @@ static void e1000_update_phy_info(unsigned long data)
|
|
|
* e1000_82547_tx_fifo_stall - Timer Call-back
|
|
|
* @data: pointer to adapter cast into an unsigned long
|
|
|
**/
|
|
|
-
|
|
|
static void e1000_82547_tx_fifo_stall(unsigned long data)
|
|
|
{
|
|
|
struct e1000_adapter *adapter = (struct e1000_adapter *)data;
|
|
|
+ schedule_work(&adapter->fifo_stall_task);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * e1000_82547_tx_fifo_stall_task - task to complete work
|
|
|
+ * @work: work struct contained inside adapter struct
|
|
|
+ **/
|
|
|
+static void e1000_82547_tx_fifo_stall_task(struct work_struct *work)
|
|
|
+{
|
|
|
+ struct e1000_adapter *adapter = container_of(work,
|
|
|
+ struct e1000_adapter,
|
|
|
+ fifo_stall_task);
|
|
|
struct e1000_hw *hw = &adapter->hw;
|
|
|
struct net_device *netdev = adapter->netdev;
|
|
|
u32 tctl;
|