Commit df262dbd authored by Wang Dongsheng's avatar Wang Dongsheng Committed by David S. Miller

net: qcom/emac: extend DMA mask to 46bits

Bit TPD3[31] is used as a timestamp bit if PTP is enabled, but
it's used as an address bit if PTP is disabled.  Since PTP isn't
supported by the driver, we can extend the DMA address to 46 bits.
Signed-off-by: default avatarWang Dongsheng <dongsheng.wang@hxt-semitech.com>
Acked-by: default avatarTimur Tabi <timur@codeaurora.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 5c38bd1b
...@@ -114,8 +114,9 @@ struct emac_tpd { ...@@ -114,8 +114,9 @@ struct emac_tpd {
#define TPD_INSTC_SET(tpd, val) BITS_SET((tpd)->word[3], 17, 17, val) #define TPD_INSTC_SET(tpd, val) BITS_SET((tpd)->word[3], 17, 17, val)
/* High-14bit Buffer Address, So, the 64b-bit address is /* High-14bit Buffer Address, So, the 64b-bit address is
* {DESC_CTRL_11_TX_DATA_HIADDR[17:0],(register) BUFFER_ADDR_H, BUFFER_ADDR_L} * {DESC_CTRL_11_TX_DATA_HIADDR[17:0],(register) BUFFER_ADDR_H, BUFFER_ADDR_L}
* Extend TPD_BUFFER_ADDR_H to [31, 18], because we never enable timestamping.
*/ */
#define TPD_BUFFER_ADDR_H_SET(tpd, val) BITS_SET((tpd)->word[3], 18, 30, val) #define TPD_BUFFER_ADDR_H_SET(tpd, val) BITS_SET((tpd)->word[3], 18, 31, val)
/* Format D. Word offset from the 1st byte of this packet to start to calculate /* Format D. Word offset from the 1st byte of this packet to start to calculate
* the custom checksum. * the custom checksum.
*/ */
......
...@@ -615,8 +615,11 @@ static int emac_probe(struct platform_device *pdev) ...@@ -615,8 +615,11 @@ static int emac_probe(struct platform_device *pdev)
u32 reg; u32 reg;
int ret; int ret;
/* The TPD buffer address is limited to 45 bits. */ /* The TPD buffer address is limited to:
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(45)); * 1. PTP: 45bits. (Driver doesn't support yet.)
* 2. NON-PTP: 46bits.
*/
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(46));
if (ret) { if (ret) {
dev_err(&pdev->dev, "could not set DMA mask\n"); dev_err(&pdev->dev, "could not set DMA mask\n");
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment