On Tue, May 26, 2015 at 07:41:18PM -0700, Greg KH wrote: > On Tue, May 26, 2015 at 10:54:01AM -0700, David Cohen wrote: > > Hi, > > > > On Mon, May 25, 2015 at 07:00:13PM +0200, Bjørn Mork wrote: > > > Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx> writes: > > > > Don't mess with bus->p. I can rename it to > "do_not_touch_this_isnt_for_you" if people think that would make it more > obvious that a private data structure shouldn't be messed with in any > way. Outside of the driver core, you have no knowledge that even if it > is a pointer, what that means with regards to anything. Being a newbie I had a newbie kind of doubt that if a module is builtin and the init fails then what happens to the functions exported by it. And to test that I created a module: int abcd(void) { pr_err("test: in abcd\n"); return 0; } EXPORT_SYMBOL(abcd); static int __init test_init(void) { return -ENOMEM; } module_init(test_init); static void __exit test_exit(void) { } module_exit(test_exit); Compiled it as builtin, and created another module which calls abcd(); and as expected abcd() executed. So same thing can happen here also: if bus_register() in ulpi_init() fails then also ulpi_unregister_driver() can be executed as the symbol has been exported. you are saying bus->p is private and not to use that but you are also saying that if we use another variable to keep the status of bus registration then the design is wrong. Then what should be the correct way? regards sudip > > thanks, > > greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html