之前一个项目上遇到一个问题是在特定的代码执行完毕后需要实现一个唤醒的动作,虽然这个问题后续没有用到休眠唤醒的动作,但是后续闲暇时间却针对这个问题来研究了一下。因为我们按下然后弹起power键实际上是可以实现休眠唤醒的,那就模拟按下和弹起的动作,主要就是上报KEY_POWER这个键值。
根据输入子系统的研究,上报键值需要依赖一定的输入设备,在无线程可用的输入设备的时候,只能自己注册一个输入设备。
#include
#include
#include
#include
#include
#include
static struct input_dev *my_dev;
static struct proc_dir_entry *my_proc;
static ssize_t write_proc(struct file *file,const char *buffer, size_t count, loff_t *ppos)
{
int my_status = 0;
int num = 0;
char temp[50]; // for store special format cmd
if (copy_from_user(temp, buffer, sizeof(temp))){
return -EFAULT;
}
num = sscanf(temp,"%d",&my_status);
if(num==1){
input_report_key(my_dev, KEY_POWER, 1);
input_sync(my_dev);
input_report_key(my_dev, KEY_POWER, 0);
input_sync(my_dev);
}
return sizeof(temp);// 返回0会不停的亮灭屏
}
static const struct file_operations test_proc = {
.write = write_proc,
};
static int test_init(void){
int err = 0;
my_dev = input_allocate_device();
my_dev->name = "feifei_dev";
input_set_capability(my_dev, EV_KEY, KEY_POWER);
err = input_register_device(my_dev);
if(err<0){
printk(" failed to register my input_dev
");
}
my_proc = proc_create("feifei_proc", 0666, NULL, &test_proc);
return 0;
}
static void test_exit(void){
return;
}
module_init(test_init);
module_exit(test_exit);
MODULE_LICENSE("GPL");