hurd: fix ptsname error when called on a non-tty
authorSamuel Thibault <samuel.thibault@ens-lyon.org>
Thu, 28 May 2020 10:22:36 +0000 (10:22 +0000)
committerSamuel Thibault <samuel.thibault@ens-lyon.org>
Thu, 28 May 2020 10:22:36 +0000 (10:22 +0000)
* sysdeps/mach/hurd/ptsname.c (__ptsname_internal): Replace
not-supported errors from __term_get_peername with ENOTTY.

sysdeps/mach/hurd/ptsname.c

index 87fac8f..9627f97 100644 (file)
@@ -48,7 +48,11 @@ __ptsname_internal (int fd, char *buf, size_t buflen, struct stat64 *stp)
   error_t err;
 
   if (err = HURD_DPORT_USE (fd, __term_get_peername (port, peername)))
-    return __hurd_dfail (fd, err), errno;
+    {
+      if (err == EMIG_BAD_ID || err == EOPNOTSUPP)
+       err = ENOTTY;
+      return __hurd_dfail (fd, err), errno;
+    }
 
   len = __strnlen (peername, sizeof peername - 1) + 1;
   if (len > buflen)