diff options
Diffstat (limited to 'libbb/pw_encrypt.c')
-rw-r--r-- | libbb/pw_encrypt.c | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/libbb/pw_encrypt.c b/libbb/pw_encrypt.c index c6c04d44a..39ffa084f 100644 --- a/libbb/pw_encrypt.c +++ b/libbb/pw_encrypt.c | |||
@@ -27,9 +27,10 @@ static int i64c(int i) | |||
27 | return ('a' - 38 + i); | 27 | return ('a' - 38 + i); |
28 | } | 28 | } |
29 | 29 | ||
30 | int FAST_FUNC crypt_make_salt(char *p, int cnt, int x) | 30 | int FAST_FUNC crypt_make_salt(char *p, int cnt /*, int x */) |
31 | { | 31 | { |
32 | x += getpid() + time(NULL); | 32 | /* was: x += ... */ |
33 | int x = getpid() + monotonic_us(); | ||
33 | do { | 34 | do { |
34 | /* x = (x*1664525 + 1013904223) % 2^32 generator is lame | 35 | /* x = (x*1664525 + 1013904223) % 2^32 generator is lame |
35 | * (low-order bit is not "random", etc...), | 36 | * (low-order bit is not "random", etc...), |
@@ -47,6 +48,26 @@ int FAST_FUNC crypt_make_salt(char *p, int cnt, int x) | |||
47 | return x; | 48 | return x; |
48 | } | 49 | } |
49 | 50 | ||
51 | char* FAST_FUNC crypt_make_pw_salt(char salt[MAX_PW_SALT_LEN], const char *algo) | ||
52 | { | ||
53 | int len = 2/2; | ||
54 | char *salt_ptr = salt; | ||
55 | if (algo[0] != 'd') { /* not des */ | ||
56 | len = 8/2; /* so far assuming md5 */ | ||
57 | *salt_ptr++ = '$'; | ||
58 | *salt_ptr++ = '1'; | ||
59 | *salt_ptr++ = '$'; | ||
60 | #if !ENABLE_USE_BB_CRYPT || ENABLE_USE_BB_CRYPT_SHA | ||
61 | if (algo[0] == 's') { /* sha */ | ||
62 | salt[1] = '5' + (strcmp(algo, "sha512") == 0); | ||
63 | len = 16/2; | ||
64 | } | ||
65 | #endif | ||
66 | } | ||
67 | crypt_make_salt(salt_ptr, len); | ||
68 | return salt_ptr; | ||
69 | } | ||
70 | |||
50 | #if ENABLE_USE_BB_CRYPT | 71 | #if ENABLE_USE_BB_CRYPT |
51 | 72 | ||
52 | static char* | 73 | static char* |