return ERESTARTSYS 作用

 

ERESTARTSYS is a part of the api between the driver and the 
signal-handling code in the kernel. It does not reach user-space (provided 
of course that it's used appropriately in the drivers :) 

When a driver needs to wait, and get awoken by a signal (as opposed to 
what it's really waiting for) the driver should in most cases abort the 
system call so the signal handler can be run (like, you push ctrl-c while 
running somethinig that's stuck in a wait for an interrupt). The kernel 
uses the ERESTARTSYS as a "magic" value saying it's ok to restart the 
system call automagically after the signal handling is done. The actual 
return-code is switched to EINTR if the system call could not be 
restarted. 

 

当进程在内核里,信号到来时先运行信号处理函数,接着继续运行内核程序。

驱动程序里如下这样使用:wait_event_interruptible()使进程睡眠,如果进程是被信号唤醒,则先执行信号处理函数,再接着重新执行驱动程序。

 

 28          wait_event_interruptible(wq,flag);

 29         if(signal_pending(current))

 30         {

 31                 printk(KERN_ALERT "process %s is waked by signal/n");

 32                 return -ERESTARTSYS;

 33         }

 

 

 

应用程序测试如下,利用时钟信号。

 

  8   static void sig_alrm(int signo)

  9  {

 10         printf("alrm time is over/n");

 11 }

 

 16   if(signal(SIGALRM,sig_alrm) == SIG_ERR)

 17  {

 18         printf("initial alrm clock error/n");

 19  }

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在下面这段代码中,哪些内容实现了同步读写:// 读写函数 static ssize_t finaldemo_read(struct file *filp,char *buf,size_t len,loff_t *off) { if(wait_event_interruptible(finaldemo.outq,finaldemo.flag!=0)) //不可读时 阻塞读进程 { return -ERESTARTSYS; } if(down_interruptible(&finaldemo.sem)) //P 操作 { return -ERESTARTSYS; } finaldemo.flag = 0; printk("into the read function\n"); printk("the rd is %c\n",finaldemo.rd); //读指针 if(finaldemo.rd < finaldemo.wr) len = min(len,(size_t)(finaldemo.wr - finaldemo.rd)); //更新读写长度 else len = min(len,(size_t)(finaldemo.end - finaldemo.rd)); printk("the len is %d\n",len); if(raw_copy_to_user(buf,finaldemo.rd,len)) { printk(KERN_ALERT"copy failed\n"); / up递增信号量的值,并唤醒所有正在等待信号量转为可用状态的进程。 必须小心使用信号量。被信号量保护的数据必须是定义清晰的,并且存取这些数据的所有代码都必须首先获得信号量。 */ up(&finaldemo.sem); return -EFAULT; } printk("the read buffer is %s\n",finaldemo.buffer); finaldemo.rd = finaldemo.rd + len; if(finaldemo.rd == finaldemo.end) finaldemo.rd = finaldemo.buffer; //字符缓冲区循环 up(&finaldemo.sem); //V 操作 return len; } static ssize_t finaldemo_write(struct file *filp,const char *buf,size_t len,loff_t *off) { if(down_interruptible(&finaldemo.sem)) //P 操作 { return -ERESTARTSYS; } while(spacefree(&finaldemo) == 0) //检查剩余空间 { up(&finaldemo.sem); //释放信号量 if(filp->f_flags & O_NONBLOCK) return -EAGAIN; if(wait_event_interruptible(finaldemo.inq,(spacefree(&finaldemo) > 0))) return -ERESTARTSYS; if(down_interruptible(&finaldemo.sem)) return -ERESTARTSYS; } if(finaldemo.rd <= finaldemo.wr) len = min(len,(size_t)(finaldemo.end - finaldemo.wr)); else len = min(len,(size_t)(finaldemo.rd-finaldemo.wr-1)); printk("the write len is %d\n",len); if(raw_copy_from_user(finaldemo.wr,buf,len)) { up(&finaldemo.sem); //V 操作 return -EFAULT; } printk("the write buffer is %s\n",finaldemo.buffer); printk("the len of buffer is %d\n",strlen(finaldemo.buffer)); finaldemo.wr = finaldemo.wr + len; if(finaldemo.wr == finaldemo.end) finaldemo.wr = finaldemo.buffer; //循环 up(&finaldemo.sem); //V 操作 finaldemo.flag=1; //条件成立,可以唤醒读进程 wake_up_interruptible(&finaldemo.outq); //唤醒读进程 return len; } module_init(finaldemo_init); module_exit(finaldemo_exit); MODULE_LICENSE("GPL");
最新发布
06-08

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值