How do I use 'chmod' on an NTFS (or FAT32) partition?
I have a script that I need to execute on an NTFS partition. The script's permission is set to 600.
I attempted to modify the permissions by running
chmod 755 script.sh, which doesn't report a failure or anything - but it also doesn't change the permissions on the file:
$ stat script.sh File: `script.sh' Size: 297070 Blocks: 584 IO Block: 4096 regular file Device: 811h/2065d Inode: 35515 Links: 1 Access: (0600/-rw-------) Uid: ( 1000/ xxxxxx) Gid: ( 1000/ xxxxxx) Access: 2010-09-30 14:05:16.041621000 -0700 Modify: 2010-09-30 14:05:05.070157000 -0700 Change: 2010-09-30 14:05:05.070475000 -0700 $ chmod 755 script.sh $ stat script.sh File: `script.sh' Size: 297070 Blocks: 584 IO Block: 4096 regular file Device: 811h/2065d Inode: 35515 Links: 1 Access: (0600/-rw-------) Uid: ( 1000/ xxxxxx) Gid: ( 1000/ xxxxxx) Access: 2010-09-30 14:05:16.041621000 -0700 Modify: 2010-09-30 14:05:05.070157000 -0700 Change: 2010-09-30 14:05:05.070475000 -0700
As you can see, it remains unchanged.
The mode is determined by the partition's mount options (you cannot change it via chmod).
For '755' on files and '777' on directories you would use something like
sudo mount -t ntfs -o rw,auto,user,fmask=0022,dmask=0000 /dev/whatever /mnt/whatever
What what should I put in place of `/dev/whatever` and `/mnt/whatever` if I have to change permission of my HDD partition named `/media/Prtn`
Does mounting in this way preserve the disk's original settings? I.e. it is safe to mount a Windows drive?
I set user to 'andrew' which is my main user. By ls for ntfs partition shows that all files/directories in it is own by root.
@EduardoCuomo, your comment to simply say "the real solution is..." isn't very insightful, so to anyone wondering what "the real solution is", I do agree, your answer below provides a detailed explanation of how to use `ntfs-3g`, which *does* allow the use of changeable permissions on NTFS-formatted partitions mounted in Linux.
Contrary to what most people believe, NTFS is a POSIX-compatible¹ filesystem, and it is possible to use permissions on NTFS.
To enable this, you need a "User Mapping File" or just give the
permissionsoption when mounting (when no compatibility with Windows is needed). This maps linux users on your system with the user IDs like NTFS/Windows use them internally.
See the ntfs-3g manpage for some info and some examples. If you need more information, see the ntfs-3g advanced documentation about ownership and permissions.
(Note that this does not work on FAT filesystems.)
¹ Yes, it can also store filenames that are valid in linux/unix but not under Windows, supports symlinks & hardlinks, etc.
here is good documentation. in short: `sudo ntfs-3g.usermap /dev/disk/by-label/MY-NTFS` and then `sudo mv UserMapping /media/MY-NTFS/.NTFS-3G/`
So this will allow you to arbitrarily set permissions like `chmod 655 /some/file` on the NTFS partition mounted in Linux? I'm trying to figure out how to merge my home partition from linux into c:\Users. Will using usermap allow me to retain all the permissions? I was planning on mounting the c:\Users directory to /home in linux.
Let me re-emphasize your remark: "when no compatibility with Windows is needed". ref: http://askubuntu.com/questions/92863/mount-ntfs-partition-at-startup-with-non-root-user-as-owner/517223#517223
Eduardo Cuomo wrote a pretty good example of all steps necessary to make a "User Mapping File" here: http://askubuntu.com/a/887502/327339
@WinEunuuchs2Unix & ctrl-alt-delor I updated the broken link to the 16.04 manpage (from the long-since-removed 11.04 manpage).
For NTFS partitions, use the
permissionsoption in fstab.
First unmount the ntfs partition.
Identify your partition UUID with
# Graphical gksu gedit /etc/fstab # Command line sudo -e /etc/fstab
And add or edit a line for the ntfs partition
# change the "UUID" to your partition UUID UUID=12102C02102CEB83 /media/windows ntfs-3g auto,users,permissions 0 0
Make a mount point (if needed)
sudo mkdir /media/windows
Now mount the partition
The options I gave you,
auto, will automatically mount the partition when you boot and
usersallows users to mount and umount .
You can then use chown and chmod on the ntfs partition.
What about fat32 ? I have a Micro sd card which is write protected and i cant access,format it.
@RanaMuhammadWaqas - this is an old question, but you can also mount it with different options. Hard to know what your problem is, perhaps identify your hardware and ask a separate question.
@bodhi.zazen `users` implies **noexec**, **nosuid**, and **nodev**. isn't? How users can mount/umount with `noexec` being set?
@KhurshidAlam- You should ask a question rather then post something like that in the comments on an answer.
You can always explicitly invoke the script interpreter, in which case execution permissions are not required. If the script uses bash, as can be verified by looking at the first line of the script, just run
Note that the script calls other scripts or binaries on the same partition, this won't work. Note also that the strategy doesn't work with binaries as opposed to textual script files written in Bash Script, Perl, Python or the like.
According to the Ownership and Permissions section of the NTFS-3G documentation, we can use mount options to control file access and creation. The combinations are very complicated (see the two tables there). Also I do not read and get all of them. For example, I do not know whether POSIX ACLs is selected at compile-time or not of the NTFS-3G binary package. But the best I have come out is using a User Mapping file combined with some mount options to approximate a plausible mapping of file ownership and permissions between Windows and Linux.
Warning: This is only what works best for my sharing a NTFS data partition (drive
D:on Windows) between dual-booted Windows 8 and Kubuntu 14.04. The instructions are recorded in careful retrospection but not thoroughly tested. It is too tiring and tedious to repeat the whole procedure again. So follow it at your own risk. But if you do, share back your experience. If you decide to follow the instructions, please read it fully to have a whole picture before actually acting. Good luck!
Alright, here you go! The detailed instructions consist of three parts. Part 1 should be carried out on Windows while Part 2 on Linux. Part 3 is for test.
The User Mapping section of the NTFS-3G documentation specifies two versions to set up user mapping between Windows and Linux, one Windows version and one Linux version. My experience was that the Linux version ended up with a miss. The Linux account was not mapped to my Windows account but some unknown account appeared under an SID. The result was a mess since this unknown account takes ownership of all files of my Windows account. In that situation, unless you have an administrative privilege to take your ownership back, files under your Windows account become inaccessible. But even if you mange, it is still a wrong mapping. That means, later whatever files you create on Linux get assigned to that unknown account on Windows and those on Windows get assigned to root on Linux (if I remember correctly). So on Windows you need to take ownership back again and on Linux change ownership. That is not what we expect it to be. After several hopeless attempts to fix the issue, I gave up and turned to the Windows version. That one worked. Detailed instructions extracted from the relevant section of the NTFS-3G documentation follow:
Download the usermap tool, extract it somewhere (in my case, drive
C:), better outside the NTFS partition (in my case drive
D:) to be shared.
Open the Windows command line. Change to the extracted directory
tools(by default) of the
usermaptool. Then run the following command:
C:\tools> mapuser > UserMapping
This generates a template and redirects it to a file named
UserMapping. Open the file with a text editor, say Notepad, you should see the following lines:
# Generated by usermap for Windows, v 1.1.5 # For Windows account "Account" in domain "Domain" # Replace "user" and "group" hereafter by matching Linux login user::SID :group:SID
Presumably, the first
SIDshould be your user SID while the second your group SID. You can check them respectively by commands
After you make sure the SIDs are correct, following the instructions in the comment, that is, change
user::SIDline to your user name and
:group:SIDline to your primary group name on Linux. On Ubuntu, they are the same. Moreover, add your Linux group name also after the first colon of the
user::SIDline. So the line should look something like
user:group:SID. It seems that if not doing so files created on Windows will be assigned to
Save the file. Move it to a directory named
.NTFS-3G(create it if not existent yet) on the NTFS partition to be shared (in my case drive
This step is for test in Part 3. On the shared NTFS partition, create a new directory and a new file.
Now boot into Linux.
sudoedit the file
/etc/fstab. Add or modify the line for the shared NTFS partition to something like the following:
UUID=... /data ntfs defaults,umask=077,utf8 0 0
The essential is to set the
fmaskmay also work but not tested). Pick a value for
umaskyou like, although I picked
077. It seems without this setting, full permissions will be given to
others for newly-created files.
Save the file. Now
sudo mountor remount (
sudo umountand then
sudo mount) the shared NTFS partition (in my case
$ sudo mount /data
Now (still on Linux)
cdto the mount point (in my case,
ls -lthe files there. Check whether their ownership and permissions match respectively that you specified in the
UserMappingfile and the
umaskyou set in
/etc/fstab(the match between permissions and
umaskrequires some complement calculation, see man (1) umask for more information). If they do, congratulations, half goal is achieved. Otherwise, poor you. Ask Ubuntu or Windows.
Then create a new directory and a new file.
ls -lto check their ownership and permissions. The ownership should be your user name and primary group as usual. The permissions should match the
umask. Now restart your computer and boot into Windows. Locate on the shared NTFS partition the directory and file you just created on Linux. Check their properties to see if they are assigned to your Windows account. If they are, congratulations, you are all done. Otherwise, bad luck. Ask Windows or Ubuntu.
Old thread, I know, but still relevant and missing a particular use case tip, composed from different suggestions on various other forums/threads and tested on Ubuntu GNOME 13.04 where I wanted an external drive to hold a Steam library...
When the NTFS partition is on an external usb drive, for example -- which means the partition is mounted on the fly upon connection -- then you can use the following method to make udev mount ntfs partitions with execution rights.
Open a terminal window and do:
$ sudo nano /etc/udev/rules.d/90-usb-disks.rules
Then paste this line in what should be a blank/new file (if not, then exit nano and reissue the command but starting the file name with a higher number like 91-...):
Then save and close. Unplug the drive and then do in terminal:
$ sudo service udev restart
Next, plug the drive back in and enjoy :)
sudo apt-get install -y ntfs-3g
Unmount NTFS partition:
sudo umount /mnt/windows
ntfs-3g.usermapto generate your
sudo ntfs-3g.usermap /dev/disk/by-label/MY-NTFS
sudo ntfs-3g.usermap /dev/sdb1
Remount NTFS partition to add
mount -a sudo mkdir /mnt/windows/.NTFS-3G sudo mv UserMapping /mnt/windows/.NTFS-3G/
sudo vim /etc/fstab
Update mount line:
- Backup your current mount line! Duplicate the line and comment it by adding a
#at the beginning.
- Change next:
UUID=34A0456DA04536A0 /mnt/windows ntfs defaults,uid=1000,gid=1000 0 0
- By next:
UUID=34A0456DA04536A0 /mnt/windows ntfs-3g defaults 0 0(Use
It should look something like this:
#UUID=34A0456DA04536A0 /mnt/windows ntfs defaults,uid=1000,gid=1000 0 0
UUID=34A0456DA04536A0 /mnt/windows ntfs-3g defaults 0 0
- Backup your current mount line! Duplicate the line and comment it by adding a
Finally, remount using your
sudo umount /mnt/windows sudo mount -a
Do this once for every NTFS partition you have!
WARNING WITH WINDOWS OS!
I check it with Windows 7+ and the permissions affect Windows OS! I change the permissions of my Home Directory on Windows partition, and when I used Windows again I could see that the user was broken!
Mount NTFS partition in a USB drive with custom permissions and owner
In Linux the mode of NTFS (and FAT32) is determined by the partition's mount options. You cannot change it via chmod.
Assumption: the USB drive is seen as
sdb1, modify to match the drive letter and partition number in your case. The general syntax is
xis the drive letter and
nis the partition number as seen by for example
sudo lsblk -f
Unmount the NTFS partition.
sudo umount /dev/sdxn # general syntax sudo umount /dev/sdb1 # modify to match your case
Create a custom mountpoint (only if you want a new mountpoint), for example with
sudo mkdir -p /mnt/sd1
Check your userID's
uidnumber (it is usually 1000, sometimes 1001 or 1002 ...)
grep ^"$USER" /etc/group
and use that number if you want to grab ownership (default is
Mount the NTFS partition
Example 1 (without execute permissions for files, no access for 'others'),
sudo mount -o rw,user,uid=1000,dmask=007,fmask=117 /dev/sdxn /mnt/sd1 # general syntax sudo mount -o rw,user,uid=1000,dmask=007,fmask=117 /dev/sdb1 /mnt/sd1 # modify to match your case
in this case you can run the script
Example 2 (with execute permissions for files, no access for 'others'),
sudo mount -o rw,user,uid=1000,umask=007,exec /dev/sdxn /mnt/sd1 # general syntax sudo mount -o rw,user,uid=1000,umask=007,exec /dev/sdb1 /mnt/sd1 # modify to match your case
In this case you can run the script
and you can run executable programs too from this location (not that it is recommended).
Example 3 (full permissions for everybody, which is convenient but not safe, when there are several users),
sudo mount -o rw,users,umask=000,exec /dev/sdxn /mnt/sd1 # general sudo mount -o rw,users,umask=000,exec /dev/sdb1 /mnt/sd1 # modify to match your case
`/media$ sudo mkdir -p sdb1` `/media$ sudo mount -o rw,users,umask=000,exec /dev/sdb1 ./sdb1/ mount: block device /dev/sdb1 is write-protected, mounting read-only`
@alhelal, I am afraid that the hardware of your USB drive has become read-only or 'grid-locked'. But there might also be some problem with the file system, and if the file system is corrupted, you might be able to fix it by repairing it in Windows, either with the GUI method or with the command line `chkdsk /f X:` according to this link https://ubuntuforums.org/showthread.php?t=2196858&;p=13409986#post13409986 -- If still no luck, backup the data and try according to https://askubuntu.com/questions/144852/cant-format-my-usb-drive-i-have-already-tried-with-mkdosfs-and-gparted/933035#933035