On Mon, Sep 5, 2016 at 9:38 AM, Alexander Sverdlin <alexander.sverdlin@xxxxxxxxx> wrote: > The comment to OF_POPULATED_BUS says "of_platform_populate recursed to children > of this node". Consider the following structure: > > ocp { > compatible = "simple-bus"; > ranges; > ... > l4_wkup: l4_wkup@44c00000 { > compatible = "ti,am3-l4-wkup", "simple-bus"; > ranges = <0 0x44c00000 0x280000>; > ... > wkup_m3: wkup_m3@100000 { > compatible = "ti,am3352-wkup-m3"; > ... > } > } > } > > If one DT overlay adds "ocp" node without children then of_platform_notify() > creates a platform device, but doesn't set OF_POPULATED_BUS. If second overlay > tries to populate children of "ocp" node, corresponding platform devices are > not instantiated because of check for OF_POPULATED_BUS flag. If the above > example structure is built of several overlays, of_platform_populate() is not > involved here at all, so maybe OF_POPULATED_BUS requirement is wrong. Your example seems a bit made up. While you can craft base DTs and overlays with any random split between them, I don't necessarily think we want to support that. There will likely be cases which we say can only be applied early in boot or we limit which nodes can be overlay targets for overlays applied from userspace. Rob -- 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