From owner-freebsd-current Tue Oct 29 3:43: 8 2002 Delivered-To: freebsd-current@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 5CD2F37B401 for ; Tue, 29 Oct 2002 03:43:07 -0800 (PST) Received: from motgate4.mot.com (motgate4.mot.com [144.189.100.102]) by mx1.FreeBSD.org (Postfix) with ESMTP id D98D143E7B for ; Tue, 29 Oct 2002 03:43:06 -0800 (PST) (envelope-from rittle@latour.rsch.comm.mot.com) Received: from mothost.mot.com (mothost.mot.com [129.188.137.101]) by motgate4.mot.com (Motorola/Motgate4) with ESMTP id g9TBbwnM007364; Tue, 29 Oct 2002 04:37:59 -0700 (MST) Received: [from latour.rsch.comm.mot.com (latour.rsch.comm.mot.com [145.1.80.116]) by mothost.mot.com (MOT-pobox 2.0) with ESMTP id EAA00436; Tue, 29 Oct 2002 04:37:58 -0700 (MST)] Received: from latour.rsch.comm.mot.com (localhost.rsch.comm.mot.com [127.0.0.1]) by latour.rsch.comm.mot.com (8.12.6/8.12.6) with ESMTP id g9TBbwpZ074454; Tue, 29 Oct 2002 05:37:58 -0600 (CST) (envelope-from rittle@latour.rsch.comm.mot.com) Received: (from rittle@localhost) by latour.rsch.comm.mot.com (8.12.6/8.12.6/Submit) id g9TBbvl0074453; Tue, 29 Oct 2002 05:37:57 -0600 (CST) Date: Tue, 29 Oct 2002 05:37:57 -0600 (CST) From: Loren James Rittle Message-Id: <200210291137.g9TBbvl0074453@latour.rsch.comm.mot.com> To: current@freebsd.org Subject: Re: Lack of real long double support In-Reply-To: <20021028.214057.108404482.imp@bsdimp.com> References: <200210290211.g9T2BBcP010112@latour.rsch.comm.mot.com> Organization: Networks and Infrastructure Lab (IL02/2240), Motorola Labs Cc: imp@bsdimp.com Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG In article <20021028.214057.108404482.imp@bsdimp.com> imp writes: > This works. I'm not sure why this isn't the default. It looks like > we have hacks in the local tree to do this, which is why I thought > that it worked great by default.... > This is true too. See the fpsetprec() call that I had to add to make > things work above. Yes, I know about that call. I conditionally added it to at least one gcc i386 FP test case that assumed 64-bit precision. However, the system header is suppose to reveal the FP hardware as it is configured not as some user could litter their code to make it so, no? > Yes. The standard didn't anticipate the fp hardware that intel made. C89, perhaps (although given the timing, I'm skeptical). C99, no way. > One could do something like: > > #define LDBL_EPSILON (fpgetprec() == FP_PE ? _LDBL_EPSILON : DBL_EPSILON) > > But as you said, this isn't a compile time constant. I'm not sure > that it would matter in any real context. I don't think that you can > do floating point in the preprocessor... This proposal isn't bad IMHO. It would clearly explain to the gcc team what type of FP support we'd want even if not in full compliance with the standard text. And, to avoid all compliance problems, perhaps: #if !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE) && !defined(__STRICT_ANSI__) // for i386, match default as expressed in __INITIAL_NPXCW__ #define LDBL_MANT_DIG 53 #define LDBL_EPSILON 2.2204460492503131E-16 [...] // changing LDBL_MANT_DIG subtly changes every value not just LDBL_EPSILON) #else // Assume something would have to be done to avoid including #define LDBL_MANT_DIG (fpgetprec() == FP_PE ? _LDBL_MANT_DIG : DBL_MANT_DIG) #define LDBL_EPSILON (fpgetprec() == FP_PE ? _LDBL_EPSILON : DBL_EPSILON) [...] #endif To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message