From: Rich Felker Date: Tue, 15 Feb 2011 02:15:07 +0000 (-0500) Subject: guard against hard links to non-ordinary-files when reading tcb shadow X-Git-Tag: v0.5.9~2 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=976f42d1f15c135e4e0dd79eb6168b67c2ec6492;p=oweals%2Fmusl.git guard against hard links to non-ordinary-files when reading tcb shadow --- diff --git a/src/passwd/getspnam_r.c b/src/passwd/getspnam_r.c index 1dd39ce0..d21ca810 100644 --- a/src/passwd/getspnam_r.c +++ b/src/passwd/getspnam_r.c @@ -1,5 +1,6 @@ #include #include +#include #include "pwf.h" /* This implementation support Openwall-style TCB passwords in place of @@ -34,8 +35,9 @@ int getspnam_r(const char *name, struct spwd *sp, char *buf, size_t size, struct fd = open(path, O_RDONLY|O_NOFOLLOW|O_NONBLOCK); if (fd >= 0) { - f = fdopen(fd, "rb"); - if (!f) { + struct stat st = { 0 }; + errno = EINVAL; + if (fstat(fd, &st) || !S_ISREG(st.st_mode) || !(f = fdopen(fd, "rb"))) { close(fd); return errno; }