Commit cfac3b0b authored by Anton Altaparmakov's avatar Anton Altaparmakov Committed by Anton Altaparmakov

NTFS:

Make all files executable by default, {u,f,d}mask mount options can be
used to take away executable bit if desired.
Also make default umask match the documentation (i.e. 0077).
parent e4d3ddf5
...@@ -35,8 +35,13 @@ uid= ...@@ -35,8 +35,13 @@ uid=
gid= gid=
umask= Provide default owner, group, and access mode mask. umask= Provide default owner, group, and access mode mask.
These options work as documented in mount(8). By These options work as documented in mount(8). By
default, the files are owned by root and are not default, the files/directories are owned by root and
readable by anyone else. he/she has read, write, and execute permissions. No one
else has any access permissions. I.e. the mode on all
files and directories is by default rwx------, a
consequence of the default umask=0077. Using a
umask of zero will grant all permissions to everyone,
i.e. all files and directories will have mode rwxrwxrwx.
fmask= fmask=
dmask= Instead of specifying umask which applies both to dmask= Instead of specifying umask which applies both to
......
...@@ -759,15 +759,13 @@ void ntfs_read_inode(struct inode *vi) ...@@ -759,15 +759,13 @@ void ntfs_read_inode(struct inode *vi)
le32_to_cpu(ctx->attr->_ARA(value_length)); le32_to_cpu(ctx->attr->_ARA(value_length));
} }
no_data_attr_special_case: no_data_attr_special_case:
/* Everyone gets read permissions. */ /* Everyone gets all permissions. */
vi->i_mode |= S_IRUGO; vi->i_mode |= S_IRWXUGO;
/* If not read-only, set write permissions. */ /* If read-only, noone gets write permissions. */
if (!IS_RDONLY(vi)) if (IS_RDONLY(vi))
vi->i_mode |= S_IWUGO; vi->i_mode &= ~S_IWUGO;
/* Apply the file permissions mask set in the mount options. */ /* Apply the file permissions mask set in the mount options. */
vi->i_mode &= ~vol->fmask; vi->i_mode &= ~vol->fmask;
// FIXME: Encrypted files should probably get their rw bits
// taken away here.
/* Setup the operations for this inode. */ /* Setup the operations for this inode. */
vi->i_op = &ntfs_file_inode_ops; vi->i_op = &ntfs_file_inode_ops;
vi->i_fop = &ntfs_file_ops; vi->i_fop = &ntfs_file_ops;
......
...@@ -1524,11 +1524,10 @@ static int ntfs_fill_super(struct super_block *sb, void *opt, const int silent) ...@@ -1524,11 +1524,10 @@ static int ntfs_fill_super(struct super_block *sb, void *opt, const int silent)
vol->nls_map = NULL; vol->nls_map = NULL;
/* /*
* Default is group and other don't have write/execute access to files * Default is group and other don't have any access to files or
* and write access to directories. * directories while owner has full access.
*/ */
vol->fmask = 0033; vol->fmask = vol->dmask = 0077;
vol->dmask = 0022;
/* /*
* Default is to show long file names (including POSIX file names), and * Default is to show long file names (including POSIX file names), and
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment