On 20 February 2017 at 09:03, Ritesh Harjani <riteshh@xxxxxxxxxxxxxx> wrote:I meant mmc_runtime_resume time which will be accounted only in MMC card run-time resume now.
As per JEDEC spec - CMD5 can be used to awake from sleep mode for emmc.
This patch series provide CMD5(awake) + mmc_partial_init support to resume
mmc card device. This is mainly to reduce the resume time.
I assume with "resume time" you don't mean "system PM resume time"?
In general MMC card resume time will be optimized.
The current approach we have for MMC is to postpone system PM resume
of the card until it's actually needed, thus via runtime PM instead.
Then the time it takes to re-initialize the eMMC don't affect the
system PM resume time at all.
Therefore I am wondering about how big of a problem this really is. Is
there a specific use case you are optimizing for?
Sorry, I did not enable MMC_CAP_WAIT_WHILE_BUSY on db410c. That's why we see 11% improvement only. After I enabled this cap, I see ~47% improvement in mmc_runtime_resume on db410c.
This was tested on db410c (emmc with HS200 mode) and MS8996 (emmc with HS400ES)
based internal board. This patch reduced the resume time by ~50% on msm8996
and ~11% on db410c.
The improved behaviour in percentage is very interesting, but I would
also like to see real numbers.
These controllers have MMC_CAP_WAIT_WHILE_BUSY capability enabled.
Moreover, I would like to know what kind of mechanism the
corresponding host drivers/controllers are using for card busy
detection?
Sure, please let me know your feedback.
As of now this patch series provides a caps (MMC_CAP2_SLEEP_AWAKE) to enable this feature.
Since there is no dependency on host platform for this, we can enable this feature by
default as well. Thoughts?
I will look into the series in more detail, however we must not add a
corresponding DT binding for this as this isn't a HW configuration. IOk.
guess what you need to know is that VCCQ stays powered on when the
card is a sleep, else waking up with CMD5 won't work
(MMC_CAP_FULL_PWR_CYCLE).
This may not be very complex actually.
The current main concern I can think of, is whether the added
complexity to the wakeup path can be justified for the improved
behaviour.
Ritesh Harjani (4):
Documentation: mmc: add mmc-sleep-awake
mmc: core: add mmc-sleep-awake caps
mmc: mmc: add support for CMD5 awake
mmc: core: Implement mmc_partial_init during resume
Documentation/devicetree/bindings/mmc/mmc.txt | 2 +
drivers/mmc/core/core.c | 13 +++
drivers/mmc/core/core.h | 1 +
drivers/mmc/core/host.c | 2 +
drivers/mmc/core/mmc.c | 160 ++++++++++++++++++++++++--
include/linux/mmc/card.h | 3 +
include/linux/mmc/host.h | 2 +
7 files changed, 176 insertions(+), 7 deletions(-)
--
The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum,
a Linux Foundation Collaborative Project.
Kind regards
Uffe