(unix_ops): Mark as const.
[kopensolaris-gnu/glibc.git] / sunrpc / rpc_thread.c
index 7f2e351..fbc1cf7 100644 (file)
@@ -8,19 +8,17 @@
 
 #ifdef _RPC_THREAD_SAFE_
 
-
 /* Variable used in non-threaded applications or for the first thread.  */
 static struct rpc_thread_variables __libc_tsd_RPC_VARS_mem;
-static struct rpc_thread_variables *__libc_tsd_RPC_VARS_data =
-     &__libc_tsd_RPC_VARS_mem;
+__libc_tsd_define (, RPC_VARS)
 
 /*
  * Task-variable destructor
  */
-void
+void __attribute__ ((section ("__libc_thread_freeres_fn")))
 __rpc_thread_destroy (void)
 {
-       struct rpc_thread_variables *tvp = __rpc_thread_variables();
+       struct rpc_thread_variables *tvp = __libc_tsd_get (RPC_VARS);
 
        if (tvp != NULL && tvp != &__libc_tsd_RPC_VARS_mem) {
                __rpc_thread_svc_cleanup ();
@@ -32,8 +30,13 @@ __rpc_thread_destroy (void)
                free (tvp->authdes_cache_s);
                free (tvp->authdes_lru_s);
                free (tvp);
+               __libc_tsd_set (RPC_VARS, NULL);
        }
 }
+#ifdef _LIBC_REENTRANT
+text_set_element (__libc_thread_subfreeres, __rpc_thread_destroy);
+#endif
+text_set_element (__libc_subfreeres, __rpc_thread_destroy);
 
 
 /*
@@ -61,7 +64,7 @@ __rpc_thread_variables (void)
                        if (tvp != NULL)
                                __libc_tsd_set (RPC_VARS, tvp);
                        else
-                               tvp = __libc_tsd_RPC_VARS_data;
+                               tvp = __libc_tsd_get (RPC_VARS);
                }
        }
        return tvp;
@@ -87,6 +90,7 @@ __rpc_thread_svc_fdset (void)
                return &svc_fdset;
        return &tvp->svc_fdset_s;
 }
+libc_hidden_def (__rpc_thread_svc_fdset)
 
 struct rpc_createerr *
 __rpc_thread_createerr (void)
@@ -98,6 +102,7 @@ __rpc_thread_createerr (void)
                return &rpc_createerr;
        return &tvp->rpc_createerr_s;
 }
+libc_hidden_def (__rpc_thread_createerr)
 
 struct pollfd **
 __rpc_thread_svc_pollfd (void)
@@ -109,6 +114,7 @@ __rpc_thread_svc_pollfd (void)
                return &svc_pollfd;
        return &tvp->svc_pollfd_s;
 }
+libc_hidden_def (__rpc_thread_svc_pollfd)
 
 int *
 __rpc_thread_svc_max_pollfd (void)
@@ -120,4 +126,6 @@ __rpc_thread_svc_max_pollfd (void)
                return &svc_max_pollfd;
        return &tvp->svc_max_pollfd_s;
 }
+libc_hidden_def (__rpc_thread_svc_max_pollfd)
+
 #endif /* _RPC_THREAD_SAFE_ */