diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 17:38:00 -0400 |
|---|---|---|
| committer | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 17:38:00 -0400 |
| commit | 4183bef2e093a2f0aab45f2d5fed82b0e02aeacf (patch) | |
| tree | e84c484db3746a0f3ead0fb7a2bb9e5a42b89e85 /drivers/net/ethernet/intel | |
| parent | 662478d060a39b8faf2b1fe2fbbb212556c2e052 (diff) | |
| parent | 775c4f66fd855e68a98fc5049003810fe98e2e20 (diff) | |
Merge branch 'late/dt' into next/dt2
This is support for the ARM Chromebook, originally scheduled
as a "late" pull request. Since it's already late now, we
can combine this into the existing next/dt2 branch.
* late/dt:
ARM: exynos: dts: cros5250: add EC device
ARM: dts: Add sbs-battery for exynos5250-snow
ARM: dts: Add i2c-arbitrator bus for exynos5250-snow
ARM: dts: Add chip-id controller node on Exynos4/5 SoC
ARM: EXYNOS: Create virtual I/O mapping for Chip-ID controller using device tree
Diffstat (limited to 'drivers/net/ethernet/intel')
| -rw-r--r-- | drivers/net/ethernet/intel/e100.c | 36 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/e1000/e1000_ethtool.c | 14 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/e1000e/netdev.c | 7 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/ixgb/ixgb_main.c | 7 | ||||
| -rw-r--r-- | drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | 11 |
5 files changed, 57 insertions, 18 deletions
diff --git a/drivers/net/ethernet/intel/e100.c b/drivers/net/ethernet/intel/e100.c index ec800b093e7e..d2bea3f07c73 100644 --- a/drivers/net/ethernet/intel/e100.c +++ b/drivers/net/ethernet/intel/e100.c | |||
| @@ -870,7 +870,7 @@ err_unlock: | |||
| 870 | } | 870 | } |
| 871 | 871 | ||
| 872 | static int e100_exec_cb(struct nic *nic, struct sk_buff *skb, | 872 | static int e100_exec_cb(struct nic *nic, struct sk_buff *skb, |
| 873 | void (*cb_prepare)(struct nic *, struct cb *, struct sk_buff *)) | 873 | int (*cb_prepare)(struct nic *, struct cb *, struct sk_buff *)) |
| 874 | { | 874 | { |
| 875 | struct cb *cb; | 875 | struct cb *cb; |
| 876 | unsigned long flags; | 876 | unsigned long flags; |
| @@ -888,10 +888,13 @@ static int e100_exec_cb(struct nic *nic, struct sk_buff *skb, | |||
| 888 | nic->cbs_avail--; | 888 | nic->cbs_avail--; |
| 889 | cb->skb = skb; | 889 | cb->skb = skb; |
| 890 | 890 | ||
| 891 | err = cb_prepare(nic, cb, skb); | ||
| 892 | if (err) | ||
| 893 | goto err_unlock; | ||
| 894 | |||
| 891 | if (unlikely(!nic->cbs_avail)) | 895 | if (unlikely(!nic->cbs_avail)) |
| 892 | err = -ENOSPC; | 896 | err = -ENOSPC; |
| 893 | 897 | ||
| 894 | cb_prepare(nic, cb, skb); | ||
| 895 | 898 | ||
| 896 | /* Order is important otherwise we'll be in a race with h/w: | 899 | /* Order is important otherwise we'll be in a race with h/w: |
| 897 | * set S-bit in current first, then clear S-bit in previous. */ | 900 | * set S-bit in current first, then clear S-bit in previous. */ |
| @@ -1091,7 +1094,7 @@ static void e100_get_defaults(struct nic *nic) | |||
| 1091 | nic->mii.mdio_write = mdio_write; | 1094 | nic->mii.mdio_write = mdio_write; |
| 1092 | } | 1095 | } |
| 1093 | 1096 | ||
| 1094 | static void e100_configure(struct nic *nic, struct cb *cb, struct sk_buff *skb) | 1097 | static int e100_configure(struct nic *nic, struct cb *cb, struct sk_buff *skb) |
| 1095 | { | 1098 | { |
| 1096 | struct config *config = &cb->u.config; | 1099 | struct config *config = &cb->u.config; |
| 1097 | u8 *c = (u8 *)config; | 1100 | u8 *c = (u8 *)config; |
| @@ -1181,6 +1184,7 @@ static void e100_configure(struct nic *nic, struct cb *cb, struct sk_buff *skb) | |||
| 1181 | netif_printk(nic, hw, KERN_DEBUG, nic->netdev, | 1184 | netif_printk(nic, hw, KERN_DEBUG, nic->netdev, |
| 1182 | "[16-23]=%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X\n", | 1185 | "[16-23]=%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X\n", |
| 1183 | c[16], c[17], c[18], c[19], c[20], c[21], c[22], c[23]); | 1186 | c[16], c[17], c[18], c[19], c[20], c[21], c[22], c[23]); |
| 1187 | return 0; | ||
| 1184 | } | 1188 | } |
| 1185 | 1189 | ||
| 1186 | /************************************************************************* | 1190 | /************************************************************************* |
| @@ -1331,7 +1335,7 @@ static const struct firmware *e100_request_firmware(struct nic *nic) | |||
| 1331 | return fw; | 1335 | return fw; |
| 1332 | } | 1336 | } |
| 1333 | 1337 | ||
| 1334 | static void e100_setup_ucode(struct nic *nic, struct cb *cb, | 1338 | static int e100_setup_ucode(struct nic *nic, struct cb *cb, |
| 1335 | struct sk_buff *skb) | 1339 | struct sk_buff *skb) |
| 1336 | { | 1340 | { |
| 1337 | const struct firmware *fw = (void *)skb; | 1341 | const struct firmware *fw = (void *)skb; |
| @@ -1358,6 +1362,7 @@ static void e100_setup_ucode(struct nic *nic, struct cb *cb, | |||
| 1358 | cb->u.ucode[min_size] |= cpu_to_le32((BUNDLESMALL) ? 0xFFFF : 0xFF80); | 1362 | cb->u.ucode[min_size] |= cpu_to_le32((BUNDLESMALL) ? 0xFFFF : 0xFF80); |
| 1359 | 1363 | ||
| 1360 | cb->command = cpu_to_le16(cb_ucode | cb_el); | 1364 | cb->command = cpu_to_le16(cb_ucode | cb_el); |
| 1365 | return 0; | ||
| 1361 | } | 1366 | } |
| 1362 | 1367 | ||
| 1363 | static inline int e100_load_ucode_wait(struct nic *nic) | 1368 | static inline int e100_load_ucode_wait(struct nic *nic) |
| @@ -1400,18 +1405,20 @@ static inline int e100_load_ucode_wait(struct nic *nic) | |||
| 1400 | return err; | 1405 | return err; |
| 1401 | } | 1406 | } |
| 1402 | 1407 | ||
| 1403 | static void e100_setup_iaaddr(struct nic *nic, struct cb *cb, | 1408 | static int e100_setup_iaaddr(struct nic *nic, struct cb *cb, |
| 1404 | struct sk_buff *skb) | 1409 | struct sk_buff *skb) |
| 1405 | { | 1410 | { |
| 1406 | cb->command = cpu_to_le16(cb_iaaddr); | 1411 | cb->command = cpu_to_le16(cb_iaaddr); |
| 1407 | memcpy(cb->u.iaaddr, nic->netdev->dev_addr, ETH_ALEN); | 1412 | memcpy(cb->u.iaaddr, nic->netdev->dev_addr, ETH_ALEN); |
| 1413 | return 0; | ||
| 1408 | } | 1414 | } |
| 1409 | 1415 | ||
| 1410 | static void e100_dump(struct nic *nic, struct cb *cb, struct sk_buff *skb) | 1416 | static int e100_dump(struct nic *nic, struct cb *cb, struct sk_buff *skb) |
| 1411 | { | 1417 | { |
| 1412 | cb->command = cpu_to_le16(cb_dump); | 1418 | cb->command = cpu_to_le16(cb_dump); |
| 1413 | cb->u.dump_buffer_addr = cpu_to_le32(nic->dma_addr + | 1419 | cb->u.dump_buffer_addr = cpu_to_le32(nic->dma_addr + |
| 1414 | offsetof(struct mem, dump_buf)); | 1420 | offsetof(struct mem, dump_buf)); |
| 1421 | return 0; | ||
| 1415 | } | 1422 | } |
| 1416 | 1423 | ||
| 1417 | static int e100_phy_check_without_mii(struct nic *nic) | 1424 | static int e100_phy_check_without_mii(struct nic *nic) |
| @@ -1581,7 +1588,7 @@ static int e100_hw_init(struct nic *nic) | |||
| 1581 | return 0; | 1588 | return 0; |
| 1582 | } | 1589 | } |
| 1583 | 1590 | ||
| 1584 | static void e100_multi(struct nic *nic, struct cb *cb, struct sk_buff *skb) | 1591 | static int e100_multi(struct nic *nic, struct cb *cb, struct sk_buff *skb) |
| 1585 | { | 1592 | { |
| 1586 | struct net_device *netdev = nic->netdev; | 1593 | struct net_device *netdev = nic->netdev; |
| 1587 | struct netdev_hw_addr *ha; | 1594 | struct netdev_hw_addr *ha; |
| @@ -1596,6 +1603,7 @@ static void e100_multi(struct nic *nic, struct cb *cb, struct sk_buff *skb) | |||
| 1596 | memcpy(&cb->u.multi.addr[i++ * ETH_ALEN], &ha->addr, | 1603 | memcpy(&cb->u.multi.addr[i++ * ETH_ALEN], &ha->addr, |
| 1597 | ETH_ALEN); | 1604 | ETH_ALEN); |
| 1598 | } | 1605 | } |
| 1606 | return 0; | ||
| 1599 | } | 1607 | } |
| 1600 | 1608 | ||
| 1601 | static void e100_set_multicast_list(struct net_device *netdev) | 1609 | static void e100_set_multicast_list(struct net_device *netdev) |
| @@ -1756,11 +1764,18 @@ static void e100_watchdog(unsigned long data) | |||
| 1756 | round_jiffies(jiffies + E100_WATCHDOG_PERIOD)); | 1764 | round_jiffies(jiffies + E100_WATCHDOG_PERIOD)); |
| 1757 | } | 1765 | } |
| 1758 | 1766 | ||
| 1759 | static void e100_xmit_prepare(struct nic *nic, struct cb *cb, | 1767 | static int e100_xmit_prepare(struct nic *nic, struct cb *cb, |
| 1760 | struct sk_buff *skb) | 1768 | struct sk_buff *skb) |
| 1761 | { | 1769 | { |
| 1770 | dma_addr_t dma_addr; | ||
| 1762 | cb->command = nic->tx_command; | 1771 | cb->command = nic->tx_command; |
| 1763 | 1772 | ||
| 1773 | dma_addr = pci_map_single(nic->pdev, | ||
| 1774 | skb->data, skb->len, PCI_DMA_TODEVICE); | ||
| 1775 | /* If we can't map the skb, have the upper layer try later */ | ||
| 1776 | if (pci_dma_mapping_error(nic->pdev, dma_addr)) | ||
| 1777 | return -ENOMEM; | ||
| 1778 | |||
| 1764 | /* | 1779 | /* |
| 1765 | * Use the last 4 bytes of the SKB payload packet as the CRC, used for | 1780 | * Use the last 4 bytes of the SKB payload packet as the CRC, used for |
| 1766 | * testing, ie sending frames with bad CRC. | 1781 | * testing, ie sending frames with bad CRC. |
| @@ -1777,11 +1792,10 @@ static void e100_xmit_prepare(struct nic *nic, struct cb *cb, | |||
| 1777 | cb->u.tcb.tcb_byte_count = 0; | 1792 | cb->u.tcb.tcb_byte_count = 0; |
| 1778 | cb->u.tcb.threshold = nic->tx_threshold; | 1793 | cb->u.tcb.threshold = nic->tx_threshold; |
| 1779 | cb->u.tcb.tbd_count = 1; | 1794 | cb->u.tcb.tbd_count = 1; |
| 1780 | cb->u.tcb.tbd.buf_addr = cpu_to_le32(pci_map_single(nic->pdev, | 1795 | cb->u.tcb.tbd.buf_addr = cpu_to_le32(dma_addr); |
| 1781 | skb->data, skb->len, PCI_DMA_TODEVICE)); | ||
| 1782 | /* check for mapping failure? */ | ||
| 1783 | cb->u.tcb.tbd.size = cpu_to_le16(skb->len); | 1796 | cb->u.tcb.tbd.size = cpu_to_le16(skb->len); |
| 1784 | skb_tx_timestamp(skb); | 1797 | skb_tx_timestamp(skb); |
| 1798 | return 0; | ||
| 1785 | } | 1799 | } |
| 1786 | 1800 | ||
| 1787 | static netdev_tx_t e100_xmit_frame(struct sk_buff *skb, | 1801 | static netdev_tx_t e100_xmit_frame(struct sk_buff *skb, |
diff --git a/drivers/net/ethernet/intel/e1000/e1000_ethtool.c b/drivers/net/ethernet/intel/e1000/e1000_ethtool.c index 43462d596a4e..ffd287196bf8 100644 --- a/drivers/net/ethernet/intel/e1000/e1000_ethtool.c +++ b/drivers/net/ethernet/intel/e1000/e1000_ethtool.c | |||
| @@ -1053,6 +1053,10 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
| 1053 | txdr->buffer_info[i].dma = | 1053 | txdr->buffer_info[i].dma = |
| 1054 | dma_map_single(&pdev->dev, skb->data, skb->len, | 1054 | dma_map_single(&pdev->dev, skb->data, skb->len, |
| 1055 | DMA_TO_DEVICE); | 1055 | DMA_TO_DEVICE); |
| 1056 | if (dma_mapping_error(&pdev->dev, txdr->buffer_info[i].dma)) { | ||
| 1057 | ret_val = 4; | ||
| 1058 | goto err_nomem; | ||
| 1059 | } | ||
| 1056 | tx_desc->buffer_addr = cpu_to_le64(txdr->buffer_info[i].dma); | 1060 | tx_desc->buffer_addr = cpu_to_le64(txdr->buffer_info[i].dma); |
| 1057 | tx_desc->lower.data = cpu_to_le32(skb->len); | 1061 | tx_desc->lower.data = cpu_to_le32(skb->len); |
| 1058 | tx_desc->lower.data |= cpu_to_le32(E1000_TXD_CMD_EOP | | 1062 | tx_desc->lower.data |= cpu_to_le32(E1000_TXD_CMD_EOP | |
| @@ -1069,7 +1073,7 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
| 1069 | rxdr->buffer_info = kcalloc(rxdr->count, sizeof(struct e1000_buffer), | 1073 | rxdr->buffer_info = kcalloc(rxdr->count, sizeof(struct e1000_buffer), |
| 1070 | GFP_KERNEL); | 1074 | GFP_KERNEL); |
| 1071 | if (!rxdr->buffer_info) { | 1075 | if (!rxdr->buffer_info) { |
| 1072 | ret_val = 4; | 1076 | ret_val = 5; |
| 1073 | goto err_nomem; | 1077 | goto err_nomem; |
| 1074 | } | 1078 | } |
| 1075 | 1079 | ||
| @@ -1077,7 +1081,7 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
| 1077 | rxdr->desc = dma_alloc_coherent(&pdev->dev, rxdr->size, &rxdr->dma, | 1081 | rxdr->desc = dma_alloc_coherent(&pdev->dev, rxdr->size, &rxdr->dma, |
| 1078 | GFP_KERNEL); | 1082 | GFP_KERNEL); |
| 1079 | if (!rxdr->desc) { | 1083 | if (!rxdr->desc) { |
| 1080 | ret_val = 5; | 1084 | ret_val = 6; |
| 1081 | goto err_nomem; | 1085 | goto err_nomem; |
| 1082 | } | 1086 | } |
| 1083 | memset(rxdr->desc, 0, rxdr->size); | 1087 | memset(rxdr->desc, 0, rxdr->size); |
| @@ -1101,7 +1105,7 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
| 1101 | 1105 | ||
| 1102 | skb = alloc_skb(E1000_RXBUFFER_2048 + NET_IP_ALIGN, GFP_KERNEL); | 1106 | skb = alloc_skb(E1000_RXBUFFER_2048 + NET_IP_ALIGN, GFP_KERNEL); |
| 1103 | if (!skb) { | 1107 | if (!skb) { |
| 1104 | ret_val = 6; | 1108 | ret_val = 7; |
| 1105 | goto err_nomem; | 1109 | goto err_nomem; |
| 1106 | } | 1110 | } |
| 1107 | skb_reserve(skb, NET_IP_ALIGN); | 1111 | skb_reserve(skb, NET_IP_ALIGN); |
| @@ -1110,6 +1114,10 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter) | |||
| 1110 | rxdr->buffer_info[i].dma = | 1114 | rxdr->buffer_info[i].dma = |
| 1111 | dma_map_single(&pdev->dev, skb->data, | 1115 | dma_map_single(&pdev->dev, skb->data, |
| 1112 | E1000_RXBUFFER_2048, DMA_FROM_DEVICE); | 1116 | E1000_RXBUFFER_2048, DMA_FROM_DEVICE); |
| 1117 | if (dma_mapping_error(&pdev->dev, rxdr->buffer_info[i].dma)) { | ||
| 1118 | ret_val = 8; | ||
| 1119 | goto err_nomem; | ||
| 1120 | } | ||
| 1113 | rx_desc->buffer_addr = cpu_to_le64(rxdr->buffer_info[i].dma); | 1121 | rx_desc->buffer_addr = cpu_to_le64(rxdr->buffer_info[i].dma); |
| 1114 | memset(skb->data, 0x00, skb->len); | 1122 | memset(skb->data, 0x00, skb->len); |
| 1115 | } | 1123 | } |
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c index 948b86ffa4f0..7e615e2bf7e6 100644 --- a/drivers/net/ethernet/intel/e1000e/netdev.c +++ b/drivers/net/ethernet/intel/e1000e/netdev.c | |||
| @@ -848,11 +848,16 @@ check_page: | |||
| 848 | } | 848 | } |
| 849 | } | 849 | } |
| 850 | 850 | ||
| 851 | if (!buffer_info->dma) | 851 | if (!buffer_info->dma) { |
| 852 | buffer_info->dma = dma_map_page(&pdev->dev, | 852 | buffer_info->dma = dma_map_page(&pdev->dev, |
| 853 | buffer_info->page, 0, | 853 | buffer_info->page, 0, |
| 854 | PAGE_SIZE, | 854 | PAGE_SIZE, |
| 855 | DMA_FROM_DEVICE); | 855 | DMA_FROM_DEVICE); |
| 856 | if (dma_mapping_error(&pdev->dev, buffer_info->dma)) { | ||
| 857 | adapter->alloc_rx_buff_failed++; | ||
| 858 | break; | ||
| 859 | } | ||
| 860 | } | ||
| 856 | 861 | ||
| 857 | rx_desc = E1000_RX_DESC_EXT(*rx_ring, i); | 862 | rx_desc = E1000_RX_DESC_EXT(*rx_ring, i); |
| 858 | rx_desc->read.buffer_addr = cpu_to_le64(buffer_info->dma); | 863 | rx_desc->read.buffer_addr = cpu_to_le64(buffer_info->dma); |
diff --git a/drivers/net/ethernet/intel/ixgb/ixgb_main.c b/drivers/net/ethernet/intel/ixgb/ixgb_main.c index ea4808373435..b5f94abe3cff 100644 --- a/drivers/net/ethernet/intel/ixgb/ixgb_main.c +++ b/drivers/net/ethernet/intel/ixgb/ixgb_main.c | |||
| @@ -2159,6 +2159,10 @@ map_skb: | |||
| 2159 | skb->data, | 2159 | skb->data, |
| 2160 | adapter->rx_buffer_len, | 2160 | adapter->rx_buffer_len, |
| 2161 | DMA_FROM_DEVICE); | 2161 | DMA_FROM_DEVICE); |
| 2162 | if (dma_mapping_error(&pdev->dev, buffer_info->dma)) { | ||
| 2163 | adapter->alloc_rx_buff_failed++; | ||
| 2164 | break; | ||
| 2165 | } | ||
| 2162 | 2166 | ||
| 2163 | rx_desc = IXGB_RX_DESC(*rx_ring, i); | 2167 | rx_desc = IXGB_RX_DESC(*rx_ring, i); |
| 2164 | rx_desc->buff_addr = cpu_to_le64(buffer_info->dma); | 2168 | rx_desc->buff_addr = cpu_to_le64(buffer_info->dma); |
| @@ -2168,7 +2172,8 @@ map_skb: | |||
| 2168 | rx_desc->status = 0; | 2172 | rx_desc->status = 0; |
| 2169 | 2173 | ||
| 2170 | 2174 | ||
| 2171 | if (++i == rx_ring->count) i = 0; | 2175 | if (++i == rx_ring->count) |
| 2176 | i = 0; | ||
| 2172 | buffer_info = &rx_ring->buffer_info[i]; | 2177 | buffer_info = &rx_ring->buffer_info[i]; |
| 2173 | } | 2178 | } |
| 2174 | 2179 | ||
diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c index db5611ae407e..79f4a26ea6cc 100644 --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | |||
| @@ -7922,12 +7922,19 @@ static int __init ixgbe_init_module(void) | |||
| 7922 | ixgbe_dbg_init(); | 7922 | ixgbe_dbg_init(); |
| 7923 | #endif /* CONFIG_DEBUG_FS */ | 7923 | #endif /* CONFIG_DEBUG_FS */ |
| 7924 | 7924 | ||
| 7925 | ret = pci_register_driver(&ixgbe_driver); | ||
| 7926 | if (ret) { | ||
| 7927 | #ifdef CONFIG_DEBUG_FS | ||
| 7928 | ixgbe_dbg_exit(); | ||
| 7929 | #endif /* CONFIG_DEBUG_FS */ | ||
| 7930 | return ret; | ||
| 7931 | } | ||
| 7932 | |||
| 7925 | #ifdef CONFIG_IXGBE_DCA | 7933 | #ifdef CONFIG_IXGBE_DCA |
| 7926 | dca_register_notify(&dca_notifier); | 7934 | dca_register_notify(&dca_notifier); |
| 7927 | #endif | 7935 | #endif |
| 7928 | 7936 | ||
| 7929 | ret = pci_register_driver(&ixgbe_driver); | 7937 | return 0; |
| 7930 | return ret; | ||
| 7931 | } | 7938 | } |
| 7932 | 7939 | ||
| 7933 | module_init(ixgbe_init_module); | 7940 | module_init(ixgbe_init_module); |
