mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-04 04:02:26 +00:00
net: lpc-enet: factor out iram access
The lpc_eth driver uses a platform specific method to find the internal sram. This prevents building it on other machines. Rework to only use one function call and keep the other platform internals where they belong. Ideally this would look up the sram location from DT, but as this is a rarely used driver, I want to keep the modifications to a minimum. Link: https://lore.kernel.org/r/20190809144043.476786-7-arnd@arndb.de Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
d88ce24a0f
commit
9dc03ffd99
@ -8,6 +8,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
|
#include <linux/soc/nxp/lpc32xx-misc.h>
|
||||||
|
|
||||||
#include <asm/mach/map.h>
|
#include <asm/mach/map.h>
|
||||||
#include <asm/system_info.h>
|
#include <asm/system_info.h>
|
||||||
@ -32,7 +33,7 @@ void lpc32xx_get_uid(u32 devid[4])
|
|||||||
*/
|
*/
|
||||||
#define LPC32XX_IRAM_BANK_SIZE SZ_128K
|
#define LPC32XX_IRAM_BANK_SIZE SZ_128K
|
||||||
static u32 iram_size;
|
static u32 iram_size;
|
||||||
u32 lpc32xx_return_iram_size(void)
|
u32 lpc32xx_return_iram(void __iomem **mapbase, dma_addr_t *dmaaddr)
|
||||||
{
|
{
|
||||||
if (iram_size == 0) {
|
if (iram_size == 0) {
|
||||||
u32 savedval1, savedval2;
|
u32 savedval1, savedval2;
|
||||||
@ -53,10 +54,14 @@ u32 lpc32xx_return_iram_size(void)
|
|||||||
} else
|
} else
|
||||||
iram_size = LPC32XX_IRAM_BANK_SIZE * 2;
|
iram_size = LPC32XX_IRAM_BANK_SIZE * 2;
|
||||||
}
|
}
|
||||||
|
if (dmaaddr)
|
||||||
|
*dmaaddr = LPC32XX_IRAM_BASE;
|
||||||
|
if (mapbase)
|
||||||
|
*mapbase = io_p2v(LPC32XX_IRAM_BASE);
|
||||||
|
|
||||||
return iram_size;
|
return iram_size;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(lpc32xx_return_iram_size);
|
EXPORT_SYMBOL_GPL(lpc32xx_return_iram);
|
||||||
|
|
||||||
static struct map_desc lpc32xx_io_desc[] __initdata = {
|
static struct map_desc lpc32xx_io_desc[] __initdata = {
|
||||||
{
|
{
|
||||||
|
@ -23,7 +23,6 @@ extern void __init lpc32xx_serial_init(void);
|
|||||||
*/
|
*/
|
||||||
extern void lpc32xx_get_uid(u32 devid[4]);
|
extern void lpc32xx_get_uid(u32 devid[4]);
|
||||||
|
|
||||||
extern u32 lpc32xx_return_iram_size(void);
|
|
||||||
/*
|
/*
|
||||||
* Pointers used for sizing and copying suspend function data
|
* Pointers used for sizing and copying suspend function data
|
||||||
*/
|
*/
|
||||||
|
@ -1,15 +0,0 @@
|
|||||||
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
||||||
/*
|
|
||||||
* arm/arch/mach-lpc32xx/include/mach/board.h
|
|
||||||
*
|
|
||||||
* Author: Kevin Wells <kevin.wells@nxp.com>
|
|
||||||
*
|
|
||||||
* Copyright (C) 2010 NXP Semiconductors
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __ASM_ARCH_BOARD_H
|
|
||||||
#define __ASM_ARCH_BOARD_H
|
|
||||||
|
|
||||||
extern u32 lpc32xx_return_iram_size(void);
|
|
||||||
|
|
||||||
#endif /* __ASM_ARCH_BOARD_H */
|
|
@ -18,8 +18,8 @@
|
|||||||
#include <linux/phy.h>
|
#include <linux/phy.h>
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
#include <linux/spinlock.h>
|
#include <linux/spinlock.h>
|
||||||
|
#include <linux/soc/nxp/lpc32xx-misc.h>
|
||||||
|
|
||||||
#include <mach/board.h>
|
|
||||||
#include <mach/hardware.h>
|
#include <mach/hardware.h>
|
||||||
#include <mach/platform.h>
|
#include <mach/platform.h>
|
||||||
|
|
||||||
@ -1311,17 +1311,16 @@ static int lpc_eth_drv_probe(struct platform_device *pdev)
|
|||||||
/* Get size of DMA buffers/descriptors region */
|
/* Get size of DMA buffers/descriptors region */
|
||||||
pldat->dma_buff_size = (ENET_TX_DESC + ENET_RX_DESC) * (ENET_MAXF_SIZE +
|
pldat->dma_buff_size = (ENET_TX_DESC + ENET_RX_DESC) * (ENET_MAXF_SIZE +
|
||||||
sizeof(struct txrx_desc_t) + sizeof(struct rx_status_t));
|
sizeof(struct txrx_desc_t) + sizeof(struct rx_status_t));
|
||||||
pldat->dma_buff_base_v = 0;
|
|
||||||
|
|
||||||
if (use_iram_for_net(dev)) {
|
if (use_iram_for_net(dev)) {
|
||||||
dma_handle = LPC32XX_IRAM_BASE;
|
if (pldat->dma_buff_size >
|
||||||
if (pldat->dma_buff_size <= lpc32xx_return_iram_size())
|
lpc32xx_return_iram(&pldat->dma_buff_base_v, &dma_handle)) {
|
||||||
pldat->dma_buff_base_v =
|
pldat->dma_buff_base_v = NULL;
|
||||||
io_p2v(LPC32XX_IRAM_BASE);
|
pldat->dma_buff_size = 0;
|
||||||
else
|
|
||||||
netdev_err(ndev,
|
netdev_err(ndev,
|
||||||
"IRAM not big enough for net buffers, using SDRAM instead.\n");
|
"IRAM not big enough for net buffers, using SDRAM instead.\n");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (pldat->dma_buff_base_v == 0) {
|
if (pldat->dma_buff_base_v == 0) {
|
||||||
ret = dma_coerce_mask_and_coherent(dev, DMA_BIT_MASK(32));
|
ret = dma_coerce_mask_and_coherent(dev, DMA_BIT_MASK(32));
|
||||||
@ -1409,7 +1408,7 @@ static int lpc_eth_drv_probe(struct platform_device *pdev)
|
|||||||
unregister_netdev(ndev);
|
unregister_netdev(ndev);
|
||||||
err_out_dma_unmap:
|
err_out_dma_unmap:
|
||||||
if (!use_iram_for_net(dev) ||
|
if (!use_iram_for_net(dev) ||
|
||||||
pldat->dma_buff_size > lpc32xx_return_iram_size())
|
pldat->dma_buff_size > lpc32xx_return_iram(NULL, NULL))
|
||||||
dma_free_coherent(dev, pldat->dma_buff_size,
|
dma_free_coherent(dev, pldat->dma_buff_size,
|
||||||
pldat->dma_buff_base_v,
|
pldat->dma_buff_base_v,
|
||||||
pldat->dma_buff_base_p);
|
pldat->dma_buff_base_p);
|
||||||
@ -1436,7 +1435,7 @@ static int lpc_eth_drv_remove(struct platform_device *pdev)
|
|||||||
unregister_netdev(ndev);
|
unregister_netdev(ndev);
|
||||||
|
|
||||||
if (!use_iram_for_net(&pldat->pdev->dev) ||
|
if (!use_iram_for_net(&pldat->pdev->dev) ||
|
||||||
pldat->dma_buff_size > lpc32xx_return_iram_size())
|
pldat->dma_buff_size > lpc32xx_return_iram(NULL, NULL))
|
||||||
dma_free_coherent(&pldat->pdev->dev, pldat->dma_buff_size,
|
dma_free_coherent(&pldat->pdev->dev, pldat->dma_buff_size,
|
||||||
pldat->dma_buff_base_v,
|
pldat->dma_buff_base_v,
|
||||||
pldat->dma_buff_base_p);
|
pldat->dma_buff_base_p);
|
||||||
|
24
include/linux/soc/nxp/lpc32xx-misc.h
Normal file
24
include/linux/soc/nxp/lpc32xx-misc.h
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Author: Kevin Wells <kevin.wells@nxp.com>
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010 NXP Semiconductors
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __SOC_LPC32XX_MISC_H
|
||||||
|
#define __SOC_LPC32XX_MISC_H
|
||||||
|
|
||||||
|
#include <linux/types.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_LPC32XX
|
||||||
|
extern u32 lpc32xx_return_iram(void __iomem **mapbase, dma_addr_t *dmaaddr);
|
||||||
|
#else
|
||||||
|
static inline u32 lpc32xx_return_iram(void __iomem **mapbase, dma_addr_t *dmaaddr)
|
||||||
|
{
|
||||||
|
*mapbase = NULL;
|
||||||
|
*dmaaddr = 0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __SOC_LPC32XX_MISC_H */
|
Loading…
Reference in New Issue
Block a user