};
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource fsg_eth_npeb_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
+static struct resource fsg_eth_npec_resources[] = {
+       {
+               .start          = IXP4XX_EthC_BASE_PHYS,
+               .end            = IXP4XX_EthC_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info fsg_plat_eth[] = {
        {
                .phy            = 5,
                .dev = {
                        .platform_data  = fsg_plat_eth,
                },
+               .num_resources  = ARRAY_SIZE(fsg_eth_npeb_resources),
+               .resource       = fsg_eth_npeb_resources,
        }, {
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEC,
                .dev = {
                        .platform_data  = fsg_plat_eth + 1,
                },
+               .num_resources  = ARRAY_SIZE(fsg_eth_npec_resources),
+               .resource       = fsg_eth_npec_resources,
        }
 };
 
 
 
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource eth_npeb_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
+static struct resource eth_npec_resources[] = {
+       {
+               .start          = IXP4XX_EthC_BASE_PHYS,
+               .end            = IXP4XX_EthC_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info eth_plat[] = {
        {
                .phy            = 0,
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEB,
                .dev.platform_data      = eth_plat,
+               .num_resources          = ARRAY_SIZE(eth_npeb_resources),
+               .resource               = eth_npeb_resources,
        }, {
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEC,
                .dev.platform_data      = eth_plat + 1,
+               .num_resources          = ARRAY_SIZE(eth_npec_resources),
+               .resource               = eth_npec_resources,
        }
 };
 
 
 };
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource ixp425_npeb_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
+static struct resource ixp425_npec_resources[] = {
+       {
+               .start          = IXP4XX_EthC_BASE_PHYS,
+               .end            = IXP4XX_EthC_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info ixdp425_plat_eth[] = {
        {
                .phy            = 0,
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEB,
                .dev.platform_data      = ixdp425_plat_eth,
+               .num_resources          = ARRAY_SIZE(ixp425_npeb_resources),
+               .resource               = ixp425_npeb_resources,
        }, {
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEC,
                .dev.platform_data      = ixdp425_plat_eth + 1,
+               .num_resources          = ARRAY_SIZE(ixp425_npec_resources),
+               .resource               = ixp425_npec_resources,
        }
 };
 
 
 };
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource nas100d_eth_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info nas100d_plat_eth[] = {
        {
                .phy            = 0,
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEB,
                .dev.platform_data      = nas100d_plat_eth,
+               .num_resources          = ARRAY_SIZE(nas100d_eth_resources),
+               .resource               = nas100d_eth_resources,
        }
 };
 
 
 };
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource nslu2_eth_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info nslu2_plat_eth[] = {
        {
                .phy            = 1,
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEB,
                .dev.platform_data      = nslu2_plat_eth,
+               .num_resources          = ARRAY_SIZE(nslu2_eth_resources),
+               .resource               = nslu2_eth_resources,
        }
 };
 
 
 };
 
 /* Built-in 10/100 Ethernet MAC interfaces */
+static struct resource ixp425_npeb_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
+static struct resource ixp425_npec_resources[] = {
+       {
+               .start          = IXP4XX_EthC_BASE_PHYS,
+               .end            = IXP4XX_EthC_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info ixdp425_plat_eth[] = {
        {
                .phy            = 0,
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEB,
                .dev.platform_data      = ixdp425_plat_eth,
+               .num_resources          = ARRAY_SIZE(ixp425_npeb_resources),
+               .resource               = ixp425_npeb_resources,
        }, {
                .name                   = "ixp4xx_eth",
                .id                     = IXP4XX_ETH_NPEC,
                .dev.platform_data      = ixdp425_plat_eth + 1,
+               .num_resources          = ARRAY_SIZE(ixp425_npec_resources),
+               .resource               = ixp425_npec_resources,
        },
 };
 
 
        .num_resources          = ARRAY_SIZE(vulcan_uart_resources),
 };
 
+static struct resource vulcan_npeb_resources[] = {
+       {
+               .start          = IXP4XX_EthB_BASE_PHYS,
+               .end            = IXP4XX_EthB_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
+static struct resource vulcan_npec_resources[] = {
+       {
+               .start          = IXP4XX_EthC_BASE_PHYS,
+               .end            = IXP4XX_EthC_BASE_PHYS + 0x0fff,
+               .flags          = IORESOURCE_MEM,
+       },
+};
+
 static struct eth_plat_info vulcan_plat_eth[] = {
        [0] = {
                .phy            = 0,
                .dev = {
                        .platform_data  = &vulcan_plat_eth[0],
                },
+               .num_resources          = ARRAY_SIZE(vulcan_npeb_resources),
+               .resource               = vulcan_npeb_resources,
        },
        [1] = {
                .name                   = "ixp4xx_eth",
                .dev = {
                        .platform_data  = &vulcan_plat_eth[1],
                },
+               .num_resources          = ARRAY_SIZE(vulcan_npec_resources),
+               .resource               = vulcan_npec_resources,
        },
 };
 
 
        struct phy_device *phydev = NULL;
        struct device *dev = &pdev->dev;
        struct eth_plat_info *plat;
+       resource_size_t regs_phys;
        struct net_device *ndev;
+       struct resource *res;
        struct port *port;
-       u32 regs_phys;
        int err;
 
        plat = dev_get_platdata(dev);
        port->netdev = ndev;
        port->id = pdev->id;
 
+       /* Get the port resource and remap */
+       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+       if (!res)
+               return -ENODEV;
+       regs_phys = res->start;
+       port->regs = devm_ioremap_resource(dev, res);
+
        switch (port->id) {
        case IXP4XX_ETH_NPEA:
                /* If the MDIO bus is not up yet, defer probe */
                if (!mdio_bus)
                        return -EPROBE_DEFER;
-               port->regs = (struct eth_regs __iomem *)IXP4XX_EthA_BASE_VIRT;
-               regs_phys  = IXP4XX_EthA_BASE_PHYS;
                break;
        case IXP4XX_ETH_NPEB:
                /*
                              IXP4XX_FEATURE_NPEB_ETH0))
                                return -ENODEV;
                        /* Else register the MDIO bus on NPE-B */
-                       if ((err = ixp4xx_mdio_register(IXP4XX_EthC_BASE_VIRT)))
+                       if ((err = ixp4xx_mdio_register(port->regs)))
                                return err;
                }
                if (!mdio_bus)
                        return -EPROBE_DEFER;
-               port->regs = (struct eth_regs __iomem *)IXP4XX_EthB_BASE_VIRT;
-               regs_phys  = IXP4XX_EthB_BASE_PHYS;
                break;
        case IXP4XX_ETH_NPEC:
                /*
                              IXP4XX_FEATURE_NPEC_ETH))
                                return -ENODEV;
                        /* Else register the MDIO bus on NPE-C */
-                       if ((err = ixp4xx_mdio_register(IXP4XX_EthC_BASE_VIRT)))
+                       if ((err = ixp4xx_mdio_register(port->regs)))
                                return err;
                }
                if (!mdio_bus)
                        return -EPROBE_DEFER;
-               port->regs = (struct eth_regs __iomem *)IXP4XX_EthC_BASE_VIRT;
-               regs_phys  = IXP4XX_EthC_BASE_PHYS;
                break;
        default:
                return -ENODEV;