mirror of
git://git.musl-libc.org/musl
synced 2025-04-01 22:48:38 +00:00
fix off-by-one error in getgrnam_r and getgrgid_r, clobbering gr_name
bug report and patch by Michael Forney. the terminating null pointer at the end of the gr_mem array was overwriting the beginning of the string data, causing the gr_name member to always be a zero-length string.
This commit is contained in:
parent
211264e46a
commit
23b8e3bc95
@ -26,14 +26,14 @@ static int getgr_r(const char *name, gid_t gid, struct group *gr, char *buf, siz
|
||||
while (__getgrent_a(f, gr, &line, &len, &mem, &nmem)) {
|
||||
if (name && !strcmp(name, gr->gr_name)
|
||||
|| !name && gr->gr_gid == gid) {
|
||||
if (size < len + nmem*sizeof(char *) + 32) {
|
||||
if (size < len + (nmem+1)*sizeof(char *) + 32) {
|
||||
rv = ERANGE;
|
||||
break;
|
||||
}
|
||||
*res = gr;
|
||||
buf += (16-(uintptr_t)buf)%16;
|
||||
gr->gr_mem = (void *)buf;
|
||||
buf += nmem*sizeof(char *);
|
||||
buf += (nmem+1)*sizeof(char *);
|
||||
memcpy(buf, line, len);
|
||||
FIX(name);
|
||||
FIX(passwd);
|
||||
|
Loading…
Reference in New Issue
Block a user