Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 13 Jan 2003 12:24:31 -0800
From:      Terry Lambert <tlambert2@mindspring.com>
To:        Bruce Evans <bde@zeta.org.au>
Cc:        Marcel Moolenaar <marcel@xcllnt.net>, Jake Burkholder <jake@locore.ca>, sparc@FreeBSD.ORG, current@FreeBSD.ORG
Subject:   Re: [PATCH] Re: fpsetmask on sparc64
Message-ID:  <3E23207F.A889A410@mindspring.com>
References:  <20030113190710.I11541-100000@gamplex.bde.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Bruce Evans wrote:
> The prototypes are machine-independent, so they are correctly placed
> in <ieeefp.h>.  This has the technical problem that it is difficult
> to implement declared functions as inlines (*), so we use an ugly
> i386 ifdef in <ieefp.h> to prevent them being declared.

In fact, this is exactly the problem.

The correct thing to do is to ensure that the values come into scope
at the same level in all implementations.

Effectively, this means that the #define's for the i386 version's
inline references need to be at the same level as the prototype
declarations.

Where the prototype declatations take place is actually moot.


> This seems least evil since inlining them doesn't seem to be useful
> and the wart only affects i386's, and these functions should be
> obsoleted by the C99 functions as soon as possible.

I think it is better to fully adhere to an old standard than to
partially adhere to a new one.  FreeBSD was much better off, in
terms of software portability, when it supported the full Draft 4
pthreads standard (both Jeremy Allison and I had a hand in the
final work of making it conform), than it was when it was in
partial conformance to the new standard.

Whether or not inlining them should be ripped out in favor of real
library routines, as in OpenBSD and NetBSD, is another matter, and,
as far as I'm concerned, that's off the table for discussion at
this point.  I'm unwilling to change implementation this late in the
game, only organization.

No matter how you look at it, the code should be organized such
that including the same header files, *whatever* they are, ends up
with the same results on all flavors of FreeBSD.  Riht now, that
does not happen.

Both of the proposed patches fix this.

Another way of fixing this would be to move the #define's for the
inline versions *up* into /usr/include/ieeefp.h, so that the scope
comes from there.

This is consistant with your suggestion here.

There are two reason to not do this, at this point:

1)	It will cause some ports to be broken; arguably, these
	ports *should* be broken.  But when you complain about
	them, you are really complaining that the <machine/XXX.h>
	scope is visible to user programs directly, instead of
	forcing them to include the correct header files, instead.

	I think this complaint should be addressed in the compiler,
	and can be, by having a #pragma that maches the directory
	visible to the compiler, with the default being invisible,
	and the regular headers can set the #pragma, and third
	party code can break.

	I would argue that, whatever you do to address the complaint,
	however, you address it *later*.

2)	This approach has the negative effect of leaving platform
	variant code in a system header file.  This is, in my
	opinion, and incredibly broken thing to do, even if you
	ignore all other issues.

	If you are dead set on this approach, I can provide a patch
	that will move the i386 #define's from <machine/floatingpoint.h>
	up into <ieeefp.h>; but I believe this is bad design at its
	worst.



> > Since on i386 <machine/floatingpoint.h>
> > also includes <machine/ieeefp.h>, we should be able to move
> > the implementation on i386 to <machine/ieeefp.h> as well. If
> > possible, I'd like to see <machine/floatingpoint.h> retired
> > unless there's a compelling reason to keep it...
> 
> There is no good reason for these to be separate, but they may be
> required for compatibility.  IIRC, their names and interfaces were
> copied from some system (Sun) that had them, but they were slightly
> misplaced (<machine> is a BSDism AFAIK so other systems couldn't have
> anything there)...  According to google, <floatingpoint.h> was in
> /usr/include in SunOS in 1992 (we link it there), and it seems to
> be the primary interface (Sun apparently had ieeefp.h in <sys> then,
> but non-BSD hits on it are not as common.

I agree that floatingpoint.h is probably something that should
gracefully fall into compatability, in terms of a message that
says "deprecated; include XXX instead"; FreeBSD already has a
number of these.  But in any case, this is not really a functional
issue, and I really don't care about it.  8-).


> - Applications can easily shoot there feet off by stepping into this header
>   tangle in any place except the one that is actually docuemented under
>   FreeBSD.

This is the case as it is today.

The patches I have proposed, both reattach the feet of a number
of application in ports, based on them already having stepped in
this mine field.

I think it's not reasonable to believe that you can make people
rewrite all the old code in the world to conform to new standards
(e.g. C99, etc.).  Basically, this means to me that a successful
standard is not one which tries to change how things are done,
but instead permits legacy code to continue to function.

This *also* argues for pushing the declaration scope for these
things down, instead of pulling them up into the (supposedly)
machine independent headers.

-- Terry

To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3E23207F.A889A410>