提交 ada66b54 编写于 作者: A Andrew Jeffery 提交者: David S. Miller

net/faraday: Separate rx page storage from rxdesc

The ftgmac100 hardware revision in e.g. the Aspeed AST2500 no longer
reserves all bits in RXDES#2 but instead uses the bottom 16 bits to
store MAC frame metadata. Avoid corruption by shifting struct page
pointers out to their own member in struct ftgmac100.
Signed-off-by: NAndrew Jeffery <andrew@aj.id.au>
Signed-off-by: NJoel Stanley <joel@jms.id.au>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 524605e5
...@@ -60,6 +60,8 @@ struct ftgmac100 { ...@@ -60,6 +60,8 @@ struct ftgmac100 {
struct ftgmac100_descs *descs; struct ftgmac100_descs *descs;
dma_addr_t descs_dma_addr; dma_addr_t descs_dma_addr;
struct page *rx_pages[RX_QUEUE_ENTRIES];
unsigned int rx_pointer; unsigned int rx_pointer;
unsigned int tx_clean_pointer; unsigned int tx_clean_pointer;
unsigned int tx_pointer; unsigned int tx_pointer;
...@@ -341,18 +343,27 @@ static bool ftgmac100_rxdes_ipcs_err(struct ftgmac100_rxdes *rxdes) ...@@ -341,18 +343,27 @@ static bool ftgmac100_rxdes_ipcs_err(struct ftgmac100_rxdes *rxdes)
return rxdes->rxdes1 & cpu_to_le32(FTGMAC100_RXDES1_IP_CHKSUM_ERR); return rxdes->rxdes1 & cpu_to_le32(FTGMAC100_RXDES1_IP_CHKSUM_ERR);
} }
static inline struct page **ftgmac100_rxdes_page_slot(struct ftgmac100 *priv,
struct ftgmac100_rxdes *rxdes)
{
return &priv->rx_pages[rxdes - priv->descs->rxdes];
}
/* /*
* rxdes2 is not used by hardware. We use it to keep track of page. * rxdes2 is not used by hardware. We use it to keep track of page.
* Since hardware does not touch it, we can skip cpu_to_le32()/le32_to_cpu(). * Since hardware does not touch it, we can skip cpu_to_le32()/le32_to_cpu().
*/ */
static void ftgmac100_rxdes_set_page(struct ftgmac100_rxdes *rxdes, struct page *page) static void ftgmac100_rxdes_set_page(struct ftgmac100 *priv,
struct ftgmac100_rxdes *rxdes,
struct page *page)
{ {
rxdes->rxdes2 = (unsigned int)page; *ftgmac100_rxdes_page_slot(priv, rxdes) = page;
} }
static struct page *ftgmac100_rxdes_get_page(struct ftgmac100_rxdes *rxdes) static struct page *ftgmac100_rxdes_get_page(struct ftgmac100 *priv,
struct ftgmac100_rxdes *rxdes)
{ {
return (struct page *)rxdes->rxdes2; return *ftgmac100_rxdes_page_slot(priv, rxdes);
} }
/****************************************************************************** /******************************************************************************
...@@ -501,7 +512,7 @@ static bool ftgmac100_rx_packet(struct ftgmac100 *priv, int *processed) ...@@ -501,7 +512,7 @@ static bool ftgmac100_rx_packet(struct ftgmac100 *priv, int *processed)
do { do {
dma_addr_t map = ftgmac100_rxdes_get_dma_addr(rxdes); dma_addr_t map = ftgmac100_rxdes_get_dma_addr(rxdes);
struct page *page = ftgmac100_rxdes_get_page(rxdes); struct page *page = ftgmac100_rxdes_get_page(priv, rxdes);
unsigned int size; unsigned int size;
dma_unmap_page(priv->dev, map, RX_BUF_SIZE, DMA_FROM_DEVICE); dma_unmap_page(priv->dev, map, RX_BUF_SIZE, DMA_FROM_DEVICE);
...@@ -779,7 +790,7 @@ static int ftgmac100_alloc_rx_page(struct ftgmac100 *priv, ...@@ -779,7 +790,7 @@ static int ftgmac100_alloc_rx_page(struct ftgmac100 *priv,
return -ENOMEM; return -ENOMEM;
} }
ftgmac100_rxdes_set_page(rxdes, page); ftgmac100_rxdes_set_page(priv, rxdes, page);
ftgmac100_rxdes_set_dma_addr(rxdes, map); ftgmac100_rxdes_set_dma_addr(rxdes, map);
ftgmac100_rxdes_set_dma_own(rxdes); ftgmac100_rxdes_set_dma_own(rxdes);
return 0; return 0;
...@@ -791,7 +802,7 @@ static void ftgmac100_free_buffers(struct ftgmac100 *priv) ...@@ -791,7 +802,7 @@ static void ftgmac100_free_buffers(struct ftgmac100 *priv)
for (i = 0; i < RX_QUEUE_ENTRIES; i++) { for (i = 0; i < RX_QUEUE_ENTRIES; i++) {
struct ftgmac100_rxdes *rxdes = &priv->descs->rxdes[i]; struct ftgmac100_rxdes *rxdes = &priv->descs->rxdes[i];
struct page *page = ftgmac100_rxdes_get_page(rxdes); struct page *page = ftgmac100_rxdes_get_page(priv, rxdes);
dma_addr_t map = ftgmac100_rxdes_get_dma_addr(rxdes); dma_addr_t map = ftgmac100_rxdes_get_dma_addr(rxdes);
if (!page) if (!page)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册