1
0
mirror of https://sourceware.org/git/glibc.git synced 2025-07-29 11:41:21 +03:00

Handle ext4 and logfs in statvfs functions.

This commit is contained in:
Ulrich Drepper
2010-03-06 15:40:50 -08:00
parent a092b645f8
commit 6e0a06fa40
3 changed files with 49 additions and 34 deletions

View File

@ -1,3 +1,8 @@
2010-03-06 Ulrich Drepper <drepper@redhat.com>
* sysdeps/unix/sysv/linux/internal_statvfs.c: Handle ext4 and logfs.
* sysdeps/unix/sysv/linux/linux_fsinfo.h: Add entry for logfs.
2010-02-18 Yann Droneaud <yann@droneaud.fr> 2010-02-18 Yann Droneaud <yann@droneaud.fr>
* resolv/res_send.c: Fixed DEBUG statements. * resolv/res_send.c: Fixed DEBUG statements.

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1998-2003, 2004, 2005, 2006 Free Software Foundation, Inc. /* Copyright (C) 1998-2006, 2010 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -45,13 +45,15 @@ __statvfs_getflags (const char *name, int fstype, struct stat64 *st)
const char *fsname = NULL; const char *fsname = NULL;
const char *fsname2 = NULL; const char *fsname2 = NULL;
const char *fsname3 = NULL;
/* Map the filesystem type we got from the statfs call to a string. */ /* Map the filesystem type we got from the statfs call to a string. */
switch (fstype) switch (fstype)
{ {
case EXT2_SUPER_MAGIC: case EXT2_SUPER_MAGIC:
fsname = "ext3"; fsname = "ext4";
fsname2 = "ext2"; fsname2 = "ext3";
fsname3 = "ext2";
break; break;
case DEVPTS_SUPER_MAGIC: case DEVPTS_SUPER_MAGIC:
fsname= "devpts"; fsname= "devpts";
@ -98,6 +100,9 @@ __statvfs_getflags (const char *name, int fstype, struct stat64 *st)
case NTFS_SUPER_MAGIC: case NTFS_SUPER_MAGIC:
fsname = "ntfs"; fsname = "ntfs";
break; break;
case LOGFS_MAGIC_U32:
fsname = "logfs";
break;
} }
FILE *mtab = __setmntent ("/proc/mounts", "r"); FILE *mtab = __setmntent ("/proc/mounts", "r");
@ -126,7 +131,9 @@ __statvfs_getflags (const char *name, int fstype, struct stat64 *st)
else if (fsname != NULL else if (fsname != NULL
&& strcmp (fsname, mntbuf.mnt_type) != 0 && strcmp (fsname, mntbuf.mnt_type) != 0
&& (fsname2 == NULL && (fsname2 == NULL
|| strcmp (fsname2, mntbuf.mnt_type) != 0)) || strcmp (fsname2, mntbuf.mnt_type) != 0)
&& (fsname3 == NULL
|| strcmp (fsname3, mntbuf.mnt_type) != 0))
continue; continue;
/* Find out about the device the current entry is for. */ /* Find out about the device the current entry is for. */

View File

@ -1,5 +1,5 @@
/* Constants from kernel header for various FSes. /* Constants from kernel header for various FSes.
Copyright (C) 1998,1999,2000,2001,2002,2003,2005 Free Software Foundation, Inc. Copyright (C) 1998-2003,2005,2010 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -25,22 +25,22 @@
filesystem types will become available we have to add the filesystem types will become available we have to add the
appropriate definitions here.*/ appropriate definitions here.*/
/* Constants that identify the `adfs' filesystem. */ /* Constant that identifies the `adfs' filesystem. */
#define ADFS_SUPER_MAGIC 0xadf5 #define ADFS_SUPER_MAGIC 0xadf5
/* Constants that identify the `affs' filesystem. */ /* Constant that identifies the `affs' filesystem. */
#define AFFS_SUPER_MAGIC 0xadff #define AFFS_SUPER_MAGIC 0xadff
/* Constants that identify the `autofs' filesystem. */ /* Constant that identifies the `autofs' filesystem. */
#define AUTOFS_SUPER_MAGIC 0x187 #define AUTOFS_SUPER_MAGIC 0x187
/* Constants that identify the `bfs' filesystem. */ /* Constant that identifies the `bfs' filesystem. */
#define BFS_MAGIC 0x1BADFACE #define BFS_MAGIC 0x1BADFACE
/* Constants that identify the `coda' filesystem. */ /* Constant that identifies the `coda' filesystem. */
#define CODA_SUPER_MAGIC 0x73757245 #define CODA_SUPER_MAGIC 0x73757245
/* Constants that identify the `coherent' filesystem. */ /* Constant that identifies the `coherent' filesystem. */
#define COH_SUPER_MAGIC 0x012ff7b7 #define COH_SUPER_MAGIC 0x012ff7b7
/* Constant that identifies the `ramfs' filesystem. */ /* Constant that identifies the `ramfs' filesystem. */
@ -52,7 +52,7 @@
/* Constant that identifies the `devpts' filesystem. */ /* Constant that identifies the `devpts' filesystem. */
#define DEVPTS_SUPER_MAGIC 0x1cd1 #define DEVPTS_SUPER_MAGIC 0x1cd1
/* Constant that identifies the `efs' filesystem. */ /* Constants that identifies the `efs' filesystem. */
#define EFS_SUPER_MAGIC 0x414A53 #define EFS_SUPER_MAGIC 0x414A53
#define EFS_MAGIC 0x072959 #define EFS_MAGIC 0x072959
@ -74,6 +74,9 @@
/* Constant that identifies the `jfs' filesystem. */ /* Constant that identifies the `jfs' filesystem. */
#define JFS_SUPER_MAGIC 0x3153464a #define JFS_SUPER_MAGIC 0x3153464a
/* Constant that identifies the `logfs<66> filesystem. */
#define LOGFS_MAGIC_U32 0xc97e8168u
/* Constants that identify the `minix2' filesystem. */ /* Constants that identify the `minix2' filesystem. */
#define MINIX2_SUPER_MAGIC 0x2468 #define MINIX2_SUPER_MAGIC 0x2468
#define MINIX2_SUPER_MAGIC2 0x2478 #define MINIX2_SUPER_MAGIC2 0x2478
@ -82,61 +85,61 @@
#define MINIX_SUPER_MAGIC 0x137f #define MINIX_SUPER_MAGIC 0x137f
#define MINIX_SUPER_MAGIC2 0x138F #define MINIX_SUPER_MAGIC2 0x138F
/* Constants that identify the `msdos' filesystem. */ /* Constant that identifies the `msdos' filesystem. */
#define MSDOS_SUPER_MAGIC 0x4d44 #define MSDOS_SUPER_MAGIC 0x4d44
/* Constants that identify the `ncp' filesystem. */ /* Constant that identifies the `ncp' filesystem. */
#define NCP_SUPER_MAGIC 0x564c #define NCP_SUPER_MAGIC 0x564c
/* Constants that identify the `nfs' filesystem. */ /* Constant that identifies the `nfs' filesystem. */
#define NFS_SUPER_MAGIC 0x6969 #define NFS_SUPER_MAGIC 0x6969
/* Constants that identify the `ntfs' filesystem. */ /* Constant that identifies the `ntfs' filesystem. */
#define NTFS_SUPER_MAGIC 0x5346544e #define NTFS_SUPER_MAGIC 0x5346544e
/* Constants that identify the `proc' filesystem. */ /* Constant that identifies the `proc' filesystem. */
#define PROC_SUPER_MAGIC 0x9fa0 #define PROC_SUPER_MAGIC 0x9fa0
/* Constant that identifies the `usbdevfs' filesystem. */ /* Constant that identifies the `usbdevfs' filesystem. */
#define USBDEVFS_SUPER_MAGIC 0x9fa2 #define USBDEVFS_SUPER_MAGIC 0x9fa2
/* Constants that identify the `qnx4' filesystem. */ /* Constant that identifies the `qnx4' filesystem. */
#define QNX4_SUPER_MAGIC 0x002f #define QNX4_SUPER_MAGIC 0x002f
/* Constants that identify the `reiser' filesystem. */ /* Constant that identifies the `reiser' filesystem. */
#define REISERFS_SUPER_MAGIC 0x52654973 #define REISERFS_SUPER_MAGIC 0x52654973
/* Constant that identifies the `romfs' filesystem. */ /* Constant that identifies the `romfs' filesystem. */
#define ROMFS_SUPER_MAGIC 0x7275 #define ROMFS_SUPER_MAGIC 0x7275
/* Constants that identify the `smb' filesystem. */ /* Constant that identifies the `shm' filesystem. */
#define SHMFS_SUPER_MAGIC 0x01021994
/* Constant that identifies the `smb' filesystem. */
#define SMB_SUPER_MAGIC 0x517b #define SMB_SUPER_MAGIC 0x517b
/* Constant that identifies the `sysfs<66> filesystem. */
#define SYSFS_MAGIC 0x62656572
/* Constants that identify the `sysV' filesystem. */ /* Constants that identify the `sysV' filesystem. */
#define SYSV2_SUPER_MAGIC 0x012ff7b6 #define SYSV2_SUPER_MAGIC 0x012ff7b6
#define SYSV4_SUPER_MAGIC 0x012ff7b5 #define SYSV4_SUPER_MAGIC 0x012ff7b5
/* Constants that identify the `udf' filesystem. */ /* Constant that identifies the `udf' filesystem. */
#define UDF_SUPER_MAGIC 0x15013346 #define UDF_SUPER_MAGIC 0x15013346
/* Constants that identify the `ufs' filesystem. */ /* Constant that identify the `ufs' filesystem. */
#define UFS_MAGIC 0x00011954 #define UFS_MAGIC 0x00011954
#define UFS_CIGAM 0x54190100 /* byteswapped MAGIC */ #define UFS_CIGAM 0x54190100 /* byteswapped MAGIC */
/* Constants that identify the `xenix' filesystem. */ /* Constant that identifies the `vxfs' filesystem. */
#define XENIX_SUPER_MAGIC 0x012ff7b4
/* Constant that identifies the `shm' filesystem. */
#define SHMFS_SUPER_MAGIC 0x01021994
/* Constants that identify the `xfs' filesystem. */
#define XFS_SUPER_MAGIC 0x58465342
/* Constants that identify the `vxfs' filesystem. */
#define VXFS_SUPER_MAGIC 0xa501fcf5 #define VXFS_SUPER_MAGIC 0xa501fcf5
/* Constants that identify the `sysfs<EFBFBD> filesystem. */ /* Constant that identifies the `xenix' filesystem. */
#define SYSFS_MAGIC 0x62656572 #define XENIX_SUPER_MAGIC 0x012ff7b4
/* Constant that identifies the `xfs' filesystem. */
#define XFS_SUPER_MAGIC 0x58465342
/* Maximum link counts. */ /* Maximum link counts. */
#define COH_LINK_MAX 10000 #define COH_LINK_MAX 10000