__aeabi_read_tp missing symbol
Olivier Houchard
mlfbsd at ci0.org
Tue Feb 27 11:49:08 UTC 2007
Hi Pascal,
On Tue, Feb 27, 2007 at 09:37:27AM +0100, Pascal Hofstee wrote:
> Hi,
>
> I just finished writing a small application for my job on FreeBSD/i386
> making sure everything compiles WARNS=9 clean. Now comes the task to
> move this code over to our embedded platform which is an Intel XScale
> (Linksys NSLU2) at the moment i have not been able to test out cognet@'s
> FreeBSD/arm work yet .. so we're using a Linux (Debian/Etch) to do our
> embedded development on, so i apologise if this tunrs out to be a Linux
> problem and i am asking the wrong people for assistence :)
>
> The problem i am encountering is that during the link stage i get a lot
> of the following link errors:
>
> datastream.o: In function `deleteSynchronisedData':
> ...../datastream.c:909: undefined reference to `__aeabi_read_tp'
>
Yes it is definitively a linux problem :-)
See below.
> Googling so far has taught me that this is GCC's work and well the
> following:
>
> `-mtp=NAME'
> Specify the access model for the thread local storage pointer.
> The valid models are `soft', which generates calls to
> `__aeabi_read_tp', `cp15', which fetches the thread pointer from
> `cp15' directly (supported in the arm6k architecture), and `auto',
> which uses the best available method for the selected processor.
> The default setting is `auto'.
>
> Obviously GCC is of the opinion that it should use the "soft" access model for
> thread local storage (which i am indeed using a lot in this source file). But
> somehow the link stage fails to find these symbols.
>
> Where should these symbols be coming from normally and how would i go about
> fixing my link stage ... It seems as if the compiler is of the opinion that
> TLS is supported.
>
> Once again i know this is currently on a Linux platform but i have much bigger
> trust in the FreeBSD community to provide sensible answers in this regard.
>
Latest revisions of gcc/binutils have support for TLS. And using EABI is the
right thing to do on linux. You're just using the wrong libc, eabi_read_tp and
friends come from the glibc. If changing your glibc is not an option, you'll
have to play with -mabi, and set it to something else than eabi, however if
you need TLS I think you're doomed with this version of gcc, you'll have to
find a matching glibc.
I could be wrong on this one, I'm not a linux/arm specialist.
Cheers,
Olivier
> --
> Pascal Hofstee
>
> _______________________________________________
> freebsd-arm at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-arm
> To unsubscribe, send any mail to "freebsd-arm-unsubscribe at freebsd.org"
More information about the freebsd-arm
mailing list