From owner-cvs-src@FreeBSD.ORG Fri Mar 7 02:57:16 2008 Return-Path: Delivered-To: cvs-src@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 998A01065673; Fri, 7 Mar 2008 02:57:16 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from mail34.syd.optusnet.com.au (mail34.syd.optusnet.com.au [211.29.133.218]) by mx1.freebsd.org (Postfix) with ESMTP id 307308FC22; Fri, 7 Mar 2008 02:57:15 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from c220-239-252-11.carlnfd3.nsw.optusnet.com.au (c220-239-252-11.carlnfd3.nsw.optusnet.com.au [220.239.252.11]) by mail34.syd.optusnet.com.au (8.13.1/8.13.1) with ESMTP id m272vBm2029737 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Fri, 7 Mar 2008 13:57:13 +1100 Date: Fri, 7 Mar 2008 13:57:11 +1100 (EST) From: Bruce Evans X-X-Sender: bde@delplex.bde.org To: David Schultz In-Reply-To: <20080306021222.GA46783@zim.MIT.EDU> Message-ID: <20080307125559.M11320@delplex.bde.org> References: <200803051121.m25BLE03035426@repoman.freebsd.org> <20080305182531.GS68971@server.vk2pj.dyndns.org> <20080306021222.GA46783@zim.MIT.EDU> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: src-committers@freebsd.org, Peter Jeremy , cvs-all@freebsd.org, Bruce Evans , Colin Percival , cvs-src@freebsd.org Subject: Re: cvs commit: src/sys/i386/include _types.h X-BeenThere: cvs-src@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: CVS commit messages for the src tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 07 Mar 2008 02:57:16 -0000 On Wed, 5 Mar 2008, David Schultz wrote: > On Wed, Mar 05, 2008, Colin Percival wrote: >> Bruce Evans wrote: >>> Modified files: >>> sys/i386/include _types.h >>> Log: >>> Change float_t and double_t to long double on i386. >> >> Doesn't this have a rather severe performance impact on any code which >> uses double_t? > > Yes, if the code is compiled with -msse2. Otherwise, doubles get > fed to the i387 anyway. Not even then. Doubles get fed to the i387 anyway in many cases (in most cases I think). One exception is double to int conversion -- this uses SSE2 so as to avoid a slow mode switch (cvtsd2si always rounds towards 0, while the default i386 mode rounds to nearest; otherwise it would be the SSE code that is slower). Adds of doubles normally go through the i387 (I've never seen an exception to this). > Technically Bruce's change isn't wrong without changing the > default precision, it's just rather pointless. It isn't pointless, since the default is only the default. Changing it using fpsetprec() has been supported in FreeBSD since 1993, and before that it required 2 lines of asm. My change gives double_t a chance of working right when the default is changed at runtime. While such changes are not really supported, there is no need to force them to be broken. > (Why tell programs > to store variables in a wider format if you're just going to > evaluate them in a narrower format anyway?) After fpsetprec(FP_PE): (1) the evaluation is not in a narrower format. (2) I use double_t when I hope that the variable will stay in a register and not cost a store (3) when I store to a double, it is obviously narrower on i386, and the compiler is tricked into doing the store correctly without using something like STRICT_ASSIGN(). STRICT_ASSIGN() uses a volatile hack which makes it potentially slower than an ordinary assignment, and currently doesn't support this mode. Irrespective of fpsetprec(FP_PE): (1)' - (3)' for float_t vs float precision. float_t just needs to be double for this. Using long double costs little and is technically half required even with the default precision, since the range is almost that of a long double. (The different range affects at least overflow exceptions.) (3)'' I can write code that is more portable and don't need to pessimize all uses of STRICT_ALIGN() on doubles by supporting full long double precision everywhere. Code that supports extra precision (either by a runtime switch or a change in the default) can use double_t and code that doesn't care or doesn't understand the complications can keep using plain double. > So I guess I agree > that if we're going to go down this path, we ought to just bite > the bullet and change npx.h and contrib/gcc/config/i386/freebsd.h > to use 64-bit precision by default on i386. I hope to do that in a non-revolutionary way. Bruce