diff options
author | jilles <jilles@FreeBSD.org> | 2015-02-08 22:24:03 +0000 |
---|---|---|
committer | jilles <jilles@FreeBSD.org> | 2015-02-08 22:24:03 +0000 |
commit | fb8fcd2a04cbf8224f6a40717c3f9a8a2c24fdbd (patch) | |
tree | e06f6d228bc98a7525065723eac7b9953702f8e5 /lib | |
parent | 969542edef027a0d305a42e2ede2c367050e807b (diff) | |
download | FreeBSD-src-fb8fcd2a04cbf8224f6a40717c3f9a8a2c24fdbd.zip FreeBSD-src-fb8fcd2a04cbf8224f6a40717c3f9a8a2c24fdbd.tar.gz |
MFC r278038: ttyname_r(): Return actual error, not always [ENOTTY].
Adjust the test that used to fail because of this bug.
PR: 191936
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libc/gen/ttyname.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/libc/gen/ttyname.c b/lib/libc/gen/ttyname.c index a21b77f..02aa158 100644 --- a/lib/libc/gen/ttyname.c +++ b/lib/libc/gen/ttyname.c @@ -65,7 +65,7 @@ ttyname_r(int fd, char *buf, size_t len) /* Must be a terminal. */ if (!isatty(fd)) - return (ENOTTY); + return (errno); /* Must have enough room */ if (len <= sizeof(_PATH_DEV)) return (ERANGE); @@ -73,7 +73,7 @@ ttyname_r(int fd, char *buf, size_t len) strcpy(buf, _PATH_DEV); used = strlen(buf); if (fdevname_r(fd, buf + used, len - used) == NULL) - return (ENOTTY); + return (errno == EINVAL ? ERANGE : errno); return (0); } |