Commit 89f077a0 authored by David S. Miller's avatar David S. Miller

Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net

Jeff Kirsher says:

====================
Intel Wired LAN Driver Updates

This series contains updates to igb and i40e.

Todd provides a fix for 82580 devices in igb, where the ethtool
loopback test was missing 82580 copper devices.

Jesse provides five fixes/cleanups to i40e based on feedback from
Joe Perches and the community.

v2: fixed up patch 5 in the series based on feedback from Joe Perches
    and David Miller
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents f8756916 d7595a22
...@@ -701,8 +701,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw, ...@@ -701,8 +701,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw,
details = I40E_ADMINQ_DETAILS(hw->aq.asq, hw->aq.asq.next_to_use); details = I40E_ADMINQ_DETAILS(hw->aq.asq, hw->aq.asq.next_to_use);
if (cmd_details) { if (cmd_details) {
memcpy(details, cmd_details, *details = *cmd_details;
sizeof(struct i40e_asq_cmd_details));
/* If the cmd_details are defined copy the cookie. The /* If the cmd_details are defined copy the cookie. The
* cpu_to_le32 is not needed here because the data is ignored * cpu_to_le32 is not needed here because the data is ignored
...@@ -760,7 +759,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw, ...@@ -760,7 +759,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw,
desc_on_ring = I40E_ADMINQ_DESC(hw->aq.asq, hw->aq.asq.next_to_use); desc_on_ring = I40E_ADMINQ_DESC(hw->aq.asq, hw->aq.asq.next_to_use);
/* if the desc is available copy the temp desc to the right place */ /* if the desc is available copy the temp desc to the right place */
memcpy(desc_on_ring, desc, sizeof(struct i40e_aq_desc)); *desc_on_ring = *desc;
/* if buff is not NULL assume indirect command */ /* if buff is not NULL assume indirect command */
if (buff != NULL) { if (buff != NULL) {
...@@ -807,7 +806,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw, ...@@ -807,7 +806,7 @@ i40e_status i40e_asq_send_command(struct i40e_hw *hw,
/* if ready, copy the desc back to temp */ /* if ready, copy the desc back to temp */
if (i40e_asq_done(hw)) { if (i40e_asq_done(hw)) {
memcpy(desc, desc_on_ring, sizeof(struct i40e_aq_desc)); *desc = *desc_on_ring;
if (buff != NULL) if (buff != NULL)
memcpy(buff, dma_buff->va, buff_size); memcpy(buff, dma_buff->va, buff_size);
retval = le16_to_cpu(desc->retval); retval = le16_to_cpu(desc->retval);
......
...@@ -507,7 +507,7 @@ i40e_status i40e_aq_get_link_info(struct i40e_hw *hw, ...@@ -507,7 +507,7 @@ i40e_status i40e_aq_get_link_info(struct i40e_hw *hw,
/* save link status information */ /* save link status information */
if (link) if (link)
memcpy(link, hw_link_info, sizeof(struct i40e_link_status)); *link = *hw_link_info;
/* flag cleared so helper functions don't call AQ again */ /* flag cleared so helper functions don't call AQ again */
hw->phy.get_link_info = false; hw->phy.get_link_info = false;
......
This diff is collapsed.
...@@ -1607,6 +1607,9 @@ static int igb_integrated_phy_loopback(struct igb_adapter *adapter) ...@@ -1607,6 +1607,9 @@ static int igb_integrated_phy_loopback(struct igb_adapter *adapter)
igb_write_phy_reg(hw, I347AT4_PAGE_SELECT, 0); igb_write_phy_reg(hw, I347AT4_PAGE_SELECT, 0);
igb_write_phy_reg(hw, PHY_CONTROL, 0x4140); igb_write_phy_reg(hw, PHY_CONTROL, 0x4140);
} }
} else if (hw->phy.type == e1000_phy_82580) {
/* enable MII loopback */
igb_write_phy_reg(hw, I82580_PHY_LBK_CTRL, 0x8041);
} }
/* add small delay to avoid loopback test failure */ /* add small delay to avoid loopback test failure */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment