summaryrefslogtreecommitdiff
path: root/libbb/pw_encrypt.c
diff options
context:
space:
mode:
authorDenys Vlasenko2014-02-09 14:38:03 +0100
committerDenys Vlasenko2014-02-09 14:38:03 +0100
commit8ed96726603a59969b99e4ea30dbd9b06955084b (patch)
tree6e9a14154a4ee84e41d195dcd636a1e65e651b9d /libbb/pw_encrypt.c
parent4e03d4134202b117a29ecf5933a7a55e2a8532a4 (diff)
downloadbusybox-8ed96726603a59969b99e4ea30dbd9b06955084b.zip
busybox-8ed96726603a59969b99e4ea30dbd9b06955084b.tar.gz
libbb: don't die if crypt() returns NULL
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb/pw_encrypt.c')
-rw-r--r--libbb/pw_encrypt.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/libbb/pw_encrypt.c b/libbb/pw_encrypt.c
index 39ffa08..bfc7030 100644
--- a/libbb/pw_encrypt.c
+++ b/libbb/pw_encrypt.c
@@ -142,7 +142,14 @@ char* FAST_FUNC pw_encrypt(const char *clear, const char *salt, int cleanup)
char* FAST_FUNC pw_encrypt(const char *clear, const char *salt, int cleanup)
{
- return xstrdup(crypt(clear, salt));
+ char *s;
+
+ s = crypt(clear, salt);
+ /*
+ * glibc used to return "" on malformed salts (for example, ""),
+ * but since 2.17 it returns NULL.
+ */
+ return xstrdup(s ? s : "");
}
#endif