aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsin <sin@2f30.org>2014-11-07 13:20:13 +0000
committersin <sin@2f30.org>2014-11-09 13:10:02 +0000
commit4339b507af01421e2deab63ca9ac3c5bdae5f4cc (patch)
tree3b63f8444d7090ea08cfd5c32f69501dc87deeec
parentOnly check errno if getpwuid() fails (diff)
downloadslock-4339b507af01421e2deab63ca9ac3c5bdae5f4cc.tar.gz
slock-4339b507af01421e2deab63ca9ac3c5bdae5f4cc.tar.bz2
slock-4339b507af01421e2deab63ca9ac3c5bdae5f4cc.tar.xz
slock-4339b507af01421e2deab63ca9ac3c5bdae5f4cc.tar.zst
slock-4339b507af01421e2deab63ca9ac3c5bdae5f4cc.zip
end{pw,sp}ent() can only be called after get{pw,sp}ent()
Calling them unconditionally can result in memory corruption.
-rw-r--r--slock.c2
1 files changed, 0 insertions, 2 deletions
diff --git a/slock.c b/slock.c
index 399386b..d281965 100644
--- a/slock.c
+++ b/slock.c
@@ -73,7 +73,6 @@ getpw(void) { /* only run as root */
else
die("slock: cannot retrieve password entry (make sure to suid or sgid slock)\n");
}
- endpwent();
rval = pw->pw_passwd;
#if HAVE_SHADOW_H
@@ -82,7 +81,6 @@ getpw(void) { /* only run as root */
sp = getspnam(getenv("USER"));
if(!sp)
die("slock: cannot retrieve shadow entry (make sure to suid or sgid slock)\n");
- endspent();
rval = sp->sp_pwdp;
}
#endif