Re: [PATCH V2 0/4] introduce device async actions mechanism

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tuesday 04 August 2009, Zhang Rui wrote:> On Tue, 2009-08-04 at 05:18 +0800, Rafael J. Wysocki wrote:> > On Friday 24 July 2009, Zhang Rui wrote:> > > Hi,> > > > Hi,> > > > > this is the patch set I made to speed up the device> > > suspend/resume/shutdown process.> > > > > > A new mechanism called Device Async Actions is introduced> > > in this patch set.> > > > Well, I'm not sure we'll need that.> > > > > The basic idea is that,> > > if the suspend/resume/shutdown process of a device group, including> > > a root device and its child devices, are independent of other devices,> > > we create an async domain for this device group,> > > and make them suspend/resume/shutdown asynchronously.    > > > > I don't really think this is the right approach.  IMO, we should rather try to> > identify groups of devices for which the PM callbacks (forget about .shutdown()> > for now) can be executed in parallel.> > hah, I see.> You want to execute as more PM callbacks at one time as possible,> right?
Not only that.  I'd like to simplify the design, because IMO using one asyncdomain would be much more straightforward than using multiple ones.
> I'm afraid this won't bring as many benefits as it looks like because> most of the suspend/resume time is cost on several specified devices.
That shouldn't matter.  As long as there's one driver that waits long enoughfor the others' devices to be handled while it's waiting, we are not goingto be hurt by this and the design is going to be simpler IMO.
> Take the dmesg I attached for example.> > total device suspend time is 1.532s.> serio2		0.407s> sd 0.0.0.0	0.452s> serio0		0.103s> 0b.4.2		0.114s> 00.1f.2		0.080s> 00.19.0		0.072s> all the others	0.304s> > total device resume time is 2.899s> PNP0C0A:00(bat)	0.896s> 00.19.0		0.056s> 0b.4.0		0.139s> 0b.1.1		0.064s> usb1		0.052s> usb2		0.051s> usb3		0.042s> usb8		0.248s> sd 0.0.0.0	0.118s> usb 3-1		0.261s> usb 8-1		0.511s> all the others	0.461s> > We can see that these several devices take 80%~85% suspend/resume time,> while all the other (nearly 500) devices take 20%.
OK, so it doesn't matter how we run the suspend/resume of the 500 'fast'devices as long as it doesn't take more than 0.896s total.  In particular, itseems we can do that in parallel just fine.
> Running a lot device PM callbacks at one time is not equal to saving a> lot time if the devices listed above still run synchronously.> > So I think the key point to speed up suspend/resume is to invoke the PM> callbacks of these devices asynchronously.> And I use the asynchronous functions for two reasons.> 1. devices with dependency are in the same asynchronous domain so that>    their PM callbacks run in-order.> 2. PM callbacks of the devices without any dependency run> asynchronously>    by using different asynchronous domains.
If I understand the async framework correctly, the domains are only used forsynchronization, ie. if you want to wait for a group of async operations tocomplete, you can put them all into one domain and then callasync_synchronize_full_domain() to wait for them all together.
You don't need multiple domains to run multiple things in parallel.
> > One such group is leaf devices, ie.> > devices that have no children.  Of course, some of them will depend of the> > other indirectly, so we should make it possible to declare (in the driver)> > whether the device can be suspended/resumed asynchronously and use the> > following logic (at the core level), in pseudo code:> > > > if (has_no_children(dev) && asynchronous_suspend_resume_allowed(dev))> >     async_resume(dev);> > else> >     resume(dev);> > > > and analogously for suspend.  Then, we can easily use one async domain for all> > of these devices.> > > Later, we can add async domains for devices that have children, but can be> > suspended and woken up in parallel with each other.> >   IOW, I think the async> > domains should span the levels rather than branches of the device> > tree.> > > > Hmm, as I said above,> this approach works only if we can make sure that the specified devices> are put in the same async domain, i.e. run in parallel.
Sure and that's the point.
For starters, let's put all devices (or rather drivers) without anydependencies into one async domain and call suspend/resume for them using theasync framework (they will be suspended/resumed in parallel with each other aswell as in parallel with the rest).  Then, let's callasync_synchronize_full_domain() for that domain when we've finished executingall of the suspend/resume callbacks.
We can easily do such a thing for each phase of suspend/resume or hibernationwithout causing any problems to happen IMO, as long as the 'async' driversreally have no dependencies.
> are there any prototype patches available?
No, because I didn't have the time to prepare any.  If you give me a couple ofdays, I can write something.  I think.
Thanks,Rafael_______________________________________________linux-pm mailing listlinux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx://lists.linux-foundation.org/mailman/listinfo/linux-pm


[Index of Archives]     [Linux ACPI]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [CPU Freq]     [Kernel Newbies]     [Fedora Kernel]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux