On Wed, Aug 8, 2012 at 4:45 AM, Rafael J. Wysocki <rjw@xxxxxxx> wrote: > On Tuesday, August 07, 2012, Ming Lei wrote: >> On Tue, Aug 7, 2012 at 7:23 PM, Rafael J. Wysocki <rjw@xxxxxxx> wrote: >> >> Yes, I agree, but I don't think it may make .runtime_post_resume >> >> not doable, do I? >> > >> > No more device PM callbacks, please. >> >> IMO, what the patch is doing is to introduce one callback which >> is just called after .runtime_resume is completed, > > No, it is not a callback. It is a function to be run _once_ when the device is > known to be active. It is not a member of a data type or anything like this. Looks it was said by Alan, not me, :-) "The documentation should explain that in some ways, "func" is like a workqueue callback routine:". See http://marc.info/?l=linux-usb&m=134426838507799&w=2 > > It's kind of disappointing that you don't see a difference between that and a > callback. > >> and you want to move something out of previous .runtime_resume > > No, I don't. Where did you get that idea from? If so, I am wondering why the 'func' can't be called in .runtime_resume directly, and follow the below inside caller at the same time? if (device is active or disabled) call func(device). > >> and do it in another new callback to speedup resume, > > No, not to speed up resume. The idea is to allow drivers to run something > when the resume is complete, so that they don't have to implement a "resume > detection" logic or use .runtime_resume() to run things that don't belong > there. Looks it was said by you, :-) "Unless your _driver_ callback is actually executed from within a PM domain callback, for example, and something else may be waiting for it to complete, so your data processing is adding latencies to some other threads. I'm not making that up, by the way, that really can happen." See http://marc.info/?l=linux-pm&m=134394271517527&w=2 Alan also said "Okay, those are valid reasons" for the idea. Except for this one, I don't see other obvious advantages about the patch. > >> so it should be reasonable to introduce the .runtime_post_resume callback in >> logic. > > No. This doesn't have anything to do with callbacks! > > If you want a new callback, you should specify what the role of this callback > is, otherwise it is not well defined. I this case, though, what the role of > func() is depends on the caller and most likely every driver would use it > for something different. So no, I don't see how it can be a callback. > >> Also, the 'func' should be per driver, not per device since only one >> 'func' is enough for all same kind of devices driven by one same >> driver. > > It isn't per device! It is per _caller_. The fact that the pointer is > stored _temporarily_ in struct device doesn't mean that it is per device > and that it is a callback. From the struct device point of view it is _data_, > not a member function. The fact is that it will become per-device one you store it in 'struct device'. Suppose one driver may drive 10000 same devices, the same data will be stored inside all the 10000 device instances, it is a good way to do it? Not mention 90% devices mayn't use the _temporarily_ data at all. > >> > Besides, callbacks in struct dev_pm_ops are not only for drivers. >> >> All the current 3 runtime callbacks are for devices. If you mean >> they can be defined in bus/power_domain/device_type, .runtime_post_resume >> still can be defined there too. > > No, it wouldn't make _any_ _sense_ there, because its role there cannot be > defined in any sane way. > >> >> > Also, "func" should not be stored in dev_pm_ops because it won't be a >> >> > read-only value. >> >> >> >> Sorry, could you explain it in detail that why the 'func' >> >> has to switch to multiple functions dynamically? I understand >> >> one function is enough and sometimes it can be bypassed with >> >> one flag(such as, ignore_post_resume is introduced in dev_pm_info) >> >> set. Also, the driver can store the device specific states >> >> in its own device instance to deal with different situations in the callback. >> >> >> >> If the idea is doable, we can save one pointer in 'struct device', >> >> since the 'func' may not be used by more than 90% devices, also >> >> have document benefit, even may simplify implementation of the >> >> mechanism. >> > >> > And how many struct device objects there are for the one extra pointer to >> > matter, let alone the fact that you want to replace it by one extra pointer >> > somewhere else? >> >> For example, in the pandaboard(one omap4 based small system), follows >> the count of device instances: >> >> [root@root]#dmesg | grep device_add | wc -l >> 471 >> >> The above is just a simple configuration(no graphics, no video/video, only >> console enabled) on Pandaboard. >> >> If the callback may be defined in dev_pm_info, > > I guess you mean struct dev_pm_ops, right? Sorry, it is a typo. > >> not only memory can be saved, also there are other advantages described >> before. > > So now please count how many struct dev_pm_ops objects there are on that system > and compute the differece. And please note that drivers that don't use > struct dev_pm_ops for power management will do that in the future. Most of dev_pm_ops stays inside module image, and not in ram. It is a bit difficult to get the count of all dev_pm_ops objects in ram since it is defined statically. For example, in USB subsystem, there are only 2 dev_pm_ops objects in RAM for a normal system, but there may have hundreds of usb devices in the system(usb_device, usb_interface, ep_device, ...). > > Also please note that the caller of pm_runtime_get_and_call() need not be > a driver, at least in theory. I admit it in theory, :-) Thanks, -- Ming Lei -- 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