diff options
Diffstat (limited to 'drivers/net/ethernet')
| -rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c | 9 | ||||
| -rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c | 9 | ||||
| -rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_sriov.c | 63 | ||||
| -rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.c | 31 | ||||
| -rw-r--r-- | drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.h | 3 | ||||
| -rw-r--r-- | drivers/net/ethernet/emulex/benet/be_main.c | 4 | ||||
| -rw-r--r-- | drivers/net/ethernet/freescale/fec_main.c | 3 | ||||
| -rw-r--r-- | drivers/net/ethernet/jme.c | 2 | ||||
| -rw-r--r-- | drivers/net/ethernet/qlogic/netxen/netxen_nic.h | 1 | ||||
| -rw-r--r-- | drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c | 2 | ||||
| -rw-r--r-- | drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c | 20 | ||||
| -rw-r--r-- | drivers/net/ethernet/toshiba/ps3_gelic_net.c | 3 | ||||
| -rw-r--r-- | drivers/net/ethernet/toshiba/ps3_gelic_net.h | 1 | ||||
| -rw-r--r-- | drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c | 1 |
14 files changed, 84 insertions, 68 deletions
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c index f2d1ff10054b..0cc26110868d 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c | |||
| @@ -53,6 +53,7 @@ static inline void bnx2x_move_fp(struct bnx2x *bp, int from, int to) | |||
| 53 | struct bnx2x_fp_stats *to_fp_stats = &bp->fp_stats[to]; | 53 | struct bnx2x_fp_stats *to_fp_stats = &bp->fp_stats[to]; |
| 54 | int old_max_eth_txqs, new_max_eth_txqs; | 54 | int old_max_eth_txqs, new_max_eth_txqs; |
| 55 | int old_txdata_index = 0, new_txdata_index = 0; | 55 | int old_txdata_index = 0, new_txdata_index = 0; |
| 56 | struct bnx2x_agg_info *old_tpa_info = to_fp->tpa_info; | ||
| 56 | 57 | ||
| 57 | /* Copy the NAPI object as it has been already initialized */ | 58 | /* Copy the NAPI object as it has been already initialized */ |
| 58 | from_fp->napi = to_fp->napi; | 59 | from_fp->napi = to_fp->napi; |
| @@ -61,6 +62,11 @@ static inline void bnx2x_move_fp(struct bnx2x *bp, int from, int to) | |||
| 61 | memcpy(to_fp, from_fp, sizeof(*to_fp)); | 62 | memcpy(to_fp, from_fp, sizeof(*to_fp)); |
| 62 | to_fp->index = to; | 63 | to_fp->index = to; |
| 63 | 64 | ||
| 65 | /* Retain the tpa_info of the original `to' version as we don't want | ||
| 66 | * 2 FPs to contain the same tpa_info pointer. | ||
| 67 | */ | ||
| 68 | to_fp->tpa_info = old_tpa_info; | ||
| 69 | |||
| 64 | /* move sp_objs contents as well, as their indices match fp ones */ | 70 | /* move sp_objs contents as well, as their indices match fp ones */ |
| 65 | memcpy(to_sp_objs, from_sp_objs, sizeof(*to_sp_objs)); | 71 | memcpy(to_sp_objs, from_sp_objs, sizeof(*to_sp_objs)); |
| 66 | 72 | ||
| @@ -2956,8 +2962,9 @@ int bnx2x_nic_unload(struct bnx2x *bp, int unload_mode, bool keep_link) | |||
| 2956 | if (IS_PF(bp)) { | 2962 | if (IS_PF(bp)) { |
| 2957 | if (CNIC_LOADED(bp)) | 2963 | if (CNIC_LOADED(bp)) |
| 2958 | bnx2x_free_mem_cnic(bp); | 2964 | bnx2x_free_mem_cnic(bp); |
| 2959 | bnx2x_free_mem(bp); | ||
| 2960 | } | 2965 | } |
| 2966 | bnx2x_free_mem(bp); | ||
| 2967 | |||
| 2961 | bp->state = BNX2X_STATE_CLOSED; | 2968 | bp->state = BNX2X_STATE_CLOSED; |
| 2962 | bp->cnic_loaded = false; | 2969 | bp->cnic_loaded = false; |
| 2963 | 2970 | ||
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c index 8bdc8b973007..1627a4e09c32 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c | |||
| @@ -7855,12 +7855,15 @@ void bnx2x_free_mem(struct bnx2x *bp) | |||
| 7855 | { | 7855 | { |
| 7856 | int i; | 7856 | int i; |
| 7857 | 7857 | ||
| 7858 | BNX2X_PCI_FREE(bp->def_status_blk, bp->def_status_blk_mapping, | ||
| 7859 | sizeof(struct host_sp_status_block)); | ||
| 7860 | |||
| 7861 | BNX2X_PCI_FREE(bp->fw_stats, bp->fw_stats_mapping, | 7858 | BNX2X_PCI_FREE(bp->fw_stats, bp->fw_stats_mapping, |
| 7862 | bp->fw_stats_data_sz + bp->fw_stats_req_sz); | 7859 | bp->fw_stats_data_sz + bp->fw_stats_req_sz); |
| 7863 | 7860 | ||
| 7861 | if (IS_VF(bp)) | ||
| 7862 | return; | ||
| 7863 | |||
| 7864 | BNX2X_PCI_FREE(bp->def_status_blk, bp->def_status_blk_mapping, | ||
| 7865 | sizeof(struct host_sp_status_block)); | ||
| 7866 | |||
| 7864 | BNX2X_PCI_FREE(bp->slowpath, bp->slowpath_mapping, | 7867 | BNX2X_PCI_FREE(bp->slowpath, bp->slowpath_mapping, |
| 7865 | sizeof(struct bnx2x_slowpath)); | 7868 | sizeof(struct bnx2x_slowpath)); |
| 7866 | 7869 | ||
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_sriov.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_sriov.c index ad83f4b48777..e8706e19f96f 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_sriov.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_sriov.c | |||
| @@ -522,23 +522,6 @@ static int bnx2x_vfop_set_user_req(struct bnx2x *bp, | |||
| 522 | return 0; | 522 | return 0; |
| 523 | } | 523 | } |
| 524 | 524 | ||
| 525 | static int | ||
| 526 | bnx2x_vfop_config_vlan0(struct bnx2x *bp, | ||
| 527 | struct bnx2x_vlan_mac_ramrod_params *vlan_mac, | ||
| 528 | bool add) | ||
| 529 | { | ||
| 530 | int rc; | ||
| 531 | |||
| 532 | vlan_mac->user_req.cmd = add ? BNX2X_VLAN_MAC_ADD : | ||
| 533 | BNX2X_VLAN_MAC_DEL; | ||
| 534 | vlan_mac->user_req.u.vlan.vlan = 0; | ||
| 535 | |||
| 536 | rc = bnx2x_config_vlan_mac(bp, vlan_mac); | ||
| 537 | if (rc == -EEXIST) | ||
| 538 | rc = 0; | ||
| 539 | return rc; | ||
| 540 | } | ||
| 541 | |||
| 542 | static int bnx2x_vfop_config_list(struct bnx2x *bp, | 525 | static int bnx2x_vfop_config_list(struct bnx2x *bp, |
| 543 | struct bnx2x_vfop_filters *filters, | 526 | struct bnx2x_vfop_filters *filters, |
| 544 | struct bnx2x_vlan_mac_ramrod_params *vlan_mac) | 527 | struct bnx2x_vlan_mac_ramrod_params *vlan_mac) |
| @@ -643,30 +626,14 @@ static void bnx2x_vfop_vlan_mac(struct bnx2x *bp, struct bnx2x_virtf *vf) | |||
| 643 | 626 | ||
| 644 | case BNX2X_VFOP_VLAN_CONFIG_LIST: | 627 | case BNX2X_VFOP_VLAN_CONFIG_LIST: |
| 645 | /* next state */ | 628 | /* next state */ |
| 646 | vfop->state = BNX2X_VFOP_VLAN_CONFIG_LIST_0; | 629 | vfop->state = BNX2X_VFOP_VLAN_MAC_CHK_DONE; |
| 647 | |||
| 648 | /* remove vlan0 - could be no-op */ | ||
| 649 | vfop->rc = bnx2x_vfop_config_vlan0(bp, vlan_mac, false); | ||
| 650 | if (vfop->rc) | ||
| 651 | goto op_err; | ||
| 652 | 630 | ||
| 653 | /* Do vlan list config. if this operation fails we try to | 631 | /* do list config */ |
| 654 | * restore vlan0 to keep the queue is working order | ||
| 655 | */ | ||
| 656 | vfop->rc = bnx2x_vfop_config_list(bp, filters, vlan_mac); | 632 | vfop->rc = bnx2x_vfop_config_list(bp, filters, vlan_mac); |
| 657 | if (!vfop->rc) { | 633 | if (!vfop->rc) { |
| 658 | set_bit(RAMROD_CONT, &vlan_mac->ramrod_flags); | 634 | set_bit(RAMROD_CONT, &vlan_mac->ramrod_flags); |
| 659 | vfop->rc = bnx2x_config_vlan_mac(bp, vlan_mac); | 635 | vfop->rc = bnx2x_config_vlan_mac(bp, vlan_mac); |
| 660 | } | 636 | } |
| 661 | bnx2x_vfop_finalize(vf, vfop->rc, VFOP_CONT); /* fall-through */ | ||
| 662 | |||
| 663 | case BNX2X_VFOP_VLAN_CONFIG_LIST_0: | ||
| 664 | /* next state */ | ||
| 665 | vfop->state = BNX2X_VFOP_VLAN_MAC_CHK_DONE; | ||
| 666 | |||
| 667 | if (list_empty(&obj->head)) | ||
| 668 | /* add vlan0 */ | ||
| 669 | vfop->rc = bnx2x_vfop_config_vlan0(bp, vlan_mac, true); | ||
| 670 | bnx2x_vfop_finalize(vf, vfop->rc, VFOP_DONE); | 637 | bnx2x_vfop_finalize(vf, vfop->rc, VFOP_DONE); |
| 671 | 638 | ||
| 672 | default: | 639 | default: |
| @@ -2819,6 +2786,18 @@ int bnx2x_vf_init(struct bnx2x *bp, struct bnx2x_virtf *vf, dma_addr_t *sb_map) | |||
| 2819 | return 0; | 2786 | return 0; |
| 2820 | } | 2787 | } |
| 2821 | 2788 | ||
| 2789 | struct set_vf_state_cookie { | ||
| 2790 | struct bnx2x_virtf *vf; | ||
| 2791 | u8 state; | ||
| 2792 | }; | ||
| 2793 | |||
| 2794 | void bnx2x_set_vf_state(void *cookie) | ||
| 2795 | { | ||
| 2796 | struct set_vf_state_cookie *p = (struct set_vf_state_cookie *)cookie; | ||
| 2797 | |||
| 2798 | p->vf->state = p->state; | ||
| 2799 | } | ||
| 2800 | |||
| 2822 | /* VFOP close (teardown the queues, delete mcasts and close HW) */ | 2801 | /* VFOP close (teardown the queues, delete mcasts and close HW) */ |
| 2823 | static void bnx2x_vfop_close(struct bnx2x *bp, struct bnx2x_virtf *vf) | 2802 | static void bnx2x_vfop_close(struct bnx2x *bp, struct bnx2x_virtf *vf) |
| 2824 | { | 2803 | { |
| @@ -2869,7 +2848,19 @@ static void bnx2x_vfop_close(struct bnx2x *bp, struct bnx2x_virtf *vf) | |||
| 2869 | op_err: | 2848 | op_err: |
| 2870 | BNX2X_ERR("VF[%d] CLOSE error: rc %d\n", vf->abs_vfid, vfop->rc); | 2849 | BNX2X_ERR("VF[%d] CLOSE error: rc %d\n", vf->abs_vfid, vfop->rc); |
| 2871 | op_done: | 2850 | op_done: |
| 2872 | vf->state = VF_ACQUIRED; | 2851 | |
| 2852 | /* need to make sure there are no outstanding stats ramrods which may | ||
| 2853 | * cause the device to access the VF's stats buffer which it will free | ||
| 2854 | * as soon as we return from the close flow. | ||
| 2855 | */ | ||
| 2856 | { | ||
| 2857 | struct set_vf_state_cookie cookie; | ||
| 2858 | |||
| 2859 | cookie.vf = vf; | ||
| 2860 | cookie.state = VF_ACQUIRED; | ||
| 2861 | bnx2x_stats_safe_exec(bp, bnx2x_set_vf_state, &cookie); | ||
| 2862 | } | ||
| 2863 | |||
| 2873 | DP(BNX2X_MSG_IOV, "set state to acquired\n"); | 2864 | DP(BNX2X_MSG_IOV, "set state to acquired\n"); |
| 2874 | bnx2x_vfop_end(bp, vf, vfop); | 2865 | bnx2x_vfop_end(bp, vf, vfop); |
| 2875 | } | 2866 | } |
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.c index d63d1327b051..86436c77af03 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.c | |||
| @@ -522,20 +522,16 @@ static void bnx2x_func_stats_init(struct bnx2x *bp) | |||
| 522 | /* should be called under stats_sema */ | 522 | /* should be called under stats_sema */ |
| 523 | static void __bnx2x_stats_start(struct bnx2x *bp) | 523 | static void __bnx2x_stats_start(struct bnx2x *bp) |
| 524 | { | 524 | { |
| 525 | /* vfs travel through here as part of the statistics FSM, but no action | 525 | if (IS_PF(bp)) { |
| 526 | * is required | 526 | if (bp->port.pmf) |
| 527 | */ | 527 | bnx2x_port_stats_init(bp); |
| 528 | if (IS_VF(bp)) | ||
| 529 | return; | ||
| 530 | |||
| 531 | if (bp->port.pmf) | ||
| 532 | bnx2x_port_stats_init(bp); | ||
| 533 | 528 | ||
| 534 | else if (bp->func_stx) | 529 | else if (bp->func_stx) |
| 535 | bnx2x_func_stats_init(bp); | 530 | bnx2x_func_stats_init(bp); |
| 536 | 531 | ||
| 537 | bnx2x_hw_stats_post(bp); | 532 | bnx2x_hw_stats_post(bp); |
| 538 | bnx2x_storm_stats_post(bp); | 533 | bnx2x_storm_stats_post(bp); |
| 534 | } | ||
| 539 | 535 | ||
| 540 | bp->stats_started = true; | 536 | bp->stats_started = true; |
| 541 | } | 537 | } |
| @@ -1997,3 +1993,14 @@ void bnx2x_afex_collect_stats(struct bnx2x *bp, void *void_afex_stats, | |||
| 1997 | estats->mac_discard); | 1993 | estats->mac_discard); |
| 1998 | } | 1994 | } |
| 1999 | } | 1995 | } |
| 1996 | |||
| 1997 | void bnx2x_stats_safe_exec(struct bnx2x *bp, | ||
| 1998 | void (func_to_exec)(void *cookie), | ||
| 1999 | void *cookie){ | ||
| 2000 | if (down_timeout(&bp->stats_sema, HZ/10)) | ||
| 2001 | BNX2X_ERR("Unable to acquire stats lock\n"); | ||
| 2002 | bnx2x_stats_comp(bp); | ||
| 2003 | func_to_exec(cookie); | ||
| 2004 | __bnx2x_stats_start(bp); | ||
| 2005 | up(&bp->stats_sema); | ||
| 2006 | } | ||
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.h b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.h index 853824d258e8..f35845006cdd 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.h +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_stats.h | |||
| @@ -539,6 +539,9 @@ struct bnx2x; | |||
| 539 | void bnx2x_memset_stats(struct bnx2x *bp); | 539 | void bnx2x_memset_stats(struct bnx2x *bp); |
| 540 | void bnx2x_stats_init(struct bnx2x *bp); | 540 | void bnx2x_stats_init(struct bnx2x *bp); |
| 541 | void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event); | 541 | void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event); |
| 542 | void bnx2x_stats_safe_exec(struct bnx2x *bp, | ||
| 543 | void (func_to_exec)(void *cookie), | ||
| 544 | void *cookie); | ||
| 542 | 545 | ||
| 543 | /** | 546 | /** |
| 544 | * bnx2x_save_statistics - save statistics when unloading. | 547 | * bnx2x_save_statistics - save statistics when unloading. |
diff --git a/drivers/net/ethernet/emulex/benet/be_main.c b/drivers/net/ethernet/emulex/benet/be_main.c index 4559c35eea13..3d91a5ec61a4 100644 --- a/drivers/net/ethernet/emulex/benet/be_main.c +++ b/drivers/net/ethernet/emulex/benet/be_main.c | |||
| @@ -4373,6 +4373,10 @@ static int be_resume(struct pci_dev *pdev) | |||
| 4373 | pci_set_power_state(pdev, PCI_D0); | 4373 | pci_set_power_state(pdev, PCI_D0); |
| 4374 | pci_restore_state(pdev); | 4374 | pci_restore_state(pdev); |
| 4375 | 4375 | ||
| 4376 | status = be_fw_wait_ready(adapter); | ||
| 4377 | if (status) | ||
| 4378 | return status; | ||
| 4379 | |||
| 4376 | /* tell fw we're ready to fire cmds */ | 4380 | /* tell fw we're ready to fire cmds */ |
| 4377 | status = be_cmd_fw_init(adapter); | 4381 | status = be_cmd_fw_init(adapter); |
| 4378 | if (status) | 4382 | if (status) |
diff --git a/drivers/net/ethernet/freescale/fec_main.c b/drivers/net/ethernet/freescale/fec_main.c index 77ea0db0bbfc..c610a2716be4 100644 --- a/drivers/net/ethernet/freescale/fec_main.c +++ b/drivers/net/ethernet/freescale/fec_main.c | |||
| @@ -971,8 +971,7 @@ fec_enet_rx(struct net_device *ndev, int budget) | |||
| 971 | htons(ETH_P_8021Q), | 971 | htons(ETH_P_8021Q), |
| 972 | vlan_tag); | 972 | vlan_tag); |
| 973 | 973 | ||
| 974 | if (!skb_defer_rx_timestamp(skb)) | 974 | napi_gro_receive(&fep->napi, skb); |
| 975 | napi_gro_receive(&fep->napi, skb); | ||
| 976 | } | 975 | } |
| 977 | 976 | ||
| 978 | bdp->cbd_bufaddr = dma_map_single(&fep->pdev->dev, data, | 977 | bdp->cbd_bufaddr = dma_map_single(&fep->pdev->dev, data, |
diff --git a/drivers/net/ethernet/jme.c b/drivers/net/ethernet/jme.c index 7fbe6abf6054..23de82a9da82 100644 --- a/drivers/net/ethernet/jme.c +++ b/drivers/net/ethernet/jme.c | |||
| @@ -3069,7 +3069,7 @@ jme_init_one(struct pci_dev *pdev, | |||
| 3069 | jwrite32(jme, JME_APMC, apmc); | 3069 | jwrite32(jme, JME_APMC, apmc); |
| 3070 | } | 3070 | } |
| 3071 | 3071 | ||
| 3072 | NETIF_NAPI_SET(netdev, &jme->napi, jme_poll, jme->rx_ring_size >> 2) | 3072 | NETIF_NAPI_SET(netdev, &jme->napi, jme_poll, NAPI_POLL_WEIGHT) |
| 3073 | 3073 | ||
| 3074 | spin_lock_init(&jme->phy_lock); | 3074 | spin_lock_init(&jme->phy_lock); |
| 3075 | spin_lock_init(&jme->macaddr_lock); | 3075 | spin_lock_init(&jme->macaddr_lock); |
diff --git a/drivers/net/ethernet/qlogic/netxen/netxen_nic.h b/drivers/net/ethernet/qlogic/netxen/netxen_nic.h index 3fe09ab2d7c9..32675e16021e 100644 --- a/drivers/net/ethernet/qlogic/netxen/netxen_nic.h +++ b/drivers/net/ethernet/qlogic/netxen/netxen_nic.h | |||
| @@ -1171,7 +1171,6 @@ typedef struct { | |||
| 1171 | 1171 | ||
| 1172 | #define NETXEN_DB_MAPSIZE_BYTES 0x1000 | 1172 | #define NETXEN_DB_MAPSIZE_BYTES 0x1000 |
| 1173 | 1173 | ||
| 1174 | #define NETXEN_NETDEV_WEIGHT 128 | ||
| 1175 | #define NETXEN_ADAPTER_UP_MAGIC 777 | 1174 | #define NETXEN_ADAPTER_UP_MAGIC 777 |
| 1176 | #define NETXEN_NIC_PEG_TUNE 0 | 1175 | #define NETXEN_NIC_PEG_TUNE 0 |
| 1177 | 1176 | ||
diff --git a/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c b/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c index c401b0b4353d..ec4cf7fd4123 100644 --- a/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c +++ b/drivers/net/ethernet/qlogic/netxen/netxen_nic_main.c | |||
| @@ -197,7 +197,7 @@ netxen_napi_add(struct netxen_adapter *adapter, struct net_device *netdev) | |||
| 197 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { | 197 | for (ring = 0; ring < adapter->max_sds_rings; ring++) { |
| 198 | sds_ring = &recv_ctx->sds_rings[ring]; | 198 | sds_ring = &recv_ctx->sds_rings[ring]; |
| 199 | netif_napi_add(netdev, &sds_ring->napi, | 199 | netif_napi_add(netdev, &sds_ring->napi, |
| 200 | netxen_nic_poll, NETXEN_NETDEV_WEIGHT); | 200 | netxen_nic_poll, NAPI_POLL_WEIGHT); |
| 201 | } | 201 | } |
| 202 | 202 | ||
| 203 | return 0; | 203 | return 0; |
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c index 03de76c7a177..1c83a44c547b 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_platform.c | |||
| @@ -71,14 +71,18 @@ static int stmmac_probe_config_dt(struct platform_device *pdev, | |||
| 71 | plat->force_sf_dma_mode = 1; | 71 | plat->force_sf_dma_mode = 1; |
| 72 | } | 72 | } |
| 73 | 73 | ||
| 74 | dma_cfg = devm_kzalloc(&pdev->dev, sizeof(*dma_cfg), GFP_KERNEL); | 74 | if (of_find_property(np, "snps,pbl", NULL)) { |
| 75 | if (!dma_cfg) | 75 | dma_cfg = devm_kzalloc(&pdev->dev, sizeof(*dma_cfg), |
| 76 | return -ENOMEM; | 76 | GFP_KERNEL); |
| 77 | 77 | if (!dma_cfg) | |
| 78 | plat->dma_cfg = dma_cfg; | 78 | return -ENOMEM; |
| 79 | of_property_read_u32(np, "snps,pbl", &dma_cfg->pbl); | 79 | plat->dma_cfg = dma_cfg; |
| 80 | dma_cfg->fixed_burst = of_property_read_bool(np, "snps,fixed-burst"); | 80 | of_property_read_u32(np, "snps,pbl", &dma_cfg->pbl); |
| 81 | dma_cfg->mixed_burst = of_property_read_bool(np, "snps,mixed-burst"); | 81 | dma_cfg->fixed_burst = |
| 82 | of_property_read_bool(np, "snps,fixed-burst"); | ||
| 83 | dma_cfg->mixed_burst = | ||
| 84 | of_property_read_bool(np, "snps,mixed-burst"); | ||
| 85 | } | ||
| 82 | 86 | ||
| 83 | return 0; | 87 | return 0; |
| 84 | } | 88 | } |
diff --git a/drivers/net/ethernet/toshiba/ps3_gelic_net.c b/drivers/net/ethernet/toshiba/ps3_gelic_net.c index ad32af67e618..9c805e0c0cae 100644 --- a/drivers/net/ethernet/toshiba/ps3_gelic_net.c +++ b/drivers/net/ethernet/toshiba/ps3_gelic_net.c | |||
| @@ -1466,8 +1466,7 @@ static void gelic_ether_setup_netdev_ops(struct net_device *netdev, | |||
| 1466 | { | 1466 | { |
| 1467 | netdev->watchdog_timeo = GELIC_NET_WATCHDOG_TIMEOUT; | 1467 | netdev->watchdog_timeo = GELIC_NET_WATCHDOG_TIMEOUT; |
| 1468 | /* NAPI */ | 1468 | /* NAPI */ |
| 1469 | netif_napi_add(netdev, napi, | 1469 | netif_napi_add(netdev, napi, gelic_net_poll, NAPI_POLL_WEIGHT); |
| 1470 | gelic_net_poll, GELIC_NET_NAPI_WEIGHT); | ||
| 1471 | netdev->ethtool_ops = &gelic_ether_ethtool_ops; | 1470 | netdev->ethtool_ops = &gelic_ether_ethtool_ops; |
| 1472 | netdev->netdev_ops = &gelic_netdevice_ops; | 1471 | netdev->netdev_ops = &gelic_netdevice_ops; |
| 1473 | } | 1472 | } |
diff --git a/drivers/net/ethernet/toshiba/ps3_gelic_net.h b/drivers/net/ethernet/toshiba/ps3_gelic_net.h index a93df6ac1909..309abb472aa2 100644 --- a/drivers/net/ethernet/toshiba/ps3_gelic_net.h +++ b/drivers/net/ethernet/toshiba/ps3_gelic_net.h | |||
| @@ -37,7 +37,6 @@ | |||
| 37 | #define GELIC_NET_RXBUF_ALIGN 128 | 37 | #define GELIC_NET_RXBUF_ALIGN 128 |
| 38 | #define GELIC_CARD_RX_CSUM_DEFAULT 1 /* hw chksum */ | 38 | #define GELIC_CARD_RX_CSUM_DEFAULT 1 /* hw chksum */ |
| 39 | #define GELIC_NET_WATCHDOG_TIMEOUT 5*HZ | 39 | #define GELIC_NET_WATCHDOG_TIMEOUT 5*HZ |
| 40 | #define GELIC_NET_NAPI_WEIGHT (GELIC_NET_RX_DESCRIPTORS) | ||
| 41 | #define GELIC_NET_BROADCAST_ADDR 0xffffffffffffL | 40 | #define GELIC_NET_BROADCAST_ADDR 0xffffffffffffL |
| 42 | 41 | ||
| 43 | #define GELIC_NET_MC_COUNT_MAX 32 /* multicast address list */ | 42 | #define GELIC_NET_MC_COUNT_MAX 32 /* multicast address list */ |
diff --git a/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c b/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c index e90e1f46121e..64b4639f43b6 100644 --- a/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c +++ b/drivers/net/ethernet/xilinx/xilinx_axienet_mdio.c | |||
| @@ -175,6 +175,7 @@ int axienet_mdio_setup(struct axienet_local *lp, struct device_node *np) | |||
| 175 | printk(KERN_WARNING "Setting MDIO clock divisor to " | 175 | printk(KERN_WARNING "Setting MDIO clock divisor to " |
| 176 | "default %d\n", DEFAULT_CLOCK_DIVISOR); | 176 | "default %d\n", DEFAULT_CLOCK_DIVISOR); |
| 177 | clk_div = DEFAULT_CLOCK_DIVISOR; | 177 | clk_div = DEFAULT_CLOCK_DIVISOR; |
| 178 | of_node_put(np1); | ||
| 178 | goto issue; | 179 | goto issue; |
| 179 | } | 180 | } |
| 180 | 181 | ||
