mirror of
https://github.com/torvalds/linux.git
synced 2024-11-29 15:41:36 +00:00
[POWERPC] mpc5200: normalize compatible property bindings
Update MPC5200 drivers to also look for compatible properties in the form "fsl,mpc5200-*" to better conform to open firmware generic names recommended practice as published here: http://www.openfirmware.org/1275/practice/gnames/gnamv14a.html This patch should *not* break compatibility with older device trees which do not use the 'fsl,' prefix. The drivers will still bind against the older names also. Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
This commit is contained in:
parent
82e30140ff
commit
66ffbe490b
@ -32,6 +32,19 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* mpc5200 device tree match tables */
|
||||||
|
static struct of_device_id mpc5200_cdm_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-cdm", },
|
||||||
|
{ .compatible = "mpc5200-cdm", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct of_device_id mpc5200_gpio_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-gpio", },
|
||||||
|
{ .compatible = "mpc5200-gpio", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fix clock configuration.
|
* Fix clock configuration.
|
||||||
*
|
*
|
||||||
@ -44,9 +57,8 @@ lite5200_fix_clock_config(void)
|
|||||||
{
|
{
|
||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
struct mpc52xx_cdm __iomem *cdm;
|
struct mpc52xx_cdm __iomem *cdm;
|
||||||
|
|
||||||
/* Map zones */
|
/* Map zones */
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200-cdm");
|
np = of_find_matching_node(NULL, mpc5200_cdm_ids);
|
||||||
cdm = of_iomap(np, 0);
|
cdm = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!cdm) {
|
if (!cdm) {
|
||||||
@ -81,7 +93,7 @@ lite5200_fix_port_config(void)
|
|||||||
struct mpc52xx_gpio __iomem *gpio;
|
struct mpc52xx_gpio __iomem *gpio;
|
||||||
u32 port_config;
|
u32 port_config;
|
||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200-gpio");
|
np = of_find_matching_node(NULL, mpc5200_gpio_ids);
|
||||||
gpio = of_iomap(np, 0);
|
gpio = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!gpio) {
|
if (!gpio) {
|
||||||
|
@ -43,6 +43,13 @@ static int lite5200_pm_set_target(suspend_state_t state)
|
|||||||
static int lite5200_pm_prepare(void)
|
static int lite5200_pm_prepare(void)
|
||||||
{
|
{
|
||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
|
const struct of_device_id immr_ids[] = {
|
||||||
|
{ .compatible = "fsl,mpc5200-immr", },
|
||||||
|
{ .compatible = "fsl,mpc5200b-immr", },
|
||||||
|
{ .type = "soc", .compatible = "mpc5200", }, /* lite5200 */
|
||||||
|
{ .type = "builtin", .compatible = "mpc5200", }, /* efika */
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
/* deep sleep? let mpc52xx code handle that */
|
/* deep sleep? let mpc52xx code handle that */
|
||||||
if (lite5200_pm_target_state == PM_SUSPEND_STANDBY)
|
if (lite5200_pm_target_state == PM_SUSPEND_STANDBY)
|
||||||
@ -52,7 +59,7 @@ static int lite5200_pm_prepare(void)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
/* map registers */
|
/* map registers */
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200");
|
np = of_find_matching_node(NULL, immr_ids);
|
||||||
mbar = of_iomap(np, 0);
|
mbar = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!mbar) {
|
if (!mbar) {
|
||||||
|
@ -18,6 +18,23 @@
|
|||||||
#include <asm/prom.h>
|
#include <asm/prom.h>
|
||||||
#include <asm/mpc52xx.h>
|
#include <asm/mpc52xx.h>
|
||||||
|
|
||||||
|
/* MPC5200 device tree match tables */
|
||||||
|
static struct of_device_id mpc52xx_xlb_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-xlb", },
|
||||||
|
{ .compatible = "mpc5200-xlb", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
static struct of_device_id mpc52xx_bus_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-immr", },
|
||||||
|
{ .compatible = "fsl,mpc5200b-immr", },
|
||||||
|
{ .compatible = "fsl,lpb", },
|
||||||
|
|
||||||
|
/* depreciated matches; shouldn't be used in new device trees */
|
||||||
|
{ .type = "builtin", .compatible = "mpc5200", }, /* efika */
|
||||||
|
{ .type = "soc", .compatible = "mpc5200", }, /* lite5200 */
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This variable is mapped in mpc52xx_map_wdt() and used in mpc52xx_restart().
|
* This variable is mapped in mpc52xx_map_wdt() and used in mpc52xx_restart().
|
||||||
* Permanent mapping is required because mpc52xx_restart() can be called
|
* Permanent mapping is required because mpc52xx_restart() can be called
|
||||||
@ -65,7 +82,7 @@ mpc5200_setup_xlb_arbiter(void)
|
|||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
struct mpc52xx_xlb __iomem *xlb;
|
struct mpc52xx_xlb __iomem *xlb;
|
||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200-xlb");
|
np = of_find_matching_node(NULL, mpc52xx_xlb_ids);
|
||||||
xlb = of_iomap(np, 0);
|
xlb = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!xlb) {
|
if (!xlb) {
|
||||||
@ -88,16 +105,11 @@ mpc5200_setup_xlb_arbiter(void)
|
|||||||
iounmap(xlb);
|
iounmap(xlb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_bus_ids[] __initdata= {
|
/**
|
||||||
{ .compatible = "fsl,mpc5200-immr", },
|
* mpc52xx_declare_of_platform_devices: register internal devices and children
|
||||||
{ .compatible = "fsl,lpb", },
|
* of the localplus bus to the of_platform
|
||||||
|
* bus.
|
||||||
/* depreciated matches; shouldn't be used in new device trees */
|
*/
|
||||||
{ .type = "builtin", .compatible = "mpc5200", }, /* efika */
|
|
||||||
{ .type = "soc", .compatible = "mpc5200", }, /* lite5200 */
|
|
||||||
{},
|
|
||||||
};
|
|
||||||
|
|
||||||
void __init
|
void __init
|
||||||
mpc52xx_declare_of_platform_devices(void)
|
mpc52xx_declare_of_platform_devices(void)
|
||||||
{
|
{
|
||||||
@ -107,33 +119,31 @@ mpc52xx_declare_of_platform_devices(void)
|
|||||||
"Error while probing of_platform bus\n");
|
"Error while probing of_platform bus\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* match tables used by mpc52xx_map_wdt()
|
||||||
|
*/
|
||||||
|
static struct of_device_id mpc52xx_gpt_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-gpt", },
|
||||||
|
{ .compatible = "mpc5200-gpt", }, /* old */
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
void __init
|
void __init
|
||||||
mpc52xx_map_wdt(void)
|
mpc52xx_map_wdt(void)
|
||||||
{
|
{
|
||||||
const void *has_wdt;
|
|
||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
|
|
||||||
/* mpc52xx_wdt is mapped here and used in mpc52xx_restart,
|
/* mpc52xx_wdt is mapped here and used in mpc52xx_restart,
|
||||||
* possibly from a interrupt context. wdt is only implement
|
* possibly from a interrupt context. wdt is only implement
|
||||||
* on a gpt0, so check has-wdt property before mapping.
|
* on a gpt0, so check has-wdt property before mapping.
|
||||||
*/
|
*/
|
||||||
for_each_compatible_node(np, NULL, "fsl,mpc5200-gpt") {
|
for_each_matching_node(np, mpc52xx_gpt_ids) {
|
||||||
has_wdt = of_get_property(np, "fsl,has-wdt", NULL);
|
if (of_get_property(np, "fsl,has-wdt", NULL) ||
|
||||||
if (has_wdt) {
|
of_get_property(np, "has-wdt", NULL)) {
|
||||||
mpc52xx_wdt = of_iomap(np, 0);
|
mpc52xx_wdt = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for_each_compatible_node(np, NULL, "mpc5200-gpt") {
|
|
||||||
has_wdt = of_get_property(np, "has-wdt", NULL);
|
|
||||||
if (has_wdt) {
|
|
||||||
mpc52xx_wdt = of_iomap(np, 0);
|
|
||||||
of_node_put(np);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -99,6 +99,12 @@ struct mpc52xx_pci {
|
|||||||
u8 reserved6[4]; /* PCI + 0xFC */
|
u8 reserved6[4]; /* PCI + 0xFC */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* MPC5200 device tree match tables */
|
||||||
|
const struct of_device_id mpc52xx_pci_ids[] __initdata = {
|
||||||
|
{ .type = "pci", .compatible = "fsl,mpc5200-pci", },
|
||||||
|
{ .type = "pci", .compatible = "mpc5200-pci", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
/* ======================================================================== */
|
/* ======================================================================== */
|
||||||
/* PCI configuration acess */
|
/* PCI configuration acess */
|
||||||
@ -411,9 +417,7 @@ void __init mpc52xx_setup_pci(void)
|
|||||||
{
|
{
|
||||||
struct device_node *pci;
|
struct device_node *pci;
|
||||||
|
|
||||||
pci = of_find_compatible_node(NULL, NULL, "fsl,mpc5200-pci");
|
pci = of_find_matching_node(NULL, mpc52xx_pci_ids);
|
||||||
if (!pci)
|
|
||||||
pci = of_find_compatible_node(NULL, NULL, "mpc5200-pci");
|
|
||||||
if (!pci)
|
if (!pci)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -29,6 +29,18 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* MPC5200 device tree match tables */
|
||||||
|
static struct of_device_id mpc52xx_pic_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-pic", },
|
||||||
|
{ .compatible = "mpc5200-pic", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
static struct of_device_id mpc52xx_sdma_ids[] __initdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-bestcomm", },
|
||||||
|
{ .compatible = "mpc5200-bestcomm", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
static struct mpc52xx_intr __iomem *intr;
|
static struct mpc52xx_intr __iomem *intr;
|
||||||
static struct mpc52xx_sdma __iomem *sdma;
|
static struct mpc52xx_sdma __iomem *sdma;
|
||||||
static struct irq_host *mpc52xx_irqhost = NULL;
|
static struct irq_host *mpc52xx_irqhost = NULL;
|
||||||
@ -367,13 +379,13 @@ void __init mpc52xx_init_irq(void)
|
|||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
|
|
||||||
/* Remap the necessary zones */
|
/* Remap the necessary zones */
|
||||||
picnode = of_find_compatible_node(NULL, NULL, "mpc5200-pic");
|
picnode = of_find_matching_node(NULL, mpc52xx_pic_ids);
|
||||||
intr = of_iomap(picnode, 0);
|
intr = of_iomap(picnode, 0);
|
||||||
if (!intr)
|
if (!intr)
|
||||||
panic(__FILE__ ": find_and_map failed on 'mpc5200-pic'. "
|
panic(__FILE__ ": find_and_map failed on 'mpc5200-pic'. "
|
||||||
"Check node !");
|
"Check node !");
|
||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200-bestcomm");
|
np = of_find_matching_node(NULL, mpc52xx_sdma_ids);
|
||||||
sdma = of_iomap(np, 0);
|
sdma = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!sdma)
|
if (!sdma)
|
||||||
|
@ -60,9 +60,16 @@ int mpc52xx_set_wakeup_gpio(u8 pin, u8 level)
|
|||||||
int mpc52xx_pm_prepare(void)
|
int mpc52xx_pm_prepare(void)
|
||||||
{
|
{
|
||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
|
const struct of_device_id immr_ids[] = {
|
||||||
|
{ .compatible = "fsl,mpc5200-immr", },
|
||||||
|
{ .compatible = "fsl,mpc5200b-immr", },
|
||||||
|
{ .type = "soc", .compatible = "mpc5200", }, /* lite5200 */
|
||||||
|
{ .type = "builtin", .compatible = "mpc5200", }, /* efika */
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
/* map the whole register space */
|
/* map the whole register space */
|
||||||
np = of_find_compatible_node(NULL, NULL, "mpc5200");
|
np = of_find_matching_node(NULL, immr_ids);
|
||||||
mbar = of_iomap(np, 0);
|
mbar = of_iomap(np, 0);
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
if (!mbar) {
|
if (!mbar) {
|
||||||
|
@ -29,11 +29,17 @@
|
|||||||
|
|
||||||
#define DRIVER_NAME "bestcomm-core"
|
#define DRIVER_NAME "bestcomm-core"
|
||||||
|
|
||||||
|
/* MPC5200 device tree match tables */
|
||||||
|
static struct of_device_id mpc52xx_sram_ids[] __devinitdata = {
|
||||||
|
{ .compatible = "fsl,mpc5200-sram", },
|
||||||
|
{ .compatible = "mpc5200-sram", },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
struct bcom_engine *bcom_eng = NULL;
|
struct bcom_engine *bcom_eng = NULL;
|
||||||
EXPORT_SYMBOL_GPL(bcom_eng); /* needed for inline functions */
|
EXPORT_SYMBOL_GPL(bcom_eng); /* needed for inline functions */
|
||||||
|
|
||||||
|
|
||||||
/* ======================================================================== */
|
/* ======================================================================== */
|
||||||
/* Public and private API */
|
/* Public and private API */
|
||||||
/* ======================================================================== */
|
/* ======================================================================== */
|
||||||
@ -373,7 +379,7 @@ mpc52xx_bcom_probe(struct of_device *op, const struct of_device_id *match)
|
|||||||
of_node_get(op->node);
|
of_node_get(op->node);
|
||||||
|
|
||||||
/* Prepare SRAM */
|
/* Prepare SRAM */
|
||||||
ofn_sram = of_find_compatible_node(NULL, "sram", "mpc5200-sram");
|
ofn_sram = of_find_matching_node(NULL, mpc52xx_sram_ids);
|
||||||
if (!ofn_sram) {
|
if (!ofn_sram) {
|
||||||
printk(KERN_ERR DRIVER_NAME ": "
|
printk(KERN_ERR DRIVER_NAME ": "
|
||||||
"No SRAM found in device tree\n");
|
"No SRAM found in device tree\n");
|
||||||
@ -478,10 +484,8 @@ mpc52xx_bcom_remove(struct of_device *op)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_bcom_of_match[] = {
|
static struct of_device_id mpc52xx_bcom_of_match[] = {
|
||||||
{
|
{ .type = "dma-controller", .compatible = "fsl,mpc5200-bestcomm", },
|
||||||
.type = "dma-controller",
|
{ .type = "dma-controller", .compatible = "mpc5200-bestcomm", },
|
||||||
.compatible = "mpc5200-bestcomm",
|
|
||||||
},
|
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -494,10 +494,8 @@ mpc52xx_ata_resume(struct of_device *op)
|
|||||||
|
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_ata_of_match[] = {
|
static struct of_device_id mpc52xx_ata_of_match[] = {
|
||||||
{
|
{ .compatible = "fsl,mpc5200-ata", },
|
||||||
.type = "ata",
|
{ .compatible = "mpc5200-ata", },
|
||||||
.compatible = "mpc5200-ata",
|
|
||||||
},
|
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1057,10 +1057,8 @@ static int mpc52xx_fec_of_resume(struct of_device *op)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_fec_match[] = {
|
static struct of_device_id mpc52xx_fec_match[] = {
|
||||||
{
|
{ .type = "network", .compatible = "fsl,mpc5200-fec", },
|
||||||
.type = "network",
|
{ .type = "network", .compatible = "mpc5200-fec", },
|
||||||
.compatible = "mpc5200-fec",
|
|
||||||
},
|
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -177,11 +177,9 @@ static int mpc52xx_fec_mdio_remove(struct of_device *of)
|
|||||||
|
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_fec_mdio_match[] = {
|
static struct of_device_id mpc52xx_fec_mdio_match[] = {
|
||||||
{
|
{ .compatible = "fsl,mpc5200b-mdio", },
|
||||||
.type = "mdio",
|
{ .compatible = "mpc5200b-fec-phy", },
|
||||||
.compatible = "mpc5200b-fec-phy",
|
{}
|
||||||
},
|
|
||||||
{},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct of_platform_driver mpc52xx_fec_mdio_driver = {
|
struct of_platform_driver mpc52xx_fec_mdio_driver = {
|
||||||
|
@ -130,7 +130,9 @@ static irqreturn_t mpc52xx_uart_int(int irq, void *dev_id);
|
|||||||
|
|
||||||
#if defined(CONFIG_PPC_MERGE)
|
#if defined(CONFIG_PPC_MERGE)
|
||||||
static struct of_device_id mpc52xx_uart_of_match[] = {
|
static struct of_device_id mpc52xx_uart_of_match[] = {
|
||||||
{ .type = "serial", .compatible = "mpc5200-psc-uart", },
|
{ .type = "serial", .compatible = "fsl,mpc5200-psc-uart", },
|
||||||
|
{ .type = "serial", .compatible = "mpc5200-psc-uart", }, /* lite5200 */
|
||||||
|
{ .type = "serial", .compatible = "mpc5200-serial", }, /* efika */
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -628,8 +628,9 @@ static int __exit mpc52xx_psc_spi_of_remove(struct of_device *op)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct of_device_id mpc52xx_psc_spi_of_match[] = {
|
static struct of_device_id mpc52xx_psc_spi_of_match[] = {
|
||||||
{ .type = "spi", .compatible = "mpc5200-psc-spi", },
|
{ .compatible = "fsl,mpc5200-psc-spi", },
|
||||||
{},
|
{ .compatible = "mpc5200-psc-spi", }, /* old */
|
||||||
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
MODULE_DEVICE_TABLE(of, mpc52xx_psc_spi_of_match);
|
MODULE_DEVICE_TABLE(of, mpc52xx_psc_spi_of_match);
|
||||||
|
@ -136,6 +136,8 @@ ohci_hcd_ppc_of_probe(struct of_device *op, const struct of_device_id *match)
|
|||||||
ohci = hcd_to_ohci(hcd);
|
ohci = hcd_to_ohci(hcd);
|
||||||
if (is_bigendian) {
|
if (is_bigendian) {
|
||||||
ohci->flags |= OHCI_QUIRK_BE_MMIO | OHCI_QUIRK_BE_DESC;
|
ohci->flags |= OHCI_QUIRK_BE_MMIO | OHCI_QUIRK_BE_DESC;
|
||||||
|
if (of_device_is_compatible(dn, "fsl,mpc5200-ohci"))
|
||||||
|
ohci->flags |= OHCI_QUIRK_FRAME_NO;
|
||||||
if (of_device_is_compatible(dn, "mpc5200-ohci"))
|
if (of_device_is_compatible(dn, "mpc5200-ohci"))
|
||||||
ohci->flags |= OHCI_QUIRK_FRAME_NO;
|
ohci->flags |= OHCI_QUIRK_FRAME_NO;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user