pm_stay_awake运用在sequans项目中。

    本文参照窝窝团队的低功耗管理而写,在其基础上增加了自己的想法。连接如下:

http://www.wowotech.net/pm_subsystem/driver_pm.html

    在我们移动手持设备中,低功耗是不得不采用的,没有低功耗,那我们的移动设备待机时间是可想而知的。

    在我做sequans项目中,遇到一个奇葩的问题:当申请gpio引脚为中断唤醒源时,只能保持100ms的唤醒时间,应用程序无法启动,设备就有休眠了,我们知道,在应用层,只要使用系统调用(echo mem > /sys/power/state)就可以关闭设备休眠模式。这个原理我这里不啰嗦,可以看窝窝的详细介绍。因为应用程序无法从挂起状态到运行状态,所以只能采用中断处理来使得设备可以保持唤醒状态“久一点”,保证设备有充足的时间去“唤醒”应用层。

    sequans的gpio驱动是采用platform方式注册的,这极大的方便了我们使用pm_stay_awake。

    现在实现过程贴上:

    主要修改gpio-sqn.c函数
申请三个全局变量:
struct device *yty_dev;//add by yty
struct work_struct *yty_work;//add by yty
struct timer_list buttons_timer;//add by yty


在sqn_gpio_probe函数中增加:
yty_dev = &pdev->dev;//add by yty
device_init_wakeup(yty_dev, true);
yty_work = kmalloc(sizeof(struct work_struct),GFP_KERNEL);
INIT_WORK(yty_work, work_func);
init_timer(&buttons_timer);
buttons_timer.function = buttons_timer_function;
add_timer(&buttons_timer);


实现work_func和buttongs_timer_function函数
void work_func(struct work_struct *work)
{
    mod_timer(&buttons_timer, jiffies + (HZ * 60)); //超时时间60s
}


void buttons_timer_function(unsigned long data)  
{
printk("timer is working\n");
pm_relax(yty_dev);//超时后便释放,此时便可以再次进入休眠。
}


注意:LTE开启时,设备是不会休眠的。所以,在前面,我们有及时关闭LTE.

中断中是不可以有延迟或者阻塞的,否则会造成系统崩溃。中断中,我们pm_stay_awake,使的设备不立即进入休眠,这个相应是非常快的。在中断中,我们注册一个工作队列,这个工作队列就是要实现定时器超时后,释放这个“锁”,让系统可以重新休眠。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值