On Wed, 22 Oct 2014, Rob Landley wrote: > > > On 10/21/14 14:58, Nicolas Pitre wrote: > > On Tue, 21 Oct 2014, Bird, Tim wrote: > > > >> I'm going to respond to several comments in this one message (sorry for the likely confusion) > >> > >> On Tuesday, October 21, 2014 9:31 AM, Nicolas Pitre [nico@xxxxxxxxxxx] wrote: > >>> > >>> On Tue, 21 Oct 2014, Grant Likely wrote: > >>> > >>>> On Sat, Oct 18, 2014 at 9:11 AM, Bird, Tim <Tim.Bird@xxxxxxxxxxxxxx> wrote: > >>>>> The answer is pretty easy, I think. I tried to mainline it once but failed, and didn't really > >>>>> try again. If it is being found useful, we should try to mainline it again, this time with > >>>>> more persistence. The reason it got rejected before IIRC was that you can accomplish > >>>>> a similar thing with modules, with no changes to the kernel. But that doesn't cover > >>>>> the case where the loadable modules feature of the kernel is turned off, which is > >>>>> common in very small systems. > >>>> > >>>> It is a rather clumsy approach though since it requires changes to > >>>> modules and it makes the configuration static per build. Could it > >>>> instead be done by the kernel accepting a list of initcalls that > >>>> should be deferred? It would depend I suppose on the cost of finding > >>>> the initcalls to defer at boot time. > >> > >> Yeah, I'm not a big fan of having to change kernel code in order to > >> use the feature. I am quite intrigued by Geert Uytterhoeven's idea > >> to add a 'D' option to the config system, so that the record of which > >> modules to defer could be stored there. This is much better than > >> hand-altering code. I don't know how difficult this would be to add > >> to the kbuild system, but the mechanism for altering the macro would > >> be, IMHO, very straightforward. > > > > Straight forward but IMHO rather suboptimal. Sure it might be good > > enough if all you want is to ship products out the door, but for > > mainline something better should be done. > > > >> This patch predated Arjan Van de Ven's fastboot work. I don't > >> know if some of his parallelization (asynchronous module loading), and > >> optimizations for USB loading made things substantially better than this. > >> The USB spec makes in impossible to avoid a certain amount of delay > >> in probing the USB busses > >> > >> USB was the main culprit, but we sometimes deferred other modules, if they > >> were not in the fastpath for taking a picture. Sony cameras had a goal of > >> booting in .5 seconds, but I think the best we ever achieved was about 1.1 > >> seconds, using deferred initcalls and a variety of other techniques. > > > > Some initcalls can be executed in parallel, but they currently all have > > to complete before user space is started. It should be possible to > > still do the parallel initcall thing, and let user space run before they > > are done as well. Only waiting for the root fs to be available should > > be sufficient. That would be completely generic, and help embedded as > > well as desktop systems. > > What would actually be nice is if initramfs could read something out of > /proc or /sys to check the status of initcalls. (Or maybe get > notification through the hotplug netlink mechanism.) > > Since initramfs is _already_ up really early, before needing any > particular drivers and way before the real root filesystem, we can > trivially punt this sort of synchronization to userspace if userspace > can just get the information about when kernel deferred processing is done. > > Possibly we already have this: /sys/module has directories for all the > kernel modules including the ones built static, so possibly userspace > can just wait for "/sys/module/zlib_delfate/initstate" to say "live". It > would just be nice to have a way to notice that's happened without > spinning reading a file. Again, not generic enough. Instead, the reading of that file could be suspended by the kernel until all initcalls have completed and then return an appropriate error code if the corresponding resource is actually not there. Otherwise the standard hotplug notification mechanism is already available. Nicolas -- To unsubscribe from this list: send the line "unsubscribe linux-embedded" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html