about summary refs log tree commit diff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1995-07-26 07:10:58 +0000
committerRoland McGrath <roland@gnu.org>1995-07-26 07:10:58 +0000
commit958f803fc021993cc2ee1d4157d0092b830368aa (patch)
tree0e5939ccad4bb5a551b81f344843613455c12bb8
parent9f2233e81a0eb06e7278584654cfbdd313d8c228 (diff)
downloadglibc-cvs/bind-493b24.tar.gz
glibc-cvs/bind-493b24.tar.xz
glibc-cvs/bind-493b24.zip
Wed Jul 26 02:00:29 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> cvs/bind-493b24
	* malloc/memalign.c: Allocate (SIZE + ALIGNMENT - 1) and then trim
 	if possible.

	* mach/shortcut.awk: Emit decls for RPC.

	* libc-symbols.h [GCC >= 2.7 && !ASSEMBLER] (weak_symbol,
 	weak_alias, strong_alias): Define using GCC __attribute__ syntax.

	* Makerules ($(installed-libcs)): Depend on `lib' (only).
-rw-r--r--ChangeLog12
-rw-r--r--libc-symbols.h20
-rw-r--r--mach/shortcut.awk5
3 files changed, 36 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 598f70f21e..5227ff0ad7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+Wed Jul 26 02:00:29 1995  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>
+
+	* malloc/memalign.c: Allocate (SIZE + ALIGNMENT - 1) and then trim
+ 	if possible.
+
+	* mach/shortcut.awk: Emit decls for RPC.
+
+	* libc-symbols.h [GCC >= 2.7 && !ASSEMBLER] (weak_symbol,
+ 	weak_alias, strong_alias): Define using GCC __attribute__ syntax.
+
+	* Makerules ($(installed-libcs)): Depend on `lib' (only).
+
 Tue Jul 25 09:14:53 1995  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>
 
 	* sysdeps/mach/hurd/pathconf.c: Declare VALUE as int, not long int.
diff --git a/libc-symbols.h b/libc-symbols.h
index f4d82a6e72..951ea61ec2 100644
--- a/libc-symbols.h
+++ b/libc-symbols.h
@@ -134,6 +134,26 @@ Cambridge, MA 02139, USA.  */
 #endif
 
 
+#if (!defined (ASSEMBLER) && \
+     (__GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7)))
+/* GCC 2.7 and later has special syntax for weak symbols and aliases.
+   Using that is better when possible, because the compiler and assembler
+   are better clued in to what we are doing.  */
+#undef	strong_alias
+#define strong_alias(name, aliasname) \
+  __typeof (name) aliasname __attribute__ ((alias (#name)));
+
+#ifdef HAVE_WEAK_SYMBOLS
+#undef	weak_symbol
+#define weak_symbol(name) \
+  __typeof (name) name __attribute__ ((weak));
+#undef	weak_alias
+#define weak_alias(name, aliasname) \
+  __typeof (name) aliasname __attribute__ ((weak, alias (#name)));
+#endif	/* HAVE_WEAK_SYMBOLS.  */
+#endif	/* Not ASSEMBLER, and GCC 2.7 or later.  */
+
+
 
 /* When the file using this macro is linked in, the linker
    will emit a warning message MSG.  */
diff --git a/mach/shortcut.awk b/mach/shortcut.awk
index d6090d7bf7..987cebe325 100644
--- a/mach/shortcut.awk
+++ b/mach/shortcut.awk
@@ -35,11 +35,14 @@ echo == 1 { print $0; }
     print "{";
     print "  kern_return_t err;";
     print "  extern kern_return_t " syscall " (" proto ");";
+    print "  extern kern_return_t " rpc " (" proto ");";
     print "  err = " syscall " (" arglist ");";
     print "  if (err == MACH_SEND_INTERRUPTED)";
     print "    err = " rpc " (" arglist ");";
     print "  return err;"
     print "}";
-    print "weak_alias (" call ", " alias ")"
+    print "weak_alias (" call ", " alias ")";
+    # Declare RPC so the weak_alias that follows will work.
+    print "extern __typeof (" call ") " rpc ";";
     echo = 1;
   }