On Mon, 23 Mar 2015 16:26:07 +0200 Adrian Hunter <adrian.hunter@xxxxxxxxx> wrote: > For Neil's problem I would do something quiet different: > > 1. The host driver already knows the bus width so can easily "get/put" > runtime pm to prevent suspend when the bus width does not permit it. > > 2. The need to do things when the card is idle comes up a lot (e.g. bkops, > sleep notification, cache flush etc etc). In Neil's case he wants to switch > to 1-bit mode, but that just seems another of these "idle" operations. So I > would investigate the requirements of supporting idle operations in general. > Hi, I agree that what I want to achieve could be characterised as an "idle" operation. I also happen to think that runtime PM is designed to support "idle" operations - it can track when a device goes 'idle' and "do the right thing". It handles all the needed ref counting and races with resume etc. So I think it should be used to manage these "idle" operations. The difficulty is that in the naive approach, we want to do something in the "runtime_suspend" operation which actually uses the device. So it has to be non-idle in order to go idle. I agree that this can appear clumsy. What we effectively have here is two levels of "idle". First the "host" goes idle in that no new commands are arriving and no interrupts have happened. In response to this the host sends a few final commands to the controller and then the controller goes idle. This two-stage process should be able to be modelled with the two levels of device: the mmc_host class device and the platform device which controls the hardware. e.g. mmc1 and omap_hsmmc.1 on my board. So this is (roughly) what I would do if I wanted to implement fully general "idle" operations for mmc cards. 1/ enable runtime_pm on the host device - in mmc_add_host. I think pm_suspend_ignore_children() would be needed so that the host can go to sleep while the card is still active. 2/ Use pm_runtime_get / pm_runtime_put_autosuspend in mmc_claim_host and mmc_release_host. 3/ Remove the ->enable and ->disable calls from mmc_{claim,release}_host. I think they only affect omap_hsmmc and it only uses them for runtime PM, which now will happen automatically. 4/ In the 'runtime_suspend' method for mmc_host, take a runtime_pm reference on the platform device and schedule a work item to run the "idle" operations When the "idle" operations complete, the runtime_pm reference will be dropped and then - having no active children or references - the platform device will go to sleep (stop its clocks or whatever). When something then calls mmc_claim_host(), the "idle" operations can be undone, either directly or via the runtime_resume operation. This would be a fairly intrusive change. I'm happy to try to find time to write bits of it if there is general agreement, but I cannot test anything other than omap_hsmmc, and I don't know any details about any other possible "idle" operations so I would need input from someone who does. NeilBrown
Attachment:
pgpoPYRHwijJh.pgp
Description: OpenPGP digital signature