public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* EINTR vs ERESTARTSYS, ERESTARTSYS not defined
@ 2001-11-22 14:36 Phil Howard
  2001-11-22 15:15 ` Andreas Schwab
  2001-11-26 19:59 ` Alan Cox
  0 siblings, 2 replies; 5+ messages in thread
From: Phil Howard @ 2001-11-22 14:36 UTC (permalink / raw)
  To: linux-kernel

The accept() call does indeed return errno==ERESTARTSYS to user space
when coming back from signal handling, even though other things like
poll() return errno==EINTR.  This would not really be a problem except
for this in include/linux/errno.h starting at line 6:

+=============================================================================
| #ifdef __KERNEL__
| 
| /* Should never be seen by user programs */
| #define ERESTARTSYS     512
| #define ERESTARTNOINTR  513
| #define ERESTARTNOHAND  514     /* restart if no handler.. */
| #define ENOIOCTLCMD     515     /* No ioctl command */
+=============================================================================

So which way is it _supposed_ to be (so someone can patch things up
to make it consistent):

1.  User space should never see ERESTARTSYS from any system call

2.  ERESTARTSYS can be seen from system call and is defined somewhere

In user space I have to define __KERNEL__ to get programs to compile
when coded to know about all possible (valid?) values of errno from
system calls.  As seen from strace:

+=============================================================================
| [pid  6453] accept(5, 0xbffff908, [16]) = ? ERESTARTSYS (To be restarted)
| [pid  6453] --- SIGALRM (Alarm clock) ---
| [pid  6453] getppid()                   = 6452
| [pid  6453] gettimeofday({1006439405, 5879}, NULL) = 0
| [pid  6453] setitimer(ITIMER_REAL, {it_interval={0, 0}, it_value={9, 994121}}, NULL) = 0
| [pid  6453] rt_sigreturn(0x5)           = -1 EINTR (Interrupted system call)
| [pid  6453] accept(5, 0xbffff908, [16]) = ? ERESTARTSYS (To be restarted)
| [pid  6453] --- SIGALRM (Alarm clock) ---
| [pid  6453] getppid()                   = 6452
| [pid  6453] gettimeofday({1006439415, 6422}, NULL) = 0
| [pid  6453] setitimer(ITIMER_REAL, {it_interval={0, 0}, it_value={9, 993578}}, NULL) = 0
| [pid  6453] rt_sigreturn(0x5)           = -1 EINTR (Interrupted system call)
| [pid  6453] accept(5, 0xbffff908, [16]) = ? ERESTARTSYS (To be restarted)
+=============================================================================

-- 
-----------------------------------------------------------------
| Phil Howard - KA9WGN |   Dallas   | http://linuxhomepage.com/ |
| phil-nospam@ipal.net | Texas, USA | http://phil.ipal.org/     |
-----------------------------------------------------------------

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2001-11-26 19:52 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20011122083623.A18057@vega.ipal.net.suse.lists.linux.kernel>
2001-11-22 15:28 ` EINTR vs ERESTARTSYS, ERESTARTSYS not defined Andi Kleen
2001-11-22 14:36 Phil Howard
2001-11-22 15:15 ` Andreas Schwab
2001-11-22 18:05   ` Phil Howard
2001-11-26 19:59 ` Alan Cox

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox