|
NAMEchmod , fchmod ,
lchmod , fchmodat —
change mode of file
LIBRARYStandard C Library (libc, -lc)SYNOPSIS#include <sys/stat.h>
int
int
int
int
DESCRIPTIONThe file permission bits of the file named specified by path or referenced by the file descriptor fd are changed to mode. Thechmod () system call verifies that the process owner
(user) either owns the file specified by path (or
fd), or is the super-user. The
chmod () system call follows symbolic links to operate
on the target of the link rather than the link itself.
The The
If A mode is created from or'd permission bit masks
defined in #define S_IRWXU 0000700 /* RWX mask for owner */ #define S_IRUSR 0000400 /* R for owner */ #define S_IWUSR 0000200 /* W for owner */ #define S_IXUSR 0000100 /* X for owner */ #define S_IRWXG 0000070 /* RWX mask for group */ #define S_IRGRP 0000040 /* R for group */ #define S_IWGRP 0000020 /* W for group */ #define S_IXGRP 0000010 /* X for group */ #define S_IRWXO 0000007 /* RWX mask for other */ #define S_IROTH 0000004 /* R for other */ #define S_IWOTH 0000002 /* W for other */ #define S_IXOTH 0000001 /* X for other */ #define S_ISUID 0004000 /* set user id on execution */ #define S_ISGID 0002000 /* set group id on execution */ #define S_ISVTX 0001000 /* sticky bit */ The non-standard The FreeBSD VM system totally ignores the
sticky bit ( If mode If mode ISUID (set UID) is set on a directory, and the MNT_SUIDDIR option was used in the mount of the file system, then the owner of any new files and sub-directories created within this directory are set to be the same as the owner of that directory. If this function is enabled, new directories will inherit the bit from their parents. Execute bits are removed from the file, and it will not be given to root. This behavior does not change the requirements for the user to be allowed to write the file, but only the eventual owner after it has been created. Group inheritance is not affected. This feature is designed for use on fileservers serving PC users via ftp, SAMBA, or netatalk. It provides security holes for shell users and as such should not be used on shell machines, especially on home directories. This option requires the SUIDDIR option in the kernel to work. Only UFS file systems support this option. For more details of the suiddir mount option, see mount(8). Writing or changing the owner of a file turns off the set-user-id and set-group-id bits unless the user is the super-user. This makes the system somewhat more secure by protecting set-user-id (set-group-id) files from remaining set-user-id (set-group-id) if they are modified, at the expense of a degree of compatibility. RETURN VALUESUpon successful completion, the value 0 is returned; otherwise the value -1 is returned and the global variable errno is set to indicate the error.ERRORSThechmod () system call will fail and the file mode will
be unchanged if:
The
In addition to the
SEE ALSOchmod(1), chflags(2), chown(2), open(2), stat(2), sticky(7)STANDARDSThechmod () system call is expected to conform to
IEEE Std 1003.1-1990 (“POSIX.1”), except
for the return of EFTYPE . The
S_ISVTX bit on directories is expected to conform to
Version 3 of the Single UNIX Specification
(“SUSv3”). The fchmodat () system
call is expected to conform to IEEE Std 1003.1-2008
(“POSIX.1”).
HISTORYThechmod () function appeared in
Version 1 AT&T UNIX. The
fchmod () system call appeared in
4.2BSD. The lchmod () system
call appeared in FreeBSD 3.0. The
fchmodat () system call appeared in
FreeBSD 8.0.
Visit the GSP FreeBSD Man Page Interface. |