Date: Sun, 10 Oct 1999 21:36:05 -0700 (PDT) From: Alfred Perlstein <bright@wintelcom.net> To: Zhihui Zhang <zzhang@cs.binghamton.edu> Cc: freebsd-hackers@FreeBSD.ORG Subject: Re: How to prevent a system call from restart? Message-ID: <Pine.BSF.4.05.9910102134440.8080-100000@fw.wintelcom.net> In-Reply-To: <Pine.GSO.3.96.991010150931.28616A-100000@sol.cs.binghamton.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, 10 Oct 1999, Zhihui Zhang wrote:
>
> I modify the day time client program from the Stevens' book and run it on
> both a Sun workstation and a FreeBSD machine. In the program, I use
> signal() and alarm() to set a 5 seconds timeout. The program works as
> expected on Sun (after I comment out the daytime line in the file
> /etc/inetd.conf) but not on the FreeBSD machine.
>
> Later I find out that the reason maybe the recvfrom() restarts
> *automatically* in FreeBSD. Why the default behaviour is different from
> SunOS? If I am correct about the reason, can anyone tell me how to prevent
> the recvfrom() from restart after receiving the SIGALRM signal?
>
> By the way, I also try the socket timeout option. It works immediately.
>
> Any help is appreciated.
from sigaction's manpage:
If a signal is caught during the system calls listed below, the call may
be forced to terminate with the error EINTR, the call may return with a
data transfer shorter than requested, or the call may be restarted.
Restart of pending calls is requested by setting the SA_RESTART bit in
sa_flags. The affected system calls include open(2), read(2), write(2),
sendto(2), recvfrom(2), sendmsg(2) and recvmsg(2) on a communications
channel or a slow device (such as a terminal, but not a regular file) and
during a wait(2) or ioctl(2). However, calls that have already committed
are not restarted, but instead return a partial success (for example, a
short read count).
you want to turn off SA_RESTART.
-Alfred Perlstein - [bright@rush.net|alfred@freebsd.org]
Wintelcom systems administrator and programmer
- http://www.wintelcom.net/ [bright@wintelcom.net]
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.BSF.4.05.9910102134440.8080-100000>
