一般来说,唤醒设备会有一个interrupt pin硬件连接到SOC 的GPIO pin,一般来说,当设备需要唤醒系统的时候,会通过改变interrupt pin电平状态,而SOC会检测到这个变化,将boot cpu唤醒,进而唤醒整个CPU系统,系统通过相关子系统通知上层做出相应的处理.这就是中断唤醒的过程.
为了使能设备的唤醒能力,设备驱动中会在suspend的时候通过enable_irq_wake(irq)接口使能设备SOC引脚的中断唤醒能力.
enable_irq_wake()可以有两种途径:
1.driver的suspend函数中,由驱动开发者主动调用.
2.driver的probe函数中调用dev_pm_set_wake_irq()和device_init_wakeup().suspend的过程会通过dev_pm_arm_wake_irq()打开所有wakeup source的irq wake功能.
当系统睡眠(echo “mem” > /sys/power/state)的时候,会调用到驱动的suspend函数,enable_irq_wake注意的工作是设置SOC相关wakeup寄存器使能中断唤醒和设置irq的标志位为IRQD_WAKEUP_STATE
设备产生中断后,会唤醒boot cpu(noboot cpu在suspend的时候以及被disable),.继续enable所有的noboot cpu之后,开始dpm_resume_noirq().这时候可以相应suspend之前的enable_irq_wakeup的irq,其他IRQ还不能被响应.并且具有唤醒能力的irq仅仅是进入中断后设置一些flag就退出了.没有执行irq handle.