[PATCH] libdl.c: static link fail for mips
Vincent Wen
wenvincent90 at gmail.com
Mon Apr 1 17:08:51 UTC 2013
Bernhard,
I sent the following patch to uClibc mailing list, according to your
previous suggestion. Please let me know if there's problem.
>From 0a0ff0a2528e08cce4179c6c3a2f6ee751d84c83 Mon Sep 17 00:00:00 2001
From: Vincent Wen <wenvincent90 at gmail.com>
Date: Mon, 1 Apr 2013 09:57:00 -0700
Subject: [PATCH] libdl.c: Static link fails on MIPS platform.
When build statically linked applications for MIPS platform,
sometimes the linker fails with following errors:
undefined reference to TLS_DTPREL_VALUE
undefined reference to TLS_TPREL_VALUE
The include of dl-tls.h is only in code guarded by SHARED,
Removing the SHARED compilation option to cover static link too.
Signed-off-by: Vincent Wen <wenvincent90 at gmail.com>
---
ldso/libdl/libdl.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/ldso/libdl/libdl.c b/ldso/libdl/libdl.c
index 4630a59..565c241 100644
--- a/ldso/libdl/libdl.c
+++ b/ldso/libdl/libdl.c
@@ -42,6 +42,7 @@
#if defined(USE_TLS) && USE_TLS
#include <ldsodefs.h>
+# include <dl-tls.h>
extern void _dl_add_to_slotinfo(struct link_map *l);
#endif
@@ -51,7 +52,6 @@ __UCLIBC_MUTEX_STATIC(_dl_mutex,
PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP);
#ifdef SHARED
# if defined(USE_TLS) && USE_TLS
-# include <dl-tls.h>
extern struct link_map *_dl_update_slotinfo(unsigned long int req_modid);
# endif
--
1.7.9.1.g8d994
Thanks,
Vincent
On Fri, Mar 29, 2013 at 10:56 AM, Vincent Wen <wenvincent90 at gmail.com> wrote:
> I am not sure what mean legitimately use DTPREL. When we build static
> link on our application, the linker breaks due to this undefined
> reference.
>
> I can re-submit the patch as you suggest as following.
>
> Thanks,
>
> Vincent
>
>
> diff --git a/ldso/libdl/libdl.c b/ldso/libdl/libdl.c
> index 71ade1f..385500a 100644
> --- a/ldso/libdl/libdl.c
> +++ b/ldso/libdl/libdl.c
> @@ -41,8 +41,9 @@
> #endif
>
> #if defined(USE_TLS) && USE_TLS
> -#include <ldsodefs.h>
> +# include <ldsodefs.h>
> extern void _dl_add_to_slotinfo(struct link_map *l);
> +# include <dl-tls.h>
> #endif
>
> /* TODO: get rid of global lock and use more finegrained locking, or
> @@ -51,7 +52,6 @@ __UCLIBC_MUTEX_STATIC(_dl_
> mutex,
> PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP);
>
> #ifdef SHARED
> # if defined(USE_TLS) && USE_TLS
> -# include <dl-tls.h>
> extern struct link_map *_dl_update_slotinfo(unsigned long int req_modid);
> # endif
>
>
> On Fri, Mar 29, 2013 at 4:52 AM, Bernhard Reutner-Fischer
> <rep.dot.nop at gmail.com> wrote:
>> On 23 February 2013 10:48, Bernhard Reutner-Fischer
>> <rep.dot.nop at gmail.com> wrote:
>>> On Fri, Feb 22, 2013 at 02:06:43PM -0800, Vincent Wen wrote:
>>>>When build statically linked applications for MIPS platform,
>>>>sometimes the linker fails with following errors:
>>>>undefined reference to TLS_DTPREL_VALUE
>>>>undefined reference to TLS_TPREL_VALUE
>>>
>>> I still suspect that these uses may need a SHARED guard, no?
>>
>> Would any static linkage legitimately use DTPREL?
>>>
>>>>The include of dl-tls.h is defined for shared library build.
>>>>Removing the SHARED compilation option to cover static link too.
>>>
>>> Otherwise this would be ok, yes.
>>> Can you have a look, please?
>>
>> If anything, this should be
>>
>> diff --git a/ldso/libdl/libdl.c b/ldso/libdl/libdl.c
>> index 71ade1f..385500a 100644
>> --- a/ldso/libdl/libdl.c
>> +++ b/ldso/libdl/libdl.c
>> @@ -41,8 +41,9 @@
>> #endif
>>
>> #if defined(USE_TLS) && USE_TLS
>> -#include <ldsodefs.h>
>> +# include <ldsodefs.h>
>> extern void _dl_add_to_slotinfo(struct link_map *l);
>> +# include <dl-tls.h>
>> #endif
>>
>> /* TODO: get rid of global lock and use more finegrained locking, or
>> @@ -51,7 +52,6 @@ __UCLIBC_MUTEX_STATIC(_dl_mutex,
>> PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP);
>>
>> #ifdef SHARED
>> # if defined(USE_TLS) && USE_TLS
>> -# include <dl-tls.h>
>> extern struct link_map *_dl_update_slotinfo(unsigned long int req_modid);
>> # endif
>>
>> thanks,
>>> TIA,
>>>>
>>>>Signed-off-by: Vincent Wen <wenvincent90 at gmail.com>
>>>>---
>>>> ldso/libdl/libdl.c | 5 ++++-
>>>> 1 files changed, 4 insertions(+), 1 deletions(-)
>>>>
>>>>diff --git a/ldso/libdl/libdl.c b/ldso/libdl/libdl.c
>>>>index 2337223..5172754 100644
>>>>--- a/ldso/libdl/libdl.c
>>>>+++ b/ldso/libdl/libdl.c
>>>>@@ -49,9 +49,12 @@ extern void _dl_add_to_slotinfo(struct link_map *l);
>>>> * perhaps RCU for the global structures */
>>>> __UCLIBC_MUTEX_STATIC(_dl_mutex, PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP);
>>>>
>>>>-#ifdef SHARED
>>>> # if defined(USE_TLS) && USE_TLS
>>>> # include <dl-tls.h>
>>>>+# endif
>>>>+
>>>>+#ifdef SHARED
>>>>+# if defined(USE_TLS) && USE_TLS
>>>> extern struct link_map *_dl_update_slotinfo(unsigned long int req_modid);
>>>> # endif
>>>>
>>>>--
>>>>1.7.9.1.g8d994
>>>>
>>>>
>>>>_______________________________________________
>>>>uClibc mailing list
>>>>uClibc at uclibc.org
>>>>http://lists.busybox.net/mailman/listinfo/uclibc
More information about the uClibc
mailing list