On Monday, October 31, 2016 12:30:55 PM CET Geert Uytterhoeven wrote: > v2: > - Drop SoC families and family names; use fixed "Renesas" instead, I think I'd rather have seen the family names left in there, but it's not important, so up to you. > - Use "renesas,prr" and "renesas,cccr" device nodes in DT if > available, else fall back to hardcoded addresses for compatibility > with existing DTBs, I only see patches 2, 3, 5, and 7 in my inbox, so I'm lacking the DT binding for these, among other things. It does seem wrong to have a device node for a specific register though. Shouldn't the node be for the block of registers that these are inside of? > - Don't register the SoC bus if the chip ID register is missing, Why? My objection was to hardcoding the register, not to registering the device? I think I'd rather see the device registered with an empty revision string. > +#define CCCR 0xe600101c /* Common Chip Code Register */ > +#define PRR 0xff000044 /* Product Register */ > +#define PRR3 0xfff00044 /* Product Register on R-Car Gen3 */ > + > +static const struct of_device_id renesas_socs[] __initconst = { > +#ifdef CONFIG_ARCH_R8A73A4 > + { .compatible = "renesas,r8a73a4", .data = (void *)PRR, }, > +#endif > +#ifdef CONFIG_ARCH_R8A7740 > + { .compatible = "renesas,r8a7740", .data = (void *)CCCR, }, > +#endif My preference here would be to list the register address only for SoCs that are known to need them, while also having .dtb files that don't have the nodes. > +static int __init renesas_soc_init(void) > +{ > + struct soc_device_attribute *soc_dev_attr; > + const struct of_device_id *match; > + void __iomem *chipid = NULL; > + struct soc_device *soc_dev; > + struct device_node *np; > + unsigned int product; > + > + np = of_find_matching_node_and_match(NULL, renesas_socs, &match); > + if (!np) > + return -ENODEV; > + > + of_node_put(np); > + > + /* Try PRR first, then CCCR, then hardcoded fallback */ > + np = of_find_compatible_node(NULL, NULL, "renesas,prr"); > + if (!np) > + np = of_find_compatible_node(NULL, NULL, "renesas,cccr"); > + if (np) { > + chipid = of_iomap(np, 0); > + of_node_put(np); > + } else if (match->data) { > + chipid = ioremap((uintptr_t)match->data, 4); > + } > + if (!chipid) > Here, I'd turn the order around and look for the DT nodes of the devices first. Only if they are not found, look at the compatible string of the root node. No need to search for a node though, you know which one it is when you look for a compatible = "renesas,r8a73a4". Arnd -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html