linux-stable/drivers/base
Qingliang Li 66ed532e73 PM: sleep: wakeirq: fix wake irq warning in system suspend
[ Upstream commit e7a7681c85 ]

When driver uses pm_runtime_force_suspend() as the system suspend callback
function and registers the wake irq with reverse enable ordering, the wake
irq will be re-enabled when entering system suspend, triggering an
'Unbalanced enable for IRQ xxx' warning. In this scenario, the call
sequence during system suspend is as follows:
  suspend_devices_and_enter()
    -> dpm_suspend_start()
      -> dpm_run_callback()
        -> pm_runtime_force_suspend()
          -> dev_pm_enable_wake_irq_check()
          -> dev_pm_enable_wake_irq_complete()

    -> suspend_enter()
      -> dpm_suspend_noirq()
        -> device_wakeup_arm_wake_irqs()
          -> dev_pm_arm_wake_irq()

To fix this issue, complete the setting of WAKE_IRQ_DEDICATED_ENABLED flag
in dev_pm_enable_wake_irq_complete() to avoid redundant irq enablement.

Fixes: 8527beb120 ("PM: sleep: wakeirq: fix wake irq arming")
Reviewed-by: Dhruva Gole <d-gole@ti.com>
Signed-off-by: Qingliang Li <qingliang.li@mediatek.com>
Reviewed-by: Johan Hovold <johan+linaro@kernel.org>
Cc: 5.16+ <stable@vger.kernel.org> # 5.16+
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-04-13 12:50:05 +02:00
..
firmware_loader Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
power PM: sleep: wakeirq: fix wake irq warning in system suspend 2024-04-13 12:50:05 +02:00
regmap regmap: debugfs: Fix a erroneous check after snprintf() 2023-11-20 10:29:17 +01:00
test
Kconfig
Makefile
arch_topology.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
attribute_container.c
base.h
bus.c
cacheinfo.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
class.c class: fix possible memory leak in __class_register() 2023-01-18 11:30:25 +01:00
component.c component: Silence bind error on -EPROBE_DEFER 2020-05-27 17:37:33 +02:00
container.c
core.c drivers: core: fix kernel-doc markup for dev_err_probe() 2024-02-23 08:12:41 +01:00
cpu.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
dd.c driver core: Release all resources during unbind before updating device links 2023-12-08 08:43:22 +01:00
devcon.c
devcoredump.c devcoredump: Send uevent once devcd is ready 2023-12-13 17:42:21 +01:00
devres.c
devtmpfs.c
driver.c driver: platform: Add helper for safer setting of driver_override 2023-11-08 11:22:18 +01:00
firmware.c
hypervisor.c
init.c
isa.c
map.c
memory.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
module.c
node.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
pinctrl.c
platform-msi.c
platform.c driver: platform: Add helper for safer setting of driver_override 2023-11-08 11:22:18 +01:00
property.c
soc.c Revert "drivers core: Use sysfs_emit and sysfs_emit_at for show(device *...) functions" 2023-10-10 21:45:00 +02:00
syscore.c
topology.c
transport_class.c