diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2015-02-10 23:41:16 +0300 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2015-02-10 23:41:16 +0300 |
commit | d260e928595c4d775e7c7e1b039875b882b3a615 (patch) | |
tree | bcc424ba41baf4941dec5e6277dd5edc2e812ef3 /winsup/cygwin/syscalls.cc | |
parent | 22d65acb9c2e5bde58d5cf1d50e3fc3b4f186e1e (diff) |
* syscalls.cc (fhandler_base::stat_fixup): Generate unique inode number
for /dev/tty under all circumstances. Add to comment.
Diffstat (limited to 'winsup/cygwin/syscalls.cc')
-rw-r--r-- | winsup/cygwin/syscalls.cc | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/winsup/cygwin/syscalls.cc b/winsup/cygwin/syscalls.cc index 9890db4f2..780302b49 100644 --- a/winsup/cygwin/syscalls.cc +++ b/winsup/cygwin/syscalls.cc @@ -1720,10 +1720,21 @@ void fhandler_base::stat_fixup (struct stat *buf) { /* For devices, set inode number to device number. This gives us a valid, - unique inode number without having to call hash_path_name. */ + unique inode number without having to call hash_path_name. /dev/tty needs + a bit of persuasion to get the same st_ino value in stat and fstat. */ if (!buf->st_ino) - buf->st_ino = (get_major () == DEV_VIRTFS_MAJOR) ? get_ino () - : get_device (); + { + if (get_major () == DEV_VIRTFS_MAJOR) + buf->st_ino = get_ino (); + else if (dev () == FH_TTY || + ((get_major () == DEV_PTYS_MAJOR + || get_major () == DEV_CONS_MAJOR) + && !strcmp (get_name (), "/dev/tty"))) + buf->st_ino = FH_TTY; + else + buf->st_ino = get_device (); + + } /* For /dev-based devices, st_dev must be set to the device number of /dev, not it's own device major/minor numbers. What we do here to speed up the process is to fetch the device number of /dev only once, liberally |