[U-Boot] [PATCH] net: macb: fix mapping of registers
Daniel Schwierzeck
daniel.schwierzeck at gmail.com
Mon Dec 17 12:08:51 UTC 2018
Am 17.12.18 um 02:01 schrieb Ramon Fried:
> Some architectures (MIPS) needs mapping to access IOMEM.
> Fix that.
>
> Fixes: f1dcc19b213d ("net: macb: Convert to driver model")
>
> Signed-off-by: Ramon Fried <ramon.fried at gmail.com>
> ---
>
> drivers/net/macb.c | 12 +++++++++++-
> 1 file changed, 11 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/net/macb.c b/drivers/net/macb.c
> index 94c89c762b..6e1b479813 100644
> --- a/drivers/net/macb.c
> +++ b/drivers/net/macb.c
> @@ -36,6 +36,7 @@
> #include <miiphy.h>
>
> #include <linux/mii.h>
> +#include <linux/io.h>
> #include <asm/io.h>
> #include <asm/dma-mapping.h>
> #include <asm/arch/clk.h>
> @@ -1149,9 +1150,18 @@ int __weak macb_late_eth_ofdata_to_platdata(struct udevice *dev)
>
> static int macb_eth_ofdata_to_platdata(struct udevice *dev)
> {
> + fdt_addr_t addr;
> + fdt_size_t size;
> + int node = dev_of_offset(dev);
> struct eth_pdata *pdata = dev_get_platdata(dev);
>
> - pdata->iobase = devfdt_get_addr(dev);
> + addr = fdtdec_get_addr_size(gd->fdt_blob, node, "reg", &size);
> + if (addr == FDT_ADDR_T_NONE)
> + return -EINVAL;
> +
> + pdata->iobase = (phys_addr_t)ioremap(addr, size);
> + if (!pdata->iobase)
> + return -EINVAL;
>
> return macb_late_eth_ofdata_to_platdata(dev);
> }
>
you should use dev_remap_addr() to avoid all the boiler plate code
--
- Daniel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20181217/754f924d/attachment.sig>
More information about the U-Boot
mailing list