
Estoy familiarizado con los 3 'bits' del modo de archivo que definen permisos de usuario, grupo y otros, así como con el 'bit' setuid/setgid/sticky, pero cuando visito stat
los directorios de nivel raíz en mi computadora portátil MacOSX veo 1 o 2 adicionales campos. ¿Qué son éstos?
[onlyanegg@macosx ~]$ stat -f '%p %N' /*
40775 /Applications
40755 /Library
40755 /Network
40755 /System
40755 /Users
41777 /Volumes
40755 /bin
41775 /cores
40555 /dev
120755 /etc
40555 /home
100644 /installer.failurerequests
40555 /mnt
40555 /net
40775 /opt
40755 /private
40755 /sbin
120755 /tmp
40755 /usr
120755 /var
Respuesta1
stat(1)
especifica que las %p
solicitudes
Tipo de archivo y permisos.
(busque "dato" en la página vinculada). El valor mostrado es todo de st_mode
(verstat(2)
:
#define S_IFMT 0170000 /* type of file */ #define S_IFIFO 0010000 /* named pipe (fifo) */ #define S_IFCHR 0020000 /* character special */ #define S_IFDIR 0040000 /* directory */ #define S_IFBLK 0060000 /* block special */ #define S_IFREG 0100000 /* regular */ #define S_IFLNK 0120000 /* symbolic link */ #define S_IFSOCK 0140000 /* socket */ #define S_IFWHT 0160000 /* whiteout */ #define S_ISUID 0004000 /* set user id on execution */ #define S_ISGID 0002000 /* set group id on execution */ #define S_ISVTX 0001000 /* save swapped text even after use */ #define S_IRUSR 0000400 /* read permission, owner */ #define S_IWUSR 0000200 /* write permission, owner */ #define S_IXUSR 0000100 /* execute/search permission, owner */
Esto explica los valores que estás obteniendo:
- los valores que comienzan con 4 son directorios (
/Applications
,/Library
...) - los valores que comienzan con 12 son enlaces simbólicos (
/etc
,/tmp
,/var
) - los valores que comienzan con 10 son archivos normales (
/installer.failurerequests
)