É apenas uma convenção. Todos os identificadores constantes estão associados a números no código-fonte do Linux. Alguns deles são muito antigos e vêm dos primeiros lançamentos do kernel, enquanto outros foram adicionados recentemente.
A constante S_ISUID
associada a "setuid" é definida em include / uapi / linux / stat.h , um dos inúmeros cabeçalhos do Linux. Poderia ter sido definido para qualquer coisa, mas aconteceu de ser 04000.
Como afirmado por @steeldriver, man 2 stat
pode ajudar você a entender o significado das diferentes constantes usadas para a permissão de arquivos:
S_IFMT 0170000 bit mask for the file type bit fields
S_IFSOCK 0140000 socket
S_IFLNK 0120000 symbolic link
S_IFREG 0100000 regular file
S_IFBLK 0060000 block device
S_IFDIR 0040000 directory
S_IFCHR 0020000 character device
S_IFIFO 0010000 FIFO
S_ISUID 0004000 set-user-ID bit
S_ISGID 0002000 set-group-ID bit (see below)
S_ISVTX 0001000 sticky bit (see below)
S_IRWXU 00700 mask for file owner permissions
S_IRUSR 00400 owner has read permission
S_IWUSR 00200 owner has write permission
S_IXUSR 00100 owner has execute permission
S_IRWXG 00070 mask for group permissions
S_IRGRP 00040 group has read permission
S_IWGRP 00020 group has write permission
S_IXGRP 00010 group has execute permission
S_IRWXO 00007 mask for permissions for others (not in group)
S_IROTH 00004 others have read permission
S_IWOTH 00002 others have write permission
S_IXOTH 00001 others have execute permission
Nesse trecho, você vê não apenas as constantes e seu valor numérico, mas também a maneira como são escolhidos. Os desenvolvedores / designers escolheram as constantes de maneira que você possa combiná-las. Por exemplo, S_ISUID and S_IRWXU and S_IRUSR and S_IRGRP = 04740
, então permissão 04740
significa precisamente "setuid e todas as permissões para proprietário e permissão de leitura para o grupo proprietário".