* [PATCH 1/4] Use re-entrant variants of getpwnam and getgrnam
@ 2008-10-22 14:13 Alan Jenkins
2008-10-22 16:25 ` Kay Sievers
0 siblings, 1 reply; 2+ messages in thread
From: Alan Jenkins @ 2008-10-22 14:13 UTC (permalink / raw)
To: linux-hotplug
Signed-off-by: Alan Jenkins <alan-jenkins@tuffmail.co.uk>
diff --git a/udev/udev-util.c b/udev/udev-util.c
index 76445bb..204c096 100644
--- a/udev/udev-util.c
+++ b/udev/udev-util.c
@@ -126,13 +126,16 @@ int util_unlink_secure(struct udev *udev, const char *filename)
uid_t util_lookup_user(struct udev *udev, const char *user)
{
+ int buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
+ char buf[buflen];
+ struct passwd pwbuf;
struct passwd *pw;
uid_t uid = 0;
if (strcmp(user, "root") = 0)
return 0;
errno = 0;
- pw = getpwnam(user);
+ getpwnam_r(user, &pwbuf, buf, buflen, &pw);
if (pw = NULL) {
if (errno = 0 || errno = ENOENT || errno = ESRCH)
err(udev, "specified user '%s' unknown\n", user);
@@ -140,18 +143,22 @@ uid_t util_lookup_user(struct udev *udev, const char *user)
err(udev, "error resolving user '%s': %m\n", user);
} else
uid = pw->pw_uid;
+
return uid;
}
extern gid_t util_lookup_group(struct udev *udev, const char *group)
{
+ int buflen = sysconf(_SC_GETGR_R_SIZE_MAX);
+ char buf[buflen];
+ struct group grbuf;
struct group *gr;
gid_t gid = 0;
if (strcmp(group, "root") = 0)
return 0;
errno = 0;
- gr = getgrnam(group);
+ getgrnam_r(group, &grbuf, buf, buflen, &gr);
if (gr = NULL) {
if (errno = 0 || errno = ENOENT || errno = ESRCH)
err(udev, "specified group '%s' unknown\n", group);
^ permalink raw reply related [flat|nested] 2+ messages in thread
end of thread, other threads:[~2008-10-22 16:25 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-10-22 14:13 [PATCH 1/4] Use re-entrant variants of getpwnam and getgrnam Alan Jenkins
2008-10-22 16:25 ` Kay Sievers
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).