| OLD | NEW | 
| (Empty) |  | 
 |   1 #include <crypt.h> | 
 |   2 #include "libc.h" | 
 |   3  | 
 |   4 struct crypt_data; | 
 |   5  | 
 |   6 char *__crypt_des(const char *, const char *, char *); | 
 |   7 char *__crypt_md5(const char *, const char *, char *); | 
 |   8 char *__crypt_blowfish(const char *, const char *, char *); | 
 |   9 char *__crypt_sha256(const char *, const char *, char *); | 
 |  10 char *__crypt_sha512(const char *, const char *, char *); | 
 |  11  | 
 |  12 char *__crypt_r(const char *key, const char *salt, struct crypt_data *data) | 
 |  13 { | 
 |  14         /* Per the crypt_r API, the caller has provided a pointer to | 
 |  15          * struct crypt_data; however, this implementation does not | 
 |  16          * use the structure to store any internal state, and treats | 
 |  17          * it purely as a char buffer for storing the result. */ | 
 |  18         char *output = (char *)data; | 
 |  19         if (salt[0] == '$' && salt[1] && salt[2]) { | 
 |  20                 if (salt[1] == '1' && salt[2] == '$') | 
 |  21                         return __crypt_md5(key, salt, output); | 
 |  22                 if (salt[1] == '2' && salt[3] == '$') | 
 |  23                         return __crypt_blowfish(key, salt, output); | 
 |  24                 if (salt[1] == '5' && salt[2] == '$') | 
 |  25                         return __crypt_sha256(key, salt, output); | 
 |  26                 if (salt[1] == '6' && salt[2] == '$') | 
 |  27                         return __crypt_sha512(key, salt, output); | 
 |  28         } | 
 |  29         return __crypt_des(key, salt, output); | 
 |  30 } | 
 |  31  | 
 |  32 weak_alias(__crypt_r, crypt_r); | 
| OLD | NEW |