Provided by: manpages-es_1.55-10_all bug

NOMBRE

       statfs, fstatfs - obtiene estadísticas del sistema de ficheros

SINOPSIS

       #include <sys/vfs.h>

       int statfs(const char *path, struct statfs *buf);
       int fstatfs(int fd, struct statfs *buf);

DESCRIPCIÓN

       statfs devuelve información de un sistema de ficheros montado.  path el el camino de cualquier fichero en
       el sistema de ficheros montado.  buf es un puntero a una estructura statfs definida como sigue:

              struct statfs {
                 long    f_type;     /* tipo sistema ficheros (ver bajo) */
                 long    f_bsize;    /* tamaño óptimo de bloque
                                        de transferencia */
                 long    f_blocks;   /* total de bloques de datos en el sistema
                                        de ficheros */
                 long    f_bfree;    /* bloques libres en el sf */
                 long    f_bavail;   /* bloques libres disponibles para
                                        no-superusuarios */
                 long    f_files;    /* total de nodos de ficheros en el sf */
                 long    f_ffree;    /* nodos de ficheros libres en el sf */
                 fsid_t  f_fsid;     /* id del sistema de ficheros */
                 long    f_namelen;  /* longitud máxima de nombre de ficheros */
                 long    f_spare[6]; /* de sobra, para más tarde */
              };

       Tipos de sistema de ficheros:
              linux/affs_fs.h:
                 AFFS_SUPER_MAGIC      0xADFF
              linux/efs_fs.h:
                 EFS_SUPER_MAGIC       0x00414A53
              linux/ext_fs.h:
                 EXT_SUPER_MAGIC       0x137D
              linux/ext2_fs.h:
                 EXT2_OLD_SUPER_MAGIC  0xEF51
                 EXT2_SUPER_MAGIC      0xEF53
              linux/hpfs_fs.h:
                 HPFS_SUPER_MAGIC      0xF995E849
              linux/iso_fs.h:
                 ISOFS_SUPER_MAGIC     0x9660
              linux/minix_fs.h:
                 MINIX_SUPER_MAGIC     0x137F /* minix orig.*/
                 MINIX_SUPER_MAGIC2    0x138F /* minix 30 carac.*/
                 MINIX2_SUPER_MAGIC    0x2468 /* minix V2 */
                 MINIX2_SUPER_MAGIC2   0x2478 /* minix V2, nombres 30 carac. */
              linux/msdos_fs.h:
                 MSDOS_SUPER_MAGIC     0x4d44
              linux/ncp_fs.h:
                 NCP_SUPER_MAGIC       0x564c
              linux/nfs_fs.h:
                 NFS_SUPER_MAGIC       0x6969
              linux/proc_fs.h:
                 PROC_SUPER_MAGIC      0x9fa0
              linux/smb_fs.h:
                 SMB_SUPER_MAGIC       0x517B
              linux/sysv_fs.h:
                 XENIX_SUPER_MAGIC     0x012FF7B4
                 SYSV4_SUPER_MAGIC     0x012FF7B5
                 SYSV2_SUPER_MAGIC     0x012FF7B6
                 COH_SUPER_MAGIC       0x012FF7B7
              linux/ufs_fs.h:
                 UFS_MAGIC             0x00011954
              linux/xfs_fs.h:
                 XFS_SUPER_MAGIC       0x58465342
              linux/xia_fs.h:
                 _XIAFS_SUPER_MAGIC    0x012FD16D

       Nadie sabe lo que f_fsid se supone que contiene (vea más abajo).

       Los campos no definidos para un sistema de ficheros particular se ponen a 0.  fstatfs devuelve  la  misma
       información sobre un fichero abierto referenciado por el descriptor fd.

VALOR DEVUELTO

       Si hubo éxito se devuelve cero. Si hubo error, se devuelve -1, y errno es actualizado apropiadamente.

ERRORES

       Para statfs:

       ENOTDIR
              Un componente del camino path no es un directorio.

       ENAMETOOLONG
              path es demasiado largo.

       ENOENT El fichero al que se refiere path no existe.

       EACCES El permiso de búsqueda se deniega para un componente del camino path.

       ELOOP  Se encontraron demasiados enlaces simbólicos al traducir path.

       EFAULT buf o path apuntan a una dirección inválida.

       EIO    Ocurrió un error de E/S mientras se leía o escribía en el sistema de ficheros.

       ENOMEM No había suficiente memoria disponible en el núcleo.

       ENOSYS El sistema de ficheros sobre el que se encuentra path no soporta statfs.

       Para fstatfs:

       EBADF  fd no es un descriptor de fichero válido.

       EFAULT buf apunta a una dirección inválida.

       EIO    Ocurrió un error de E/S mientras se leía o escribía en el sistema de ficheros.

       ENOSYS El sistema de ficheros sobre el que está abierto fd no soporta statfs.

CONFORME A

       La versión de Linux de statfs está inspirada en la de 4.4BSD (aunque no usan la misma estructura).

   f_fsid
       Solaris  y  POSIX  1003.1-2001  poseen una llamada al sistema statvfs que devuelve una estructura statvfs
       (definida en <sys/statvfs.h>) con un campo f_fsid de tipo unsigned long .  Linux, SunOS,  HPUX  y  4.4BSD
       poseen  una llamada al sistema statfs que devuelve una estructura statfs (definida en <sys/vfs.h>) con un
       campo f_fsid de tipo fsid_t , donde fsid_t está definido como struct { int val[2]; }.  Lo mismo se aplica
       para FreeBSD, salvo que utiliza el fichero de cabecera <sys/mount.h>.

       La  idea general es que f_fsid contenga información aleatoria de manera que el par (f_fsid,ino) determine
       unívocamente un fichero.  Algunos SOs usan (una variante de) el número de dispositivo,  o  el  número  de
       dispositivo  combinado  con  el  tipo  de  sistema de ficheros.  Muchos SOs restringen el acceso al campo
       f_fsid solamente al superusuario (poniéndolo a cero para aquellos usuarios sin privilegios), ya que  este
       campo  es  usado  en  el  manejo  de ficheros del sistema de ficheros cuando es exportado mediante NFS, y
       conceder acceso a él es un problema de seguridad.

       En algunos SOs fsid puede ser usado como segundo parámetro en la llamada al sistema sysfs().

VÉASE TAMBIÉN

       stat(2)