diff options
Diffstat (limited to 'drivers/net/ethernet/stmicro')
6 files changed, 12 insertions, 8 deletions
| diff --git a/drivers/net/ethernet/stmicro/stmmac/common.h b/drivers/net/ethernet/stmicro/stmmac/common.h index e1e5ac053760..ce2ea2d491ac 100644 --- a/drivers/net/ethernet/stmicro/stmmac/common.h +++ b/drivers/net/ethernet/stmicro/stmmac/common.h @@ -409,7 +409,7 @@ struct stmmac_desc_ops {  	/* get timestamp value */  	 u64(*get_timestamp) (void *desc, u32 ats);  	/* get rx timestamp status */ -	int (*get_rx_timestamp_status) (void *desc, u32 ats); +	int (*get_rx_timestamp_status)(void *desc, void *next_desc, u32 ats);  	/* Display ring */  	void (*display_ring)(void *head, unsigned int size, bool rx);  	/* set MSS via context descriptor */ diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac4_descs.c b/drivers/net/ethernet/stmicro/stmmac/dwmac4_descs.c index 4b286e27c4ca..7e089bf906b4 100644 --- a/drivers/net/ethernet/stmicro/stmmac/dwmac4_descs.c +++ b/drivers/net/ethernet/stmicro/stmmac/dwmac4_descs.c @@ -258,7 +258,8 @@ static int dwmac4_rx_check_timestamp(void *desc)  	return ret;  } -static int dwmac4_wrback_get_rx_timestamp_status(void *desc, u32 ats) +static int dwmac4_wrback_get_rx_timestamp_status(void *desc, void *next_desc, +						 u32 ats)  {  	struct dma_desc *p = (struct dma_desc *)desc;  	int ret = -EINVAL; @@ -270,7 +271,7 @@ static int dwmac4_wrback_get_rx_timestamp_status(void *desc, u32 ats)  			/* Check if timestamp is OK from context descriptor */  			do { -				ret = dwmac4_rx_check_timestamp(desc); +				ret = dwmac4_rx_check_timestamp(next_desc);  				if (ret < 0)  					goto exit;  				i++; diff --git a/drivers/net/ethernet/stmicro/stmmac/enh_desc.c b/drivers/net/ethernet/stmicro/stmmac/enh_desc.c index 7546b3664113..2a828a312814 100644 --- a/drivers/net/ethernet/stmicro/stmmac/enh_desc.c +++ b/drivers/net/ethernet/stmicro/stmmac/enh_desc.c @@ -400,7 +400,8 @@ static u64 enh_desc_get_timestamp(void *desc, u32 ats)  	return ns;  } -static int enh_desc_get_rx_timestamp_status(void *desc, u32 ats) +static int enh_desc_get_rx_timestamp_status(void *desc, void *next_desc, +					    u32 ats)  {  	if (ats) {  		struct dma_extended_desc *p = (struct dma_extended_desc *)desc; diff --git a/drivers/net/ethernet/stmicro/stmmac/norm_desc.c b/drivers/net/ethernet/stmicro/stmmac/norm_desc.c index f817f8f36569..db4cee57bb24 100644 --- a/drivers/net/ethernet/stmicro/stmmac/norm_desc.c +++ b/drivers/net/ethernet/stmicro/stmmac/norm_desc.c @@ -265,7 +265,7 @@ static u64 ndesc_get_timestamp(void *desc, u32 ats)  	return ns;  } -static int ndesc_get_rx_timestamp_status(void *desc, u32 ats) +static int ndesc_get_rx_timestamp_status(void *desc, void *next_desc, u32 ats)  {  	struct dma_desc *p = (struct dma_desc *)desc; diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_hwtstamp.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_hwtstamp.c index 721b61655261..08c19ebd5306 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_hwtstamp.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_hwtstamp.c @@ -34,6 +34,7 @@ static u32 stmmac_config_sub_second_increment(void __iomem *ioaddr,  {  	u32 value = readl(ioaddr + PTP_TCR);  	unsigned long data; +	u32 reg_value;  	/* For GMAC3.x, 4.x versions, convert the ptp_clock to nano second  	 *	formula = (1/ptp_clock) * 1000000000 @@ -50,10 +51,11 @@ static u32 stmmac_config_sub_second_increment(void __iomem *ioaddr,  	data &= PTP_SSIR_SSINC_MASK; +	reg_value = data;  	if (gmac4) -		data = data << GMAC4_PTP_SSIR_SSINC_SHIFT; +		reg_value <<= GMAC4_PTP_SSIR_SSINC_SHIFT; -	writel(data, ioaddr + PTP_SSIR); +	writel(reg_value, ioaddr + PTP_SSIR);  	return data;  } diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index c52a9963c19d..0323d672e1c5 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c @@ -482,7 +482,7 @@ static void stmmac_get_rx_hwtstamp(struct stmmac_priv *priv, struct dma_desc *p,  		desc = np;  	/* Check if timestamp is available */ -	if (priv->hw->desc->get_rx_timestamp_status(desc, priv->adv_ts)) { +	if (priv->hw->desc->get_rx_timestamp_status(p, np, priv->adv_ts)) {  		ns = priv->hw->desc->get_timestamp(desc, priv->adv_ts);  		netdev_dbg(priv->dev, "get valid RX hw timestamp %llu\n", ns);  		shhwtstamp = skb_hwtstamps(skb); | 

