Update.
authorUlrich Drepper <drepper@redhat.com>
Fri, 15 Mar 2002 09:30:44 +0000 (09:30 +0000)
committerUlrich Drepper <drepper@redhat.com>
Fri, 15 Mar 2002 09:30:44 +0000 (09:30 +0000)
2002-03-15  Ulrich Drepper  <drepper@redhat.com>

* sysdeps/i386/i386-mcount.S: Just call __mcount_internal, it is an
internal function.  Adjust for internal_function calling convention.
* sysdeps/i386/machine-gmon.h: Declare and define __mcount_internal
as internal_function.

* sysdeps/generic/framestate.c: Declare fallback_frame_state_for as
hidden.

* nss/XXX-lookup.c (DB_LOOKUP_FCT): Add internal_function to
declaration and definition.
* nss/getXXbyYY_r.c (DB_LOOKUP_FCT): Add internal_function to
declaration.
* nss/getXXent_r.c: Likewise.
* nss/nsswitch.h (db_lookup_function): Add internal_function to
definition.

* include/time.h: Declare __localtime_r as hidden.

* include/grp.h: Declare __getgrent_r as hidden.
* include/netdb.h: Declare __gethostent_r, __getnetent_r,
__getservent_r, and __getprotoent_r as hidden.
* include/pwd.h: Declare __getpwent_r as hidden.
* include/shadow.h: Declare __getspent_r as hidden.
* include/rpc/netdb.h: Declare __getrpcent_r as hidden.

* iconv/gconv_int.h: Declare __gconv_read_conf, __gconv_alias_compare,
and __gconv_transliterate as hidden.
Add internal_function to __gconv_get_path declaration.
* iconv/gconv_int.h: Add internal_function to __gconv_get_path
definition.  Add attribute_hidden to __gconv_read_conf definition.

16 files changed:
ChangeLog
iconv/gconv_conf.c
iconv/gconv_int.h
include/grp.h
include/netdb.h
include/pwd.h
include/rpc/netdb.h
include/shadow.h
include/time.h
nss/XXX-lookup.c
nss/getXXbyYY_r.c
nss/getXXent_r.c
nss/nsswitch.h
sysdeps/generic/framestate.c
sysdeps/i386/i386-mcount.S
sysdeps/i386/machine-gmon.h

index 5f54987..12a5011 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,36 @@
+2002-03-15  Ulrich Drepper  <drepper@redhat.com>
+
+       * sysdeps/i386/i386-mcount.S: Just call __mcount_internal, it is an
+       internal function.  Adjust for internal_function calling convention.
+       * sysdeps/i386/machine-gmon.h: Declare and define __mcount_internal
+       as internal_function.
+
+       * sysdeps/generic/framestate.c: Declare fallback_frame_state_for as
+       hidden.
+
+       * nss/XXX-lookup.c (DB_LOOKUP_FCT): Add internal_function to
+       declaration and definition.
+       * nss/getXXbyYY_r.c (DB_LOOKUP_FCT): Add internal_function to
+       declaration.
+       * nss/getXXent_r.c: Likewise.
+       * nss/nsswitch.h (db_lookup_function): Add internal_function to
+       definition.
+
+       * include/time.h: Declare __localtime_r as hidden.
+
+       * include/grp.h: Declare __getgrent_r as hidden.
+       * include/netdb.h: Declare __gethostent_r, __getnetent_r,
+       __getservent_r, and __getprotoent_r as hidden.
+       * include/pwd.h: Declare __getpwent_r as hidden.
+       * include/shadow.h: Declare __getspent_r as hidden.
+       * include/rpc/netdb.h: Declare __getrpcent_r as hidden.
+
+       * iconv/gconv_int.h: Declare __gconv_read_conf, __gconv_alias_compare,
+       and __gconv_transliterate as hidden.
+       Add internal_function to __gconv_get_path declaration.
+       * iconv/gconv_int.h: Add internal_function to __gconv_get_path
+       definition.  Add attribute_hidden to __gconv_read_conf definition.
+
 2002-03-14  Ulrich Drepper  <drepper@redhat.com>
 
        * elf/rtld.c: Declare _environ as hidden.
index 99519d0..8c2f4b0 100644 (file)
@@ -1,5 +1,5 @@
 /* Handle configuration data.
-   Copyright (C) 1997,98,99,2000,2001 Free Software Foundation, Inc.
+   Copyright (C) 1997,98,99,2000,2001,2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -416,6 +416,7 @@ read_conf_file (const char *filename, const char *directory, size_t dir_len,
 
 /* Determine the directories we are looking for data in.  */
 void
+internal_function
 __gconv_get_path (void)
 {
   struct path_elem *result;
@@ -527,6 +528,7 @@ __gconv_get_path (void)
 /* Read all configuration files found in the user-specified and the default
    path.  */
 void
+attribute_hidden
 __gconv_read_conf (void)
 {
   void *modules = NULL;
index ae6be36..df7d2ee 100644 (file)
@@ -199,16 +199,17 @@ extern void __gconv_release_step (struct __gconv_step *step)
      internal_function;
 
 /* Read all the configuration data and cache it.  */
-extern void __gconv_read_conf (void);
+extern void __gconv_read_conf (void) attribute_hidden;
 
 /* Try to read module cache file.  */
 extern int __gconv_load_cache (void) internal_function;
 
 /* Determine the directories we are looking in.  */
-extern void __gconv_get_path (void);
+extern void __gconv_get_path (void) internal_function;
 
 /* Comparison function to search alias.  */
-extern int __gconv_alias_compare (const void *p1, const void *p2);
+extern int __gconv_alias_compare (const void *p1, const void *p2)
+     attribute_hidden;
 
 /* Clear reference to transformation step implementations which might
    cause the code to be unloaded.  */
@@ -248,7 +249,7 @@ extern int __gconv_transliterate (struct __gconv_step *step,
                                  __const unsigned char **inbufp,
                                  __const unsigned char *inbufend,
                                  unsigned char **outbufstart,
-                                 size_t *irreversible);
+                                 size_t *irreversible) attribute_hidden;
 
 
 /* Builtin transformations.  */
index 6b13ea1..984483b 100644 (file)
@@ -3,7 +3,8 @@
 
 /* Now define the internal interfaces.  */
 extern int __getgrent_r (struct group *__resultbuf, char *buffer,
-                        size_t __buflen, struct group **__result);
+                        size_t __buflen, struct group **__result)
+     attribute_hidden;
 extern int __old_getgrent_r (struct group *__resultbuf, char *buffer,
                             size_t __buflen, struct group **__result);
 extern int __fgetgrent_r (FILE * __stream, struct group *__resultbuf,
index 929ab9e..0a97c01 100644 (file)
@@ -5,7 +5,7 @@
 extern int __gethostent_r (struct hostent *__restrict __result_buf,
                           char *__restrict __buf, size_t __buflen,
                           struct hostent **__restrict __result,
-                          int *__restrict __h_errnop);
+                          int *__restrict __h_errnop) attribute_hidden;
 extern int __old_gethostent_r (struct hostent *__restrict __result_buf,
                               char *__restrict __buf, size_t __buflen,
                               struct hostent **__restrict __result,
@@ -49,7 +49,7 @@ extern int __old_gethostbyname2_r (__const char *__restrict __name, int __af,
 extern int __getnetent_r (struct netent *__restrict __result_buf,
                          char *__restrict __buf, size_t __buflen,
                          struct netent **__restrict __result,
-                         int *__restrict __h_errnop);
+                         int *__restrict __h_errnop) attribute_hidden;
 extern int __old_getnetent_r (struct netent *__restrict __result_buf,
                              char *__restrict __buf, size_t __buflen,
                              struct netent **__restrict __result,
@@ -79,7 +79,8 @@ extern int __old_getnetbyname_r (__const char *__restrict __name,
 
 extern int __getservent_r (struct servent *__restrict __result_buf,
                           char *__restrict __buf, size_t __buflen,
-                          struct servent **__restrict __result);
+                          struct servent **__restrict __result)
+     attribute_hidden;
 extern int __old_getservent_r (struct servent *__restrict __result_buf,
                               char *__restrict __buf, size_t __buflen,
                               struct servent **__restrict __result);
@@ -108,7 +109,8 @@ extern int __old_getservbyport_r (int __port,
 
 extern int __getprotoent_r (struct protoent *__restrict __result_buf,
                            char *__restrict __buf, size_t __buflen,
-                           struct protoent **__restrict __result);
+                           struct protoent **__restrict __result)
+     attribute_hidden;
 extern int __old_getprotoent_r (struct protoent *__restrict __result_buf,
                                char *__restrict __buf, size_t __buflen,
                                struct protoent **__restrict __result);
index 341c6ce..374f02a 100644 (file)
@@ -3,7 +3,8 @@
 
 /* Now define the internal interfaces.  */
 extern int __getpwent_r (struct passwd *__resultbuf, char *__buffer,
-                        size_t __buflen, struct passwd **__result);
+                        size_t __buflen, struct passwd **__result)
+     attribute_hidden;
 extern int __old_getpwent_r (struct passwd *__resultbuf, char *__buffer,
                             size_t __buflen, struct passwd **__result);
 extern int __getpwuid_r (__uid_t __uid, struct passwd *__resultbuf,
index 310cdd7..71c4a09 100644 (file)
@@ -17,7 +17,8 @@ extern int __old_getrpcbynumber_r (int __number, struct rpcent *__result_buf,
                                   struct rpcent **__result);
 
 extern int __getrpcent_r (struct rpcent *__result_buf, char *__buffer,
-                         size_t __buflen, struct rpcent **__result);
+                         size_t __buflen, struct rpcent **__result)
+     attribute_hidden;
 extern int __old_getrpcent_r (struct rpcent *__result_buf, char *__buffer,
                              size_t __buflen, struct rpcent **__result);
 
index 0ae6b21..3891d79 100644 (file)
@@ -3,7 +3,8 @@
 
 /* Now define the internal interfaces.  */
 extern int __getspent_r (struct spwd *__result_buf, char *__buffer,
-                        size_t __buflen, struct spwd **__result);
+                        size_t __buflen, struct spwd **__result)
+     attribute_hidden;
 extern int __old_getspent_r (struct spwd *__result_buf, char *__buffer,
                             size_t __buflen, struct spwd **__result);
 extern int __getspnam_r (__const char *__name, struct spwd *__result_buf,
index 0806e10..ff331cd 100644 (file)
@@ -38,7 +38,7 @@ extern time_t __mktime_internal (struct tm *__tp,
                                                       struct tm *),
                                 time_t *__offset);
 extern struct tm *__localtime_r (__const time_t *__timer,
-                                struct tm *__tp);
+                                struct tm *__tp) attribute_hidden;
 
 extern struct tm *__gmtime_r (__const time_t *__restrict __timer,
                              struct tm *__restrict __tp);
index 79985e6..847c314 100644 (file)
 service_user *DATABASE_NAME_SYMBOL attribute_hidden;
 
 extern int DB_LOOKUP_FCT (service_user **ni, const char *fct_name,
-                         void **fctp);
+                         void **fctp) internal_function;
 
 int
+internal_function
 DB_LOOKUP_FCT (service_user **ni, const char *fct_name, void **fctp)
 {
   if (DATABASE_NAME_SYMBOL == NULL
index d7ab257..ecd28ad 100644 (file)
@@ -112,7 +112,8 @@ typedef enum nss_status (*lookup_function) (ADD_PARAMS, LOOKUP_TYPE *, char *,
                                            size_t, int * H_ERRNO_PARM);
 
 /* The lookup function for the first entry of this service.  */
-extern int DB_LOOKUP_FCT (service_user **nip, const char *name, void **fctp);
+extern int DB_LOOKUP_FCT (service_user **nip, const char *name, void **fctp)
+     internal_function;
 
 /* Interval in which we transfer retry to contact the NSCD.  */
 #define NSS_NSCD_RETRY 100
index 9df443e..e1a2236 100644 (file)
@@ -111,7 +111,8 @@ static STAYOPEN_TMP;
 __libc_lock_define_initialized (static, lock)
 
 /* The lookup function for the first entry of this service.  */
-extern int DB_LOOKUP_FCT (service_user **nip, const char *name, void **fctp);
+extern int DB_LOOKUP_FCT (service_user **nip, const char *name, void **fctp)
+     internal_function;
 \f
 void
 SETFUNC_NAME (STAYOPEN)
index 5d6be74..16dd938 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997, 1998, 1999, 2001 Free Software Foundation, Inc.
+/* Copyright (C) 1996,1997,1998,1999,2001,2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -131,7 +131,8 @@ int __nss_next (service_user **ni, const char *fct_name, void **fctp,
 void *__nss_lookup_function (service_user *ni, const char *fct_name);
 
 
-typedef int (*db_lookup_function) (service_user **, const char *, void **);
+typedef int (*db_lookup_function) (service_user **, const char *, void **)
+     internal_function;
 typedef enum nss_status (*setent_function) (int);
 typedef enum nss_status (*endent_function) (void);
 typedef enum nss_status (*getent_function) (void *, char *, size_t,
index 5cb3e6c..31f8603 100644 (file)
 #include <unwind-dw2.c>
 #undef __frame_state_for
 
+struct frame_state * fallback_frame_state_for (void *, struct frame_state *)
+#ifdef _LIBC
+     attribute_hidden
+#endif
+     ;
+
 typedef struct frame_state * (*framesf)(void *pc, struct frame_state *);
 struct frame_state *__frame_state_for (void *pc,
                                       struct frame_state *frame_state);
index 3d71198..727d7a0 100644 (file)
@@ -1,5 +1,5 @@
 /* i386-specific implemetation of profiling support.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -36,22 +36,12 @@ C_LABEL(_mcount)
        pushl %ecx
        pushl %edx
 
-       movl 12(%esp), %eax
-       movl 4(%ebp), %ecx
-       pushl %eax
-       pushl %ecx
+       movl 12(%esp), %edx
+       movl 4(%ebp), %eax
 
-#ifdef PIC
-       call 1f
-1:     popl %ecx
-       addl $_GLOBAL_OFFSET_TABLE_+[.-1b], %ecx
-       movl C_SYMBOL_NAME(__mcount_internal@GOT)(%ecx), %eax
-       call *%eax
-#else
+       /* No need to access the PLT or GOT, __mcount_internal is an
+          internal function and we can make a relative call.  */
        call C_SYMBOL_NAME(__mcount_internal)
-#endif
-       popl %ecx
-       popl %eax       /* Pop the parameters.  */
 
        /* Pop the saved registers.  Please note that `mcount' has no
           return value.  */
index 33ec763..21aba79 100644 (file)
@@ -1,5 +1,5 @@
 /* i386-specific implementation of profiling support.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
 /* We must not pollute the global namespace.  */
 #define mcount_internal __mcount_internal
 
-void mcount_internal (u_long frompc, u_long selfpc);
+extern void mcount_internal (u_long frompc, u_long selfpc) internal_function;
 
 #define _MCOUNT_DECL(frompc, selfpc) \
-void mcount_internal (u_long frompc, u_long selfpc)
+void internal_function mcount_internal (u_long frompc, u_long selfpc)
 
 
 /* Define MCOUNT as empty since we have the implementation in another