summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--config.h.in3
-rw-r--r--mach/mach_init.c18
-rw-r--r--sysdeps/mach/configure.in9
4 files changed, 29 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index b70cb7264f..5feb9f265d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
 2002-02-16  Roland McGrath  <roland@frob.com>
 
+	* config.h.in: Add #undef HAVE_HOST_PAGE_SIZE.
+	* sysdeps/mach/configure.in: Check for host_page_size RPC to define it.
+	* mach/mach_init.c (__mach_init) [HAVE_HOST_PAGE_SIZE]: Use
+	host_page_size instead of vm_statistics.
+
 	* sysdeps/mach/Makefile (mach-before-compile): Don't include
 	mach_interface.h here, since not all variants use that name.
 
diff --git a/config.h.in b/config.h.in
index b15e8f15ce..fae29729e4 100644
--- a/config.h.in
+++ b/config.h.in
@@ -131,6 +131,9 @@
 /* Mach/Hurd specific: define if mig supports the `retcode' keyword.  */
 #undef	HAVE_MIG_RETCODE
 
+/* Mach specific: define if the `host_page_size' RPC is available.  */
+#undef	HAVE_HOST_PAGE_SIZE
+
 /*
  */
 
diff --git a/mach/mach_init.c b/mach/mach_init.c
index 468aba9025..0dd33e44d9 100644
--- a/mach/mach_init.c
+++ b/mach/mach_init.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1992,93,95,97,2001 Free Software Foundation, Inc.
+/* Copyright (C) 1992,93,95,97,2001,02 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
@@ -16,8 +16,7 @@
    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
    02111-1307 USA.  */
 
-#include <mach_init.h>
-#include <mach/mach_interface.h>
+#include <mach.h>
 #include <mach/mig_support.h>
 #include <unistd.h>
 
@@ -29,13 +28,20 @@ void
 __mach_init (void)
 {
   kern_return_t err;
-  vm_statistics_data_t stats;
 
   __mach_task_self_ = (__mach_task_self) ();
   __mig_init (0);
 
-  if (err = __vm_statistics (__mach_task_self (), &stats))
+#if HAVE_HOST_PAGE_SIZE
+  if (err = __host_page_size (__mach_host_self (), &__vm_page_size))
     _exit (err);
-  __vm_page_size = stats.pagesize;
+#else
+  {
+    vm_statistics_data_t stats;
+    if (err = __vm_statistics (__mach_task_self (), &stats))
+      _exit (err);
+    __vm_page_size = stats.pagesize;
+  }
+#endif
 }
 weak_alias (__mach_init, mach_init)
diff --git a/sysdeps/mach/configure.in b/sysdeps/mach/configure.in
index 058a2a05c8..05dc45b61d 100644
--- a/sysdeps/mach/configure.in
+++ b/sysdeps/mach/configure.in
@@ -59,3 +59,12 @@ done
 if test "x$mach_interface_list" = x; then
   AC_MSG_ERROR([what manner of Mach is this?])
 fi
+
+AC_CACHE_CHECK(for host_page_size in mach_host.defs,
+	       libc_cv_mach_host_page_size, [dnl
+AC_EGREP_HEADER(host_page_size, mach/mach_host.defs,
+		libc_cv_mach_host_page_size=yes,
+		libc_cv_mach_host_page_size=no)])
+if test $libc_cv_mach_host_page_size = yes; then
+  AC_DEFINE([HAVE_HOST_PAGE_SIZE])
+fi