• B
    PM / Sleep: Detect device suspend/resume lockup and log event · 70fea60d
    Benoit Goby 提交于
    Rather than hard-lock the kernel, dump the suspend/resume thread stack
    and panic() to capture a message in pstore when a driver takes too long
    to suspend/resume. Default suspend/resume watchdog timeout is set to 12
    seconds to be longer than the usbhid 10 second timeout, but could be
    changed at compile time.
    
    Exclude from the watchdog the time spent waiting for children that
    are resumed asynchronously and time every device, whether or not they
    resumed synchronously.
    
    This patch is targeted for mobile devices where a suspend/resume lockup
    could cause a system reboot. Information about failing device can be
    retrieved in subsequent boot session by mounting pstore and inspecting
    the log. Laptops with EFI-enabled pstore could also benefit from
    this feature.
    
    The hardware watchdog timer is likely suspended during this time and
    couldn't be relied upon. The soft-lockup detector would eventually tell
    that tasks are not scheduled, but would provide little context as to why.
    The patch hence uses system timer and assumes it is still active while the
    devices are suspended/resumed.
    
    This feature can be enabled/disabled during kernel configuration.
    
    This change is based on earlier work by San Mehat.
    Signed-off-by: NBenoit Goby <benoit@android.com>
    Signed-off-by: NZoran Markovic <zoran.markovic@linaro.org>
    Acked-by: NUlf Hansson <ulf.hansson@linaro.org>
    Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
    70fea60d
main.c 35.4 KB