mirror of https://gitee.com/openkylin/linux.git
net: dwc-xlgmac: fix an error code in xlgmac_alloc_pages()
The dma_mapping_error() returns true if there is an error but we want
to return -ENOMEM and not 1.
Fixes: 65e0ace2c5
("net: dwc-xlgmac: Initial driver for DesignWare Enterprise Ethernet")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: Jie Deng <jiedeng@synopsys.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a7678c70ef
commit
31c7ba9eff
|
@ -335,7 +335,6 @@ static int xlgmac_alloc_pages(struct xlgmac_pdata *pdata,
|
||||||
{
|
{
|
||||||
struct page *pages = NULL;
|
struct page *pages = NULL;
|
||||||
dma_addr_t pages_dma;
|
dma_addr_t pages_dma;
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Try to obtain pages, decreasing order if necessary */
|
/* Try to obtain pages, decreasing order if necessary */
|
||||||
gfp |= __GFP_COLD | __GFP_COMP | __GFP_NOWARN;
|
gfp |= __GFP_COLD | __GFP_COMP | __GFP_NOWARN;
|
||||||
|
@ -352,10 +351,9 @@ static int xlgmac_alloc_pages(struct xlgmac_pdata *pdata,
|
||||||
/* Map the pages */
|
/* Map the pages */
|
||||||
pages_dma = dma_map_page(pdata->dev, pages, 0,
|
pages_dma = dma_map_page(pdata->dev, pages, 0,
|
||||||
PAGE_SIZE << order, DMA_FROM_DEVICE);
|
PAGE_SIZE << order, DMA_FROM_DEVICE);
|
||||||
ret = dma_mapping_error(pdata->dev, pages_dma);
|
if (dma_mapping_error(pdata->dev, pages_dma)) {
|
||||||
if (ret) {
|
|
||||||
put_page(pages);
|
put_page(pages);
|
||||||
return ret;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
pa->pages = pages;
|
pa->pages = pages;
|
||||||
|
|
Loading…
Reference in New Issue