From owner-freebsd-hackers@FreeBSD.ORG Thu Nov 13 03:54:00 2003 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 7080E16A4CE for ; Thu, 13 Nov 2003 03:54:00 -0800 (PST) Received: from razorbill.mail.pas.earthlink.net (razorbill.mail.pas.earthlink.net [207.217.121.248]) by mx1.FreeBSD.org (Postfix) with ESMTP id 9DEE543FDD for ; Thu, 13 Nov 2003 03:53:59 -0800 (PST) (envelope-from tlambert2@mindspring.com) Received: from user-2ivfmpo.dialup.mindspring.com ([165.247.219.56] helo=mindspring.com) by razorbill.mail.pas.earthlink.net with asmtp (SSLv3:RC4-MD5:128) (Exim 3.33 #1) id 1AKG2r-0005Dk-00; Thu, 13 Nov 2003 03:53:54 -0800 Message-ID: <3FB36EA2.6318962F@mindspring.com> Date: Thu, 13 Nov 2003 03:44:34 -0800 From: Terry Lambert X-Mailer: Mozilla 4.79 [en] (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: Jaromir Dolecek References: <200311120858.hAC8wFfg001905@s102-n054.tele2.cz> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit X-ELNK-Trace: b1a02af9316fbb217a47c185c03b154d40683398e744b8a4b16d4a9357fb6aaa68407555f39f83ca93caf27dac41a8fd350badd9bab72f9c350badd9bab72f9c cc: freebsd-hackers@freebsd.org cc: tech-kern@NetBSD.org cc: hackers@openbsd.org cc: marius@monkey.org cc: Niels Provos Subject: Re: kqueue, NOTE_EOF X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 13 Nov 2003 11:54:00 -0000 Jaromir Dolecek wrote: > marius aamodt eriksen wrote: > > in order to be able to preserve consistent semantics across poll, > > select, and kqueue (EVFILT_READ), i propose the following change: on > > EVFILT_READ, add an fflag NOTE_EOF which will return when the file > > pointer *is* at the end of the file (effectively always returning on > > EVFILT_READ, but setting the NOTE_EOF flag when it is at the end). > > > > specifically, this allows libevent[1] to behave consistently across > > underlying polling infrastructures (this has become a practical > > issue). > > I'm not sure I understand what is the exact issue. > > Why would this be necessary or what does this exactly solve? AFAIK > poll() doesn't set any flags in this case neither, so I don't > see how this is inconsistent. > > BTW, shouldn't the EOF flag be cleared when the file is extended? It solves the half-close-on-socket issue which occurs on an HTTP/1.0 request or an HTTP/1.1 non-pipelined/terminal request that occurs on most HTTP connections as a result of the client closing their side of the socket connection, but the server being expected to provide a response to the request on the same socket. You need this to be able to distinguish, after getting an EOF, if you need to provide a response to the request, or you need to drop it, based on additional processing you choose to do in your application. Doing it this way saves you 33%, 50%, or 66% of the required system calls to detect the edge conditions, depending on your I/O model and when they hit. It is useful for HTTP servers, HTTP Proxy servers, L7 load balancers, load balancers that implement Direct Server Return for requests, and in a number of other common cases having to do with networking (e.g. transcoding proxies for cell phones or other users requiring it, FTP control vs. data channels in the non-passive case, ssh/rcmd/etc., as just a couple of select examples). I rather expect that it would be singularly useless for socketpair(), pipe(), named pipe (FIFO), or file operations, but that's not what we are talking about when we talk about event libraries that deal with input sources/sinks. -- Terry