> +void watchdog_do_reboot(void) > +{ > + if (wdd_reboot_dev) > + wdd_reboot_dev->ops->reboot(wdd_reboot_dev); > +} > +EXPORT_SYMBOL(watchdog_do_reboot); Crashes and burns if you are unloading a watchdog just as you try to reboot. Yes its wildly unlikely but it's still conceptually wrong. > > + if (wdd->ops->reboot) > + wdd_reboot_dev = wdd; > + Two parallel registers from different bus types, parallel register/unregister ? This feels to me like a backward step. We've gone from various device bits leaking into the core code (where they can work all the time) to various core code leaking into the devices which is asking for init order problems and other races. Given we are talking about stuff of the order of 10-20 instructions I think duplication is not only the lesser evil it's also smaller, more reliable and easier to maintain. IMHO this is a solution looking for a problem. Alan -- To unsubscribe from this list: send the line "unsubscribe linux-doc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html