diff options
Diffstat (limited to 'drivers/net/ethernet/freescale/gianfar.c')
| -rw-r--r-- | drivers/net/ethernet/freescale/gianfar.c | 17 | 
1 files changed, 5 insertions, 12 deletions
| diff --git a/drivers/net/ethernet/freescale/gianfar.c b/drivers/net/ethernet/freescale/gianfar.c index f27f9bae1a4a..3c8da1a18ba0 100644 --- a/drivers/net/ethernet/freescale/gianfar.c +++ b/drivers/net/ethernet/freescale/gianfar.c @@ -102,8 +102,6 @@  #include <linux/phy_fixed.h>  #include <linux/of.h>  #include <linux/of_net.h> -#include <linux/of_address.h> -#include <linux/of_irq.h>  #include "gianfar.h" @@ -112,7 +110,7 @@  const char gfar_driver_version[] = "2.0";  static int gfar_enet_open(struct net_device *dev); -static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev); +static netdev_tx_t gfar_start_xmit(struct sk_buff *skb, struct net_device *dev);  static void gfar_reset_task(struct work_struct *work);  static void gfar_timeout(struct net_device *dev);  static int gfar_close(struct net_device *dev); @@ -1814,8 +1812,8 @@ static int init_phy(struct net_device *dev)  	phydev->supported &= (GFAR_SUPPORTED | gigabit_support);  	phydev->advertising = phydev->supported; -	/* Add support for flow control, but don't advertise it by default */ -	phydev->supported |= (SUPPORTED_Pause | SUPPORTED_Asym_Pause); +	/* Add support for flow control */ +	phy_support_asym_pause(phydev);  	/* disable EEE autoneg, EEE not supported by eTSEC */  	memset(&edata, 0, sizeof(struct ethtool_eee)); @@ -2334,7 +2332,7 @@ static inline bool gfar_csum_errata_76(struct gfar_private *priv,  /* This is called by the kernel when a frame is ready for transmission.   * It is pointed to by the dev->hard_start_xmit function pointer   */ -static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev) +static netdev_tx_t gfar_start_xmit(struct sk_buff *skb, struct net_device *dev)  {  	struct gfar_private *priv = netdev_priv(dev);  	struct gfar_priv_tx_q *tx_queue = NULL; @@ -3658,12 +3656,7 @@ static u32 gfar_get_flowctrl_cfg(struct gfar_private *priv)  		if (phydev->asym_pause)  			rmt_adv |= LPA_PAUSE_ASYM; -		lcl_adv = 0; -		if (phydev->advertising & ADVERTISED_Pause) -			lcl_adv |= ADVERTISE_PAUSE_CAP; -		if (phydev->advertising & ADVERTISED_Asym_Pause) -			lcl_adv |= ADVERTISE_PAUSE_ASYM; - +		lcl_adv = ethtool_adv_to_lcl_adv_t(phydev->advertising);  		flowctrl = mii_resolve_flowctrl_fdx(lcl_adv, rmt_adv);  		if (flowctrl & FLOW_CTRL_TX)  			val |= MACCFG1_TX_FLOW; | 
