From owner-freebsd-current Mon Mar 6 11:12:10 2000 Delivered-To: freebsd-current@freebsd.org Received: from systemics.com (hayek.ai [209.88.68.42]) by hub.freebsd.org (Postfix) with ESMTP id 2CCA937C0F7 for ; Mon, 6 Mar 2000 11:12:04 -0800 (PST) (envelope-from iang@systemics.com) Received: (from iang@localhost) by systemics.com (8.9.3/8.9.1) id PAA75240; Mon, 6 Mar 2000 15:10:20 -0400 (AST) (envelope-from iang) Date: Mon, 6 Mar 2000 15:10:20 -0400 (AST) From: Ian Grigg Message-Id: <200003061910.PAA75240@systemics.com> To: phk@critter.freebsd.dk Subject: Re: [ID 20000306.004] unpack(NaN) big baddaboom Cc: current@FreeBSD.ORG, perl5-porters@perl.org Reply-To: iang@systemics.com Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG More on that! Lads here took this to heart and put the debugger over the code. Apparently, Linux uses glibc which sets the flags in FPU to ignore the cmp-NaN fault. Then, I guess, Perl picks it up and turns it into NaN. OTOH, FreeBSD libraries don't do that, and the FPU causes the cmp-NaN fault to cause a FP exception. (Recorded 2nd hand, you won't catch me using debuggers.) > That is because FreeBSD correctly traps operations on the value NaN. > > Depending on your religion the bug is either in perl itself which > should be more careful about NaN and Inf values, or in the perl > script you supply which does something which is patently bogus, > but nothing which should provoke a FP trap according to IEEE. I don't know much about religion, but this feels like a Perl bug to me. I feed a highlevel command a number I read off the wire, and it blows up. As I have no control over the wire (it's a network) I cannot *not* handle the number. > I would argue that as long as your perl script doesn't use the NaN > in an operation which IEEE documents as giving a trap ( compare of > two floats for ordered magnitude for instance) then your perl > interpreter shouldn't either. Well, in that sense, this is my workaround: my $data = $is->read(4); # # Damn, FreeBSD throws Floating Point Exception on NaN! # my $long = unpack("N", $data); if ($long == 2143289344) { return "NaN"; } So I'm fine with it for now. But, as Perl is an interpretive language, and they are supposed to, on some higher plain of thought, handle everything thrown at them, I'd rather it just returned "NaN" like Linux. Still, I'm fixed! Thanks for the confirmation. iang To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message