|
|
Message-Id: <1381126104-24579-1-git-send-email-mforney@mforney.org>
Date: Sun, 6 Oct 2013 23:08:24 -0700
From: Michael Forney <mforney@...rney.org>
To: musl@...ts.openwall.com
Subject: [PATCH] getcwd: Set errno to EINVAL when size == 0
According to POSIX,
The getcwd() function shall fail if:
[EINVAL]
The size argument is 0.
[ERANGE]
The size argument is greater than 0, but is smaller than the length
of the string +1.
---
src/unistd/getcwd.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/src/unistd/getcwd.c b/src/unistd/getcwd.c
index 2e540cd..0238fa7 100644
--- a/src/unistd/getcwd.c
+++ b/src/unistd/getcwd.c
@@ -8,6 +8,10 @@ char *getcwd(char *buf, size_t size)
{
char tmp[PATH_MAX];
if (!buf) buf = tmp, size = PATH_MAX;
+ else if (size == 0) {
+ errno = EINVAL;
+ return 0;
+ }
if (syscall(SYS_getcwd, buf, size) < 0) return 0;
return buf == tmp ? strdup(buf) : buf;
}
--
1.8.4
Powered by blists - more mailing lists
Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.