diff options
Diffstat (limited to 'fs/ntfs')
-rw-r--r-- | fs/ntfs/ChangeLog | 6 | ||||
-rw-r--r-- | fs/ntfs/super.c | 14 |
2 files changed, 16 insertions, 4 deletions
diff --git a/fs/ntfs/ChangeLog b/fs/ntfs/ChangeLog index e4fd6134244d..7f4007242893 100644 --- a/fs/ntfs/ChangeLog +++ b/fs/ntfs/ChangeLog | |||
@@ -90,7 +90,11 @@ ToDo/Notes: | |||
90 | in the first buffer head instead of a driver global spin lock to | 90 | in the first buffer head instead of a driver global spin lock to |
91 | improve scalability. | 91 | improve scalability. |
92 | - Minor fix to error handling and error message display in | 92 | - Minor fix to error handling and error message display in |
93 | fs/ntfs/aops.c::ntfs_prepare_nonresident_write(). | 93 | fs/ntfs/aops.c::ntfs_prepare_nonresident_write(). |
94 | - Change the mount options {u,f,d}mask to always parse the number as | ||
95 | an octal number to conform to how chmod(1) works, too. Thanks to | ||
96 | Giuseppe Bilotta and Horst von Brand for pointing out the errors of | ||
97 | my ways. | ||
94 | 98 | ||
95 | 2.1.23 - Implement extension of resident files and make writing safe as well as | 99 | 2.1.23 - Implement extension of resident files and make writing safe as well as |
96 | many bug fixes, cleanups, and enhancements... | 100 | many bug fixes, cleanups, and enhancements... |
diff --git a/fs/ntfs/super.c b/fs/ntfs/super.c index b2b392961268..453d0d51ea4b 100644 --- a/fs/ntfs/super.c +++ b/fs/ntfs/super.c | |||
@@ -126,6 +126,14 @@ static BOOL parse_options(ntfs_volume *vol, char *opt) | |||
126 | if (*v) \ | 126 | if (*v) \ |
127 | goto needs_val; \ | 127 | goto needs_val; \ |
128 | } | 128 | } |
129 | #define NTFS_GETOPT_OCTAL(option, variable) \ | ||
130 | if (!strcmp(p, option)) { \ | ||
131 | if (!v || !*v) \ | ||
132 | goto needs_arg; \ | ||
133 | variable = simple_strtoul(ov = v, &v, 8); \ | ||
134 | if (*v) \ | ||
135 | goto needs_val; \ | ||
136 | } | ||
129 | #define NTFS_GETOPT_BOOL(option, variable) \ | 137 | #define NTFS_GETOPT_BOOL(option, variable) \ |
130 | if (!strcmp(p, option)) { \ | 138 | if (!strcmp(p, option)) { \ |
131 | BOOL val; \ | 139 | BOOL val; \ |
@@ -157,9 +165,9 @@ static BOOL parse_options(ntfs_volume *vol, char *opt) | |||
157 | *v++ = 0; | 165 | *v++ = 0; |
158 | NTFS_GETOPT("uid", uid) | 166 | NTFS_GETOPT("uid", uid) |
159 | else NTFS_GETOPT("gid", gid) | 167 | else NTFS_GETOPT("gid", gid) |
160 | else NTFS_GETOPT("umask", fmask = dmask) | 168 | else NTFS_GETOPT_OCTAL("umask", fmask = dmask) |
161 | else NTFS_GETOPT("fmask", fmask) | 169 | else NTFS_GETOPT_OCTAL("fmask", fmask) |
162 | else NTFS_GETOPT("dmask", dmask) | 170 | else NTFS_GETOPT_OCTAL("dmask", dmask) |
163 | else NTFS_GETOPT("mft_zone_multiplier", mft_zone_multiplier) | 171 | else NTFS_GETOPT("mft_zone_multiplier", mft_zone_multiplier) |
164 | else NTFS_GETOPT_WITH_DEFAULT("sloppy", sloppy, TRUE) | 172 | else NTFS_GETOPT_WITH_DEFAULT("sloppy", sloppy, TRUE) |
165 | else NTFS_GETOPT_BOOL("show_sys_files", show_sys_files) | 173 | else NTFS_GETOPT_BOOL("show_sys_files", show_sys_files) |