Hi, On Mon, Feb 08, 2016 at 11:20:14AM -0800, Darren Hart wrote: > My only major concern is module load order dependencies. Inter-module > dependencies are frowned upon with good reason, the kernel load ordering is > non-deterministic and it's possible, for example, for dell-laptop to fail to > find the symbols exported by dell-smbios under certain conditions. > > I have worked around this in the past with things like the following: > > #ifdef MODULE > #ifdef CONFIG_FOO_MODULE > if (request_module("foo")) > return -ENODEV; > #endif > #endif > > Something like the above may be necessary for dell-smbios in dell-laptop, > dell-wmi, and dell-leds now that they depend on the dell-smbios exported > functions. > > Cc Greg in case there is a better way to handle this that I'm not aware of. Deferred probing seems to be the preferred way, see e.g.: https://lists.freedesktop.org/archives/dri-devel/2016-January/098404.html (In this example, apple_gmux_present() determines presence of the device and !vga_switcheroo_handler_flags() determine non-presence of its driver.) This will also work if the subsystem depended on is compiled in rather than in a module. Best regards, Lukas -- To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html