diff options
Diffstat (limited to 'drivers/net/ixgbe')
-rw-r--r-- | drivers/net/ixgbe/ixgbe.h | 4 | ||||
-rw-r--r-- | drivers/net/ixgbe/ixgbe_ethtool.c | 33 | ||||
-rw-r--r-- | drivers/net/ixgbe/ixgbe_type.h | 31 |
3 files changed, 19 insertions, 49 deletions
diff --git a/drivers/net/ixgbe/ixgbe.h b/drivers/net/ixgbe/ixgbe.h index cd22323cfd22..2a93e116f5a7 100644 --- a/drivers/net/ixgbe/ixgbe.h +++ b/drivers/net/ixgbe/ixgbe.h | |||
@@ -229,10 +229,6 @@ struct ixgbe_q_vector { | |||
229 | #define IXGBE_TX_CTXTDESC_ADV(R, i) \ | 229 | #define IXGBE_TX_CTXTDESC_ADV(R, i) \ |
230 | (&(((struct ixgbe_adv_tx_context_desc *)((R).desc))[i])) | 230 | (&(((struct ixgbe_adv_tx_context_desc *)((R).desc))[i])) |
231 | 231 | ||
232 | #define IXGBE_GET_DESC(R, i, type) (&(((struct type *)((R).desc))[i])) | ||
233 | #define IXGBE_TX_DESC(R, i) IXGBE_GET_DESC(R, i, ixgbe_legacy_tx_desc) | ||
234 | #define IXGBE_RX_DESC(R, i) IXGBE_GET_DESC(R, i, ixgbe_legacy_rx_desc) | ||
235 | |||
236 | #define IXGBE_MAX_JUMBO_FRAME_SIZE 16128 | 232 | #define IXGBE_MAX_JUMBO_FRAME_SIZE 16128 |
237 | #ifdef IXGBE_FCOE | 233 | #ifdef IXGBE_FCOE |
238 | /* Use 3K as the baby jumbo frame size for FCoE */ | 234 | /* Use 3K as the baby jumbo frame size for FCoE */ |
diff --git a/drivers/net/ixgbe/ixgbe_ethtool.c b/drivers/net/ixgbe/ixgbe_ethtool.c index 2a978008fd6e..1464b33f1b8e 100644 --- a/drivers/net/ixgbe/ixgbe_ethtool.c +++ b/drivers/net/ixgbe/ixgbe_ethtool.c | |||
@@ -1440,7 +1440,7 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1440 | goto err_nomem; | 1440 | goto err_nomem; |
1441 | } | 1441 | } |
1442 | 1442 | ||
1443 | tx_ring->size = tx_ring->count * sizeof(struct ixgbe_legacy_tx_desc); | 1443 | tx_ring->size = tx_ring->count * sizeof(union ixgbe_adv_tx_desc); |
1444 | tx_ring->size = ALIGN(tx_ring->size, 4096); | 1444 | tx_ring->size = ALIGN(tx_ring->size, 4096); |
1445 | if (!(tx_ring->desc = pci_alloc_consistent(pdev, tx_ring->size, | 1445 | if (!(tx_ring->desc = pci_alloc_consistent(pdev, tx_ring->size, |
1446 | &tx_ring->dma))) { | 1446 | &tx_ring->dma))) { |
@@ -1454,7 +1454,7 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1454 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDBAH(0), | 1454 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDBAH(0), |
1455 | ((u64) tx_ring->dma >> 32)); | 1455 | ((u64) tx_ring->dma >> 32)); |
1456 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDLEN(0), | 1456 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDLEN(0), |
1457 | tx_ring->count * sizeof(struct ixgbe_legacy_tx_desc)); | 1457 | tx_ring->count * sizeof(union ixgbe_adv_tx_desc)); |
1458 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDH(0), 0); | 1458 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDH(0), 0); |
1459 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDT(0), 0); | 1459 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TDT(0), 0); |
1460 | 1460 | ||
@@ -1472,7 +1472,7 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1472 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TXDCTL(0), reg_data); | 1472 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_TXDCTL(0), reg_data); |
1473 | 1473 | ||
1474 | for (i = 0; i < tx_ring->count; i++) { | 1474 | for (i = 0; i < tx_ring->count; i++) { |
1475 | struct ixgbe_legacy_tx_desc *desc = IXGBE_TX_DESC(*tx_ring, i); | 1475 | union ixgbe_adv_tx_desc *desc = IXGBE_TX_DESC_ADV(*tx_ring, i); |
1476 | struct sk_buff *skb; | 1476 | struct sk_buff *skb; |
1477 | unsigned int size = 1024; | 1477 | unsigned int size = 1024; |
1478 | 1478 | ||
@@ -1486,13 +1486,18 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1486 | tx_ring->tx_buffer_info[i].length = skb->len; | 1486 | tx_ring->tx_buffer_info[i].length = skb->len; |
1487 | tx_ring->tx_buffer_info[i].dma = | 1487 | tx_ring->tx_buffer_info[i].dma = |
1488 | pci_map_single(pdev, skb->data, skb->len, | 1488 | pci_map_single(pdev, skb->data, skb->len, |
1489 | PCI_DMA_TODEVICE); | 1489 | PCI_DMA_TODEVICE); |
1490 | desc->buffer_addr = cpu_to_le64(tx_ring->tx_buffer_info[i].dma); | 1490 | desc->read.buffer_addr = |
1491 | desc->lower.data = cpu_to_le32(skb->len); | 1491 | cpu_to_le64(tx_ring->tx_buffer_info[i].dma); |
1492 | desc->lower.data |= cpu_to_le32(IXGBE_TXD_CMD_EOP | | 1492 | desc->read.cmd_type_len = cpu_to_le32(skb->len); |
1493 | IXGBE_TXD_CMD_IFCS | | 1493 | desc->read.cmd_type_len |= cpu_to_le32(IXGBE_TXD_CMD_EOP | |
1494 | IXGBE_TXD_CMD_RS); | 1494 | IXGBE_TXD_CMD_IFCS | |
1495 | desc->upper.data = 0; | 1495 | IXGBE_TXD_CMD_RS); |
1496 | desc->read.olinfo_status = 0; | ||
1497 | if (adapter->hw.mac.type == ixgbe_mac_82599EB) | ||
1498 | desc->read.olinfo_status |= | ||
1499 | (skb->len << IXGBE_ADVTXD_PAYLEN_SHIFT); | ||
1500 | |||
1496 | } | 1501 | } |
1497 | 1502 | ||
1498 | /* Setup Rx Descriptor ring and Rx buffers */ | 1503 | /* Setup Rx Descriptor ring and Rx buffers */ |
@@ -1508,7 +1513,7 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1508 | goto err_nomem; | 1513 | goto err_nomem; |
1509 | } | 1514 | } |
1510 | 1515 | ||
1511 | rx_ring->size = rx_ring->count * sizeof(struct ixgbe_legacy_rx_desc); | 1516 | rx_ring->size = rx_ring->count * sizeof(union ixgbe_adv_rx_desc); |
1512 | rx_ring->size = ALIGN(rx_ring->size, 4096); | 1517 | rx_ring->size = ALIGN(rx_ring->size, 4096); |
1513 | if (!(rx_ring->desc = pci_alloc_consistent(pdev, rx_ring->size, | 1518 | if (!(rx_ring->desc = pci_alloc_consistent(pdev, rx_ring->size, |
1514 | &rx_ring->dma))) { | 1519 | &rx_ring->dma))) { |
@@ -1566,8 +1571,8 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1566 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_RXCTRL, rctl); | 1571 | IXGBE_WRITE_REG(&adapter->hw, IXGBE_RXCTRL, rctl); |
1567 | 1572 | ||
1568 | for (i = 0; i < rx_ring->count; i++) { | 1573 | for (i = 0; i < rx_ring->count; i++) { |
1569 | struct ixgbe_legacy_rx_desc *rx_desc = | 1574 | union ixgbe_adv_rx_desc *rx_desc = |
1570 | IXGBE_RX_DESC(*rx_ring, i); | 1575 | IXGBE_RX_DESC_ADV(*rx_ring, i); |
1571 | struct sk_buff *skb; | 1576 | struct sk_buff *skb; |
1572 | 1577 | ||
1573 | skb = alloc_skb(IXGBE_RXBUFFER_2048 + NET_IP_ALIGN, GFP_KERNEL); | 1578 | skb = alloc_skb(IXGBE_RXBUFFER_2048 + NET_IP_ALIGN, GFP_KERNEL); |
@@ -1580,7 +1585,7 @@ static int ixgbe_setup_desc_rings(struct ixgbe_adapter *adapter) | |||
1580 | rx_ring->rx_buffer_info[i].dma = | 1585 | rx_ring->rx_buffer_info[i].dma = |
1581 | pci_map_single(pdev, skb->data, IXGBE_RXBUFFER_2048, | 1586 | pci_map_single(pdev, skb->data, IXGBE_RXBUFFER_2048, |
1582 | PCI_DMA_FROMDEVICE); | 1587 | PCI_DMA_FROMDEVICE); |
1583 | rx_desc->buffer_addr = | 1588 | rx_desc->read.pkt_addr = |
1584 | cpu_to_le64(rx_ring->rx_buffer_info[i].dma); | 1589 | cpu_to_le64(rx_ring->rx_buffer_info[i].dma); |
1585 | memset(skb->data, 0x00, skb->len); | 1590 | memset(skb->data, 0x00, skb->len); |
1586 | } | 1591 | } |
diff --git a/drivers/net/ixgbe/ixgbe_type.h b/drivers/net/ixgbe/ixgbe_type.h index fa87309dc087..8fb6ade0c629 100644 --- a/drivers/net/ixgbe/ixgbe_type.h +++ b/drivers/net/ixgbe/ixgbe_type.h | |||
@@ -1893,27 +1893,6 @@ enum ixgbe_fdir_pballoc_type { | |||
1893 | #define IXGBE_FDIR_INIT_DONE_POLL 10 | 1893 | #define IXGBE_FDIR_INIT_DONE_POLL 10 |
1894 | #define IXGBE_FDIRCMD_CMD_POLL 10 | 1894 | #define IXGBE_FDIRCMD_CMD_POLL 10 |
1895 | 1895 | ||
1896 | /* Transmit Descriptor - Legacy */ | ||
1897 | struct ixgbe_legacy_tx_desc { | ||
1898 | u64 buffer_addr; /* Address of the descriptor's data buffer */ | ||
1899 | union { | ||
1900 | __le32 data; | ||
1901 | struct { | ||
1902 | __le16 length; /* Data buffer length */ | ||
1903 | u8 cso; /* Checksum offset */ | ||
1904 | u8 cmd; /* Descriptor control */ | ||
1905 | } flags; | ||
1906 | } lower; | ||
1907 | union { | ||
1908 | __le32 data; | ||
1909 | struct { | ||
1910 | u8 status; /* Descriptor status */ | ||
1911 | u8 css; /* Checksum start */ | ||
1912 | __le16 vlan; | ||
1913 | } fields; | ||
1914 | } upper; | ||
1915 | }; | ||
1916 | |||
1917 | /* Transmit Descriptor - Advanced */ | 1896 | /* Transmit Descriptor - Advanced */ |
1918 | union ixgbe_adv_tx_desc { | 1897 | union ixgbe_adv_tx_desc { |
1919 | struct { | 1898 | struct { |
@@ -1928,16 +1907,6 @@ union ixgbe_adv_tx_desc { | |||
1928 | } wb; | 1907 | } wb; |
1929 | }; | 1908 | }; |
1930 | 1909 | ||
1931 | /* Receive Descriptor - Legacy */ | ||
1932 | struct ixgbe_legacy_rx_desc { | ||
1933 | __le64 buffer_addr; /* Address of the descriptor's data buffer */ | ||
1934 | __le16 length; /* Length of data DMAed into data buffer */ | ||
1935 | __le16 csum; /* Packet checksum */ | ||
1936 | u8 status; /* Descriptor status */ | ||
1937 | u8 errors; /* Descriptor Errors */ | ||
1938 | __le16 vlan; | ||
1939 | }; | ||
1940 | |||
1941 | /* Receive Descriptor - Advanced */ | 1910 | /* Receive Descriptor - Advanced */ |
1942 | union ixgbe_adv_rx_desc { | 1911 | union ixgbe_adv_rx_desc { |
1943 | struct { | 1912 | struct { |