All of lore.kernel.org
 help / color / mirror / Atom feed
* Altivec and binary compatibility
@ 2000-02-04 10:29 Adrian Cox
  2000-02-07 15:11 ` Giuliano Pochini
  0 siblings, 1 reply; 7+ messages in thread
From: Adrian Cox @ 2000-02-04 10:29 UTC (permalink / raw)
  To: LinuxPPC-Dev, Debian PowerPC


Altivec raises an interesting question of binary compatibility, in the
area of C++ exceptions and \x03C setjmp/longjmp.

As the jmp_buf is a different size in Altivec and non-Altivec code, it
is not possible to jump or pass exceptions between the two. This is a
problem, because:
1) Now would not be a good time to change the size of a jmp_buf.
2) We do not need two incompatible 32-bit PowerPC ABIs under Linux.
2a) Most libraries installed by a distribution will be non-Altivec code,
to avoid having both G[123] and G4 binary variants of the distribution.

To add to the problem, throwing exceptions on an error is just what a
modern C++ library is supposed to do.  Throwing or catching an exception
in Altivec code will produce sequences that cannot execute on a G3
(which is precisely what got me considering this).

Does anybody have any bright ideas, beyond ensuring that everybody
restricts the use of Altivec compilation to routines which only call
safe functions? As long as Altivec code requires the vector keyword,
that's probably a reasonable assumption.

- Adrian Cox, AG Electronics

** Sent via the linuxppc-dev mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2000-02-20 16:00 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2000-02-04 10:29 Altivec and binary compatibility Adrian Cox
2000-02-07 15:11 ` Giuliano Pochini
2000-02-07 18:06   ` Adrian Cox
2000-02-08 20:11     ` Giuliano Pochini
2000-02-11  9:41       ` Adrian Cox
     [not found]     ` <v03010d02b4cce4346bac@[192.168.1.16]>
     [not found]       ` <38A7D0FD.D6A7E95D@agelectronics.co.uk>
2000-02-20  1:18         ` Giuliano Pochini
2000-02-20 16:00         ` Giuliano Pochini

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.