work around linux bug in readlink syscall with zero buffer size
authorRich Felker <dalias@aerifal.cx>
Tue, 24 Nov 2020 00:44:19 +0000 (19:44 -0500)
committerRich Felker <dalias@aerifal.cx>
Tue, 24 Nov 2020 00:44:19 +0000 (19:44 -0500)
commite2fa720be7024cce4fc489f3877476d35da48ee2
tree624a4b85cc7aacccc9a359eaf0ffc00a614ffddf
parentc17cda6d61bc24d5bb51b0837d951da063a1fba5
work around linux bug in readlink syscall with zero buffer size

linux fails with EINVAL when a zero buffer size is passed to the
syscall. this is non-conforming because POSIX already defines EINVAL
with a significantly different meaning: the target is not a symlink.

since the request is semantically valid, patch it up by using a dummy
buffer of length one, and truncating the return value to zero if it
succeeds.
src/unistd/readlink.c
src/unistd/readlinkat.c