(unix_ops): Mark as const.
[kopensolaris-gnu/glibc.git] / sunrpc / rpc_thread.c
index d0dc40b..fbc1cf7 100644 (file)
@@ -8,33 +8,35 @@
 
 #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 ();
                __rpc_thread_clnt_cleanup ();
                __rpc_thread_key_cleanup ();
-               free (tvp->authnone_private_s);
                free (tvp->clnt_perr_buf_s);
                free (tvp->clntraw_private_s);
                free (tvp->svcraw_private_s);
                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);
 
 
 /*
@@ -62,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;
@@ -88,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)
@@ -99,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)
@@ -110,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)
@@ -121,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_ */