]> sourceware.org Git - glibc.git/commitdiff
2002-10-16 Roland McGrath <roland@redhat.com>
authorRoland McGrath <roland@gnu.org>
Wed, 16 Oct 2002 22:09:42 +0000 (22:09 +0000)
committerRoland McGrath <roland@gnu.org>
Wed, 16 Oct 2002 22:09:42 +0000 (22:09 +0000)
* sysdeps/unix/sysv/linux/fpathconf.c (LINUX_LINK_MAX): Move macro ...
* sysdeps/unix/sysv/linux/linux_fsinfo.h (LINUX_LINK_MAX): ... here.
* sysdeps/unix/sysv/linux/pathconf.h: New file.
(statfs_link_max): New function, guts from fpathconf.c.
* sysdeps/unix/sysv/linux/fpathconf.c: Rewritten using that.
* sysdeps/unix/sysv/linux/pathconf.c (__pathconf): Likewise.
* sysdeps/unix/sysv/linux/alpha/pathconf.c (__pathconf): Rewritten
to use the linux/pathconf.c code by #include rather than duplication.
* sysdeps/unix/sysv/linux/alpha/fpathconf.c (__pathconf): Likewise.

sysdeps/unix/sysv/linux/alpha/fpathconf.c
sysdeps/unix/sysv/linux/alpha/pathconf.c
sysdeps/unix/sysv/linux/fpathconf.c
sysdeps/unix/sysv/linux/linux_fsinfo.h
sysdeps/unix/sysv/linux/pathconf.c
sysdeps/unix/sysv/linux/pathconf.h [new file with mode: 0644]

index 1820e5b22968b60d63f6e504de7c4be18e38a778..a8a24de1f8fc1ce292ae4dda68b26b119aefa6f5 100644 (file)
@@ -1,4 +1,5 @@
-/* Copyright (C) 1991,1995,1996,1998,2000,2002 Free Software Foundation, Inc.
+/* Get file-specific information about a descriptor.  Linux/Alpha version.
+   Copyright (C) 1991,95,96,98,99,2000,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
    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
    02111-1307 USA.  */
 
-#include <errno.h>
-#include <stddef.h>
 #include <unistd.h>
-#include <limits.h>
 #include <sys/statfs.h>
 
-#include <linux_fsinfo.h>
 
+static long int linux_fpathconf (int fd, int name);
 
-/* The Linux kernel header mentioned this as a kind of generic value.  */
-#define LINUX_LINK_MAX 127
+/* Define this first, so it can be inlined.  */
+#define __fpathconf static linux_fpathconf
+#include <sysdeps/unix/sysv/linux/fpathconf.c>
 
-static long int default_fpathconf (int fd, int name);
 
-/* Get file-specific information about descriptor FD.  */
+/* Get file-specific information about FD.  */
 long int
-__fpathconf (fd, name)
-     int fd;
-     int name;
+__pathconf (int fd, int name)
 {
-  if (fd < 0)
-    {
-      __set_errno (EBADF);
-      return -1;
-    }
-
   if (name == _PC_FILESIZEBITS)
     {
-      /* Test whether this is on a ext2 filesystem which supports large
-        files.  */
+      /* Test whether this is on a ext2 or UFS filesystem which
+        support large files.  */
       struct statfs fs;
 
       if (__fstatfs (fd, &fs) < 0
@@ -57,56 +47,6 @@ __fpathconf (fd, name)
       /* This filesystem supported files >2GB.  */
       return 64;
     }
-  if (name == _PC_LINK_MAX)
-    {
-      struct statfs fsbuf;
-
-      /* Determine the filesystem type.  */
-      if (__fstatfs (fd, &fsbuf) < 0)
-       /* not possible, return the default value.  */
-       return LINUX_LINK_MAX;
-
-      switch (fsbuf.f_type)
-       {
-       case EXT2_SUPER_MAGIC:
-         return EXT2_LINK_MAX;
-
-       case MINIX_SUPER_MAGIC:
-       case MINIX_SUPER_MAGIC2:
-         return MINIX_LINK_MAX;
-
-       case MINIX2_SUPER_MAGIC:
-       case MINIX2_SUPER_MAGIC2:
-         return MINIX2_LINK_MAX;
-
-       case XENIX_SUPER_MAGIC:
-         return XENIX_LINK_MAX;
 
-       case SYSV4_SUPER_MAGIC:
-       case SYSV2_SUPER_MAGIC:
-         return SYSV_LINK_MAX;
-
-       case COH_SUPER_MAGIC:
-         return COH_LINK_MAX;
-
-       case UFS_MAGIC:
-       case UFS_CIGAM:
-         return UFS_LINK_MAX;
-
-       case REISERFS_SUPER_MAGIC:
-         return REISERFS_LINK_MAX;
-
-       case XFS_SUPER_MAGIC:
-         return XFS_LINK_MAX;
-
-       default:
-         return LINUX_LINK_MAX;
-       }
-    }
-
-  /* Fallback to the generic version.  */
-  return default_fpathconf (fd, name);
+  return linux_fpathconf (fd, name);
 }
-
-#define __fpathconf static default_fpathconf
-#include <sysdeps/posix/fpathconf.c>
index 45c1724dcf4679aa7ec049a7dc0db4aec2c93693..1b35dc87cf10478b29311bb2dc6e2c49f2e39c85 100644 (file)
@@ -1,4 +1,5 @@
-/* Copyright (C) 1991, 1995, 1996, 1998, 2000 Free Software Foundation, Inc.
+/* Get file-specific information about a file.  Linux/Alpha version.
+   Copyright (C) 1991,95,96,98,99,2000,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
    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
    02111-1307 USA.  */
 
-#include <errno.h>
-#include <stddef.h>
 #include <unistd.h>
-#include <limits.h>
-#include <fcntl.h>
 #include <sys/statfs.h>
 
-#include <linux_fsinfo.h>
+static long int linux_pathconf (const char *file, int name);
 
+/* Define this first, so it can be inlined.  */
+#define __pathconf static linux_pathconf
+#include <sysdeps/unix/sysv/linux/pathconf.c>
 
-/* The Linux kernel header mentioned this as a kind of generic value.  */
-#define LINUX_LINK_MAX 127
 
-static long int default_pathconf (const char *path, int name);
-
-/* Get file-specific information about PATH.  */
+/* Get file-specific information about FILE.  */
 long int
-__pathconf (const char *path, int name)
+__pathconf (const char *file, int name)
 {
   if (name == _PC_FILESIZEBITS)
     {
@@ -41,7 +37,7 @@ __pathconf (const char *path, int name)
         support large files.  */
       struct statfs fs;
 
-      if (__statfs (path, &fs) < 0
+      if (__statfs (file, &fs) < 0
          || (fs.f_type != EXT2_SUPER_MAGIC
              && fs.f_type != UFS_MAGIC
              && fs.f_type != UFS_CIGAM))
@@ -50,50 +46,6 @@ __pathconf (const char *path, int name)
       /* This filesystem supported files >2GB.  */
       return 64;
     }
-  if (name == _PC_LINK_MAX)
-    {
-      struct statfs fsbuf;
-
-      /* Determine the filesystem type.  */
-      if (__statfs (path, &fsbuf) < 0)
-       /* not possible, return the default value.  */
-       return LINUX_LINK_MAX;
-
-      switch (fsbuf.f_type)
-       {
-       case EXT2_SUPER_MAGIC:
-         return EXT2_LINK_MAX;
-
-       case MINIX_SUPER_MAGIC:
-       case MINIX_SUPER_MAGIC2:
-         return MINIX_LINK_MAX;
-
-       case MINIX2_SUPER_MAGIC:
-       case MINIX2_SUPER_MAGIC2:
-         return MINIX2_LINK_MAX;
-
-       case XENIX_SUPER_MAGIC:
-         return XENIX_LINK_MAX;
 
-       case SYSV4_SUPER_MAGIC:
-       case SYSV2_SUPER_MAGIC:
-         return SYSV_LINK_MAX;
-
-       case COH_SUPER_MAGIC:
-         return COH_LINK_MAX;
-
-       case UFS_MAGIC:
-       case UFS_CIGAM:
-         return UFS_LINK_MAX;
-
-       default:
-         return LINUX_LINK_MAX;
-       }
-    }
-
-  /* Fallback to the generic version.  */
-  return default_pathconf (path, name);
+  return linux_pathconf (file, name);
 }
-
-#define __pathconf static default_pathconf
-#include <sysdeps/posix/pathconf.c>
index 108ffa705a26e8ad068170ee5a19fb7716948fa3..a43a58767d3bf04ded89a55ca1e75dd54a0d0d67 100644 (file)
@@ -1,4 +1,4 @@
-/* Linux specific extensions to fpathconf.
+/* Get file-specific information about descriptor FD.  Linux version.
    Copyright (C) 1991,95,96,98,99,2000,2001,2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
    02111-1307 USA.  */
 
-#include <errno.h>
-#include <unistd.h>
-#include <limits.h>
-#include <sys/statfs.h>
-
-#include "linux_fsinfo.h"
-
-
-/* The Linux kernel header mentioned this as a kind of generic value.  */
-#define LINUX_LINK_MAX 127
+#include "pathconf.h"
 
 static long int posix_fpathconf (int fd, int name);
 
+/* Define this first, so it can be inlined.  */
+#define __fpathconf static posix_fpathconf
+#include <sysdeps/posix/fpathconf.c>
+
 
 /* Get file-specific information about descriptor FD.  */
 long int
@@ -40,58 +35,8 @@ __fpathconf (fd, name)
   if (name == _PC_LINK_MAX)
     {
       struct statfs fsbuf;
-
-      /* Determine the filesystem type.  */
-      if (__fstatfs (fd, &fsbuf) < 0)
-       {
-         if (errno == ENOSYS)
-           /* not possible, return the default value.  */
-           return LINUX_LINK_MAX;
-
-         /* Some error occured.  */
-          return -1;
-       }
-
-      switch (fsbuf.f_type)
-       {
-       case EXT2_SUPER_MAGIC:
-         return EXT2_LINK_MAX;
-
-       case MINIX_SUPER_MAGIC:
-       case MINIX_SUPER_MAGIC2:
-         return MINIX_LINK_MAX;
-
-       case MINIX2_SUPER_MAGIC:
-       case MINIX2_SUPER_MAGIC2:
-         return MINIX2_LINK_MAX;
-
-       case XENIX_SUPER_MAGIC:
-         return XENIX_LINK_MAX;
-
-       case SYSV4_SUPER_MAGIC:
-       case SYSV2_SUPER_MAGIC:
-         return SYSV_LINK_MAX;
-
-       case COH_SUPER_MAGIC:
-         return COH_LINK_MAX;
-
-       case UFS_MAGIC:
-       case UFS_CIGAM:
-         return UFS_LINK_MAX;
-
-       case REISERFS_SUPER_MAGIC:
-         return REISERFS_LINK_MAX;
-
-       case XFS_SUPER_MAGIC:
-         return XFS_LINK_MAX;
-
-       default:
-         return LINUX_LINK_MAX;
-       }
+      return statfs_link_max (__fstatfs (fd, &fsbuf), &fsbuf);
     }
 
   return posix_fpathconf (fd, name);
 }
-
-#define __fpathconf static posix_fpathconf
-#include <sysdeps/posix/fpathconf.c>
index 60b4721e101ebb991a187f8f5ebab5e6296f9788..8aa7e28c7cd329d9a91e8ed9e1f97d2332ff9551 100644 (file)
 #define XENIX_LINK_MAX         126     /* ?? */
 #define XFS_LINK_MAX           2147483647
 
+/* The Linux kernel header mentioned this as a kind of generic value.  */
+#define LINUX_LINK_MAX 127
+
+
 #endif /* linux_fsinfo.h */
index 8f21b241ccfb90d53c497c978f99b8c73a8bc46f..50a4b3ada4ebb49403df1c19c99f4712b507a116 100644 (file)
@@ -1,5 +1,5 @@
-/* Linux specific extensions to pathconf.
-   Copyright (C) 1991,95,96,98,99,2000,2001 Free Software Foundation, Inc.
+/* Get file-specific information about a file.  Linux version.
+   Copyright (C) 1991,95,96,98,99,2000,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
    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
    02111-1307 USA.  */
 
-#include <errno.h>
-#include <unistd.h>
-#include <limits.h>
-#include <sys/statfs.h>
+#include "pathconf.h"
 
-#include "linux_fsinfo.h"
+static long int posix_pathconf (const char *file, int name);
 
-
-/* The Linux kernel header mentioned this as a kind of generic value.  */
-#define LINUX_LINK_MAX 127
-
-static long int posix_pathconf (const char *path, int name);
+/* Define this first, so it can be inlined.  */
+#define __pathconf static posix_pathconf
+#include <sysdeps/posix/pathconf.c>
 
 
-/* Get file-specific information about descriptor FD.  */
+/* Get file-specific information about FILE.  */
 long int
-__pathconf (path, name)
-     const char *path;
-     int name;
+__pathconf (const char *file, int name)
 {
   if (name == _PC_LINK_MAX)
     {
       struct statfs fsbuf;
-
-      /* Determine the filesystem type.  */
-      if (__statfs (path, &fsbuf) < 0)
-       {
-         if (errno == ENOSYS)
-           /* not possible, return the default value.  */
-           return LINUX_LINK_MAX;
-
-         /* Some error occured.  */
-          return -1;
-       }
-
-      switch (fsbuf.f_type)
-       {
-       case EXT2_SUPER_MAGIC:
-         return EXT2_LINK_MAX;
-
-       case MINIX_SUPER_MAGIC:
-       case MINIX_SUPER_MAGIC2:
-         return MINIX_LINK_MAX;
-
-       case MINIX2_SUPER_MAGIC:
-       case MINIX2_SUPER_MAGIC2:
-         return MINIX2_LINK_MAX;
-
-       case XENIX_SUPER_MAGIC:
-         return XENIX_LINK_MAX;
-
-       case SYSV4_SUPER_MAGIC:
-       case SYSV2_SUPER_MAGIC:
-         return SYSV_LINK_MAX;
-
-       case COH_SUPER_MAGIC:
-         return COH_LINK_MAX;
-
-       case UFS_MAGIC:
-       case UFS_CIGAM:
-         return UFS_LINK_MAX;
-
-       case REISERFS_SUPER_MAGIC:
-         return REISERFS_LINK_MAX;
-
-       default:
-         return LINUX_LINK_MAX;
-       }
+      return statfs_link_max (__statfs (file, &fsbuf), &fsbuf);
     }
 
-  return posix_pathconf (path, name);
+  return posix_pathconf (file, name);
 }
-
-#define __pathconf static posix_pathconf
-#include <sysdeps/posix/pathconf.c>
diff --git a/sysdeps/unix/sysv/linux/pathconf.h b/sysdeps/unix/sysv/linux/pathconf.h
new file mode 100644 (file)
index 0000000..3965639
--- /dev/null
@@ -0,0 +1,76 @@
+/* Common parts of Linux implementation of pathconf and fpathconf.
+   Copyright (C) 1991,95,96,98,99,2000,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
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, write to the Free
+   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+   02111-1307 USA.  */
+
+#include <unistd.h>
+#include <errno.h>
+#include <sys/statfs.h>
+#include "linux_fsinfo.h"
+
+/* Used like: return statfs_link_max (__statfs (name, &buf), &buf); */
+
+static long int
+statfs_link_max (int result, const struct statfs *fsbuf)
+{
+  if (result < 0)
+    {
+      if (errno == ENOSYS)
+       /* Not possible, return the default value.  */
+       return LINUX_LINK_MAX;
+
+      /* Some error occured.  */
+      return -1;
+    }
+
+  switch (fsbuf->f_type)
+    {
+    case EXT2_SUPER_MAGIC:
+      return EXT2_LINK_MAX;
+
+    case MINIX_SUPER_MAGIC:
+    case MINIX_SUPER_MAGIC2:
+      return MINIX_LINK_MAX;
+
+    case MINIX2_SUPER_MAGIC:
+    case MINIX2_SUPER_MAGIC2:
+      return MINIX2_LINK_MAX;
+
+    case XENIX_SUPER_MAGIC:
+      return XENIX_LINK_MAX;
+
+    case SYSV4_SUPER_MAGIC:
+    case SYSV2_SUPER_MAGIC:
+      return SYSV_LINK_MAX;
+
+    case COH_SUPER_MAGIC:
+      return COH_LINK_MAX;
+
+    case UFS_MAGIC:
+    case UFS_CIGAM:
+      return UFS_LINK_MAX;
+
+    case REISERFS_SUPER_MAGIC:
+      return REISERFS_LINK_MAX;
+
+    case XFS_SUPER_MAGIC:
+      return XFS_LINK_MAX;
+
+    default:
+      return LINUX_LINK_MAX;
+    }
+}
This page took 0.048785 seconds and 5 git commands to generate.