Subject: Re: optimising for different 680x0 (Was: Config understandings)
To: Ignatios Souvatzis <is@beverly.kleinbus.org>
From: David Brownlee <abs@netbsd.org>
List: port-amiga
Date: 10/18/2000 08:20:27
	The i386 port compiles two versions of libm, one with hardware
	floating point and one software. ld.elf_so selects the right
	one for dynamic programs automatically based on the
	machdep.fpu_present sysctl and a config line in /etc/ld.so.conf:
	"libm.so.0       machdep.fpu_present     1:libm387.so.0,libm.so.0"

	Would there be any sense in doing something similar for m68k
	ports? Obviously it doesn't help static programs, but most of
	those should not have any significant FPU usage...

                David/absolute
			       -- www.netbsd.org: A pmap for every occasion --


On Tue, 17 Oct 2000, Ignatios Souvatzis wrote:

> On Tue, Oct 17, 2000 at 02:20:12AM -0400, John Klos wrote:
> > IS wrote:
>
> > > M68060=YES in /etc/mk.conf chooses a different libm to be built, and also
> > > influences some of the big number aritmetic routines used by the ssh and
> > > pgp packages.
>
> > So you put the tuna WITH the mayo...
>
> Sort of. Now, that I slept enough for two nights in a row, I can even remember
> to explain why: Normal assembler-language bignum  routines for m68k like to use
> the 32x32->64bit multiplication of m680[234]0, which was removed on the M68060
> and causes a kernel trap. The compiler avoids it when -m68060 or -m68020-60
> is given, but of course it has no idea that it should use different assembler
> files (or none at all). Similar stuff happens when you use some floating point
> routines that are written with the 6888[12] FPU in mind; they are trap-emulated
> on 68040 and 68060, and using a specialized libm helps a lot here in some
> cases.