chmod - change file mode bits


   chmod [OPTION]... MODE[,MODE]... FILE...
   chmod [OPTION]... OCTAL-MODE FILE...
   chmod [OPTION]... --reference=RFILE FILE...


   This manual page documents the GNU version of chmod.  chmod changes the
   file mode bits of each given file  according  to  mode,  which  can  be
   either a symbolic representation of changes to make, or an octal number
   representing the bit pattern for the new mode bits.

   The format of a symbolic mode is  [ugoa...][[-+=][perms...]...],  where
   perms  is  either zero or more letters from the set rwxXst, or a single
   letter from the  set  ugo.   Multiple  symbolic  modes  can  be  given,
   separated by commas.

   A  combination  of the letters ugoa controls which users' access to the
   file will be changed: the user who owns it  (u),  other  users  in  the
   file's group (g), other users not in the file's group (o), or all users
   (a).  If none of these are given, the effect is as if (a)  were  given,
   but bits that are set in the umask are not affected.

   The  operator  +  causes the selected file mode bits to be added to the
   existing file mode bits of each file; - causes them to be removed;  and
   =  causes  them  to  be added and causes unmentioned bits to be removed
   except that a directory's unmentioned set user and group  ID  bits  are
   not affected.

   The  letters  rwxXst select file mode bits for the affected users: read
   (r), write (w), execute (or search for directories) (x), execute/search
   only  if  the file is a directory or already has execute permission for
   some user (X), set user  or  group  ID  on  execution  (s),  restricted
   deletion  flag  or  sticky  bit  (t).   Instead of one or more of these
   letters,  you  can  specify  exactly  one  of  the  letters  ugo:   the
   permissions  granted to the user who owns the file (u), the permissions
   granted to other users who are members of the file's group (g), and the
   permissions  granted  to users that are in neither of the two preceding
   categories (o).

   A numeric mode is from one to  four  octal  digits  (0-7),  derived  by
   adding up the bits with values 4, 2, and 1.  Omitted digits are assumed
   to be leading zeros.  The first digit selects the set user ID  (4)  and
   set group ID (2) and restricted deletion or sticky (1) attributes.  The
   second digit selects permissions for the user who owns the  file:  read
   (4),  write  (2),  and  execute  (1); the third selects permissions for
   other users in the file's group, with the same values; and  the  fourth
   for other users not in the file's group, with the same values.

   chmod never changes the permissions of symbolic links; the chmod system
   call cannot change their permissions.  This is not a problem since  the
   permissions  of  symbolic  links  are  never  used.   However, for each
   symbolic link listed on the command line, chmod changes the permissions
   of  the  pointed-to  file.   In  contrast, chmod ignores symbolic links
   encountered during recursive directory traversals.


   chmod clears the set-group-ID bit of a regular file if the file's group
   ID  does  not  match the user's effective group ID or one of the user's
   supplementary group IDs, unless the user  has  appropriate  privileges.
   Additional restrictions may cause the set-user-ID and set-group-ID bits
   of MODE or RFILE to be ignored.  This behavior depends  on  the  policy
   and  functionality of the underlying chmod system call.  When in doubt,
   check the underlying system behavior.

   chmod preserves a directory's set-user-ID and set-group-ID bits  unless
   you  explicitly  specify otherwise.  You can set or clear the bits with
   symbolic modes like u+s and g-s, and you can set (but  not  clear)  the
   bits with a numeric mode.


   The  restricted  deletion  flag  or  sticky  bit is a single bit, whose
   interpretation depends on the file type.  For directories, it  prevents
   unprivileged  users  from  removing or renaming a file in the directory
   unless they  own  the  file  or  the  directory;  this  is  called  the
   restricted  deletion  flag  for the directory, and is commonly found on
   world-writable directories like /tmp.  For regular files on some  older
   systems,  the  bit saves the program's text image on the swap device so
   it will load more quickly when run; this is called the sticky bit.


   Change the mode of each FILE to MODE.   With  --reference,  change  the
   mode of each FILE to that of RFILE.

   -c, --changes
          like verbose but report only when a change is made

   -f, --silent, --quiet
          suppress most error messages

   -v, --verbose
          output a diagnostic for every file processed

          do not treat '/' specially (the default)

          fail to operate recursively on '/'

          use RFILE's mode instead of MODE values

   -R, --recursive
          change files and directories recursively

   --help display this help and exit

          output version information and exit

   Each           MODE           is          of          the          form


   Written by David MacKenzie and Jim Meyering.


   GNU coreutils online help: <>
   Report chmod translation bugs to <>


   Copyright  2016 Free Software Foundation, Inc.   License  GPLv3+:  GNU
   GPL version 3 or later <>.
   This  is  free  software:  you  are free to change and redistribute it.
   There is NO WARRANTY, to the extent permitted by law.



   Full documentation at: <>
   or available locally via: info '(coreutils) chmod invocation'

More Linux Commands

Unicode::Collate::CJK::Pinyin(3pm) - weighting CJK Unified I
Unicode::Collate::CJK::Pinyin provides weightPinyin(), that is adequate for overrideCJK of Unicode::Collate and makes tailoring of CJK Unified Ideographs in the

envz_merge(3) - environment string support - Linux man page
These functions are glibc-specific. An argz vector is a pointer to a character buffer together with a length, see argz_add(3). An envz vector is a special argz

self(n) method call internal introspection - Linux man page
The self command, which should only be used from within the context of a call to a method (i.e. inside a method, constructor or destructor body) is used to allo

Tcl_FSUtime(3) - procedures to interact with any filesystem
There are several reasons for calling the Tcl_FS API functions (e.g. Tcl_FSAccess and Tcl_FSStat) rather than calling system level functions like access and sta

wcslen(3) - determine the length of a wide-character string
The wcslen() function is the wide-character equivalent of the strlen(3) function. It determines the length of the wide-character string pointed to by s, excludi

XFillArc(3) - fill rectangles, polygons, or arcs (Man Page)
The XFillRectangle and XFillRectangles functions fill the specified rectangle or rectangles as if a four-point FillPolygon protocol request were specified for e

pwdx(1) - report current working directory of a process.....
pwdx [options] pid [...] OPTIONS V, version Output version information and exit. h, help Output help screen and exit. SEE ALSO ps(1), pgrep(1) STANDARDS..(Man)

FcFontSetDestroy(3) - Destroy a font set - Linux man page...
Destroys a font set. Note that this destroys any referenced patterns as well. VERSION Fontconfig version 2.8.0 FcFontSetDestroy.3 (Library - Linux manual page)

uselib(2) - load shared library (System - Linux man page)...
The system call uselib() serves to load a shared library to be used by the calling process. It is given a pathname. The address where to load is found in the li

sincos(3) - calculate sin and cos simultaneously (Man Page)
Several applications need sine and cosine of the same angle x. This function computes both at the same time, and stores the results in *sin and *cos. If x is a

pppd-radattr(8) - RADIUS utility plugin for pppd (8)........
The radattr plugin for pppd causes all radius attributes returned by the RADIUS server at authentication time to be stored in the file /var/run/radattr.pppN whe

setresgid32(2) - set real, effective and saved user or group
setresuid() sets the real user ID, the effective user ID, and the saved set-user-ID of the calling process. Unprivileged user processes may change the real UID,

We can't live, work or learn in freedom unless the software we use is free.