From owner-freebsd-current Mon Jun 1 09:17:54 1998 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id JAA04925 for freebsd-current-outgoing; Mon, 1 Jun 1998 09:17:54 -0700 (PDT) (envelope-from owner-freebsd-current@FreeBSD.ORG) Received: from antipodes.cdrom.com (castles228.castles.com [208.214.165.228]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id JAA04918 for ; Mon, 1 Jun 1998 09:17:50 -0700 (PDT) (envelope-from mike@antipodes.cdrom.com) Received: from antipodes.cdrom.com (localhost [127.0.0.1]) by antipodes.cdrom.com (8.8.8/8.8.5) with ESMTP id IAA17888; Mon, 1 Jun 1998 08:13:18 -0700 (PDT) Message-Id: <199806011513.IAA17888@antipodes.cdrom.com> X-Mailer: exmh version 2.0zeta 7/24/97 To: Joerg Schilling cc: mike@smith.net.au, freebsd-current@FreeBSD.ORG Subject: Re: cdrecord trouble on currnet In-reply-to: Your message of "Mon, 01 Jun 1998 14:15:43 +0200." <199806011215.OAA16994@sherwood.gmd.de> Mime-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Date: Mon, 01 Jun 1998 08:13:18 -0700 From: Mike Smith Content-Transfer-Encoding: 8bit X-MIME-Autoconverted: from quoted-printable to 8bit by hub.freebsd.org id JAA04920 Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG > >From mike@dingo.cdrom.com Fri May 29 22:41:20 1998 > > >It's due to not checking the return value from the sysconf(_SC_PAGESIZE) > >in fifo.c. Once you get past that, there's a timing failure between the > >writer and reader processes due to a similar omission a little further > >down the file. > > >Having dealt with these, I seem to be dummy-burning quite happily. = > >I'll cut a disc for real to be sure, and then send you my patches for = > >discussion. > > This seems to be the real problem with freebsd-current. There do not seem to be any other operational problems, no. The weekend intervened before I could complete checking against your error handling suggestions; I'll finish that this morning. > You cannot deal with this problem: > > Systems that define _SC_PAGESIZE or _SC_PAGE_SIZE (HP-UX) > don't support getpagesize() so there is no way to fix this > in runtime except if you introduce an additional > > HAVE_GETPAGESIZE > > in the autoconfiguration. > > But even then the code would be badly readable. This is a problem with the design of cdrecord, insofar as it's fairly clear it wasn't designed for portability. Probably the most expedient move would be not to pretend that cdrecord is compliant with the default POSIX API on FreeBSD for now, and wind back the presented API to one that it is. That's what _POSIX_VERSION is all about. Thanks for the HP-UX pointer; I'll take note that _SC_PAGESIZE is implicitly assumed to mean DONT_HAVE_GETPAGESIZE. > I would prefer if the sysconf code would call getpagesize() in userland. This would defeat the entire purpose of sysconf(), which is to pass opaque constants to the kernel. I don't see any merit in hacking a perfectly compliant interface to deal with (pardon my saying it) buggy applications. -- \\ Sometimes you're ahead, \\ Mike Smith \\ sometimes you're behind. \\ mike@smith.net.au \\ The race is long, and in the \\ msmith@freebsd.org \\ end it's only with yourself. \\ msmith@cdrom.com To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message