Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 20 Jan 2008 02:33:14 +0200
From:      Heikki Suonsivu <hsu@wlansystems.com>
To:        freebsd-hackers@freebsd.org
Subject:   FreeBSD on non-fpu device
Message-ID:  <479296CA.8000700@wlansystems.com>

next in thread | raw e-mail | index | archive | help
This is a multi-part message in MIME format.
--------------070307080101080101000206
Content-Type: text/plain; charset=ISO-8859-1; format=flowed
Content-Transfer-Encoding: 7bit

There is very low cost microscopic PC (see eBOX 2300 and eBOX 2300SX 
www.compactpc.com.tw), which previously run FreeBSD fine, being based on 
  Vortex86 cpu on Sis SoC chip 550.  Unfortunately the manufacturer 
switched to a new SoC cpu which is 486SX derivative without FPU.  This 
does not work with FreeBSD.

Why anyone would be interested?  The eBOX 2300SX cpu is a SoC device, 
which is by far the lowest power consumption I have seen, and this is 
probably cheapest computer on the market, still suitable for number of 
applications.  While it is not exactly a speed daemon, it works well 
enough for all kinds of mp3-playing, small servers and control applications.

Linux is known to work but also requires extra drivers and possibly some 
patches, and apparently most current distributions do not have math 
emulation on by default.

FreeBSD 4.11 install CD does boot on this thing, and might work, but 
failed to detect neither the ethernet nor external USB DVD drive I was 
using for install, so I would not go forward on actually getting the OS 
to the hard disk.

Now, I was wondering if FreeBSD could be actually run on these things, 
by compiling the kernel and world with -msoft-float CFLAGS on another 
computer?  This might work iff:

- there is no assembly code utilizing fpu instructions.

- there is nothing in the world requiring some other compilers than gcc, 
  or compilers without -msoft-float option.  However, I am under 
assumption that all the world is compiled with gcc?  It may be necessary 
to change calling conventions as well, that might break other other things.

- Possibly -mno-fp-ret-in-387 may be needed - any experiences?

Now, has anyone ever tried this?  Is this hopeless?  What goes wrong?

Alternatively, porting MATH_EMULATE back from NetBSD etc might be an 
option, but might be a larger task, and apparently NetBSD math emulation 
did not work out of box either (seems to be a cpu detection bug, based 
on mailing list discussions).

There are other issues with the device, drivers etc, but that is less 
problematic.

We can donate hardware to someone who wants to have a go on getting this 
device running FreeBSD.

Heikki Suonsivu
bbnetworks.net


--------------070307080101080101000206--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?479296CA.8000700>