forked from aniani/vim
patch 9.0.1015: without /dev/urandom srand() seed is too predictable
Problem: Without /dev/urandom srand() seed is too predictable. Solution: Use micro seconds and XOR with process ID. (Yasuhiro Matsumoto, closes #11656)
This commit is contained in:
committed by
Bram Moolenaar
parent
25201016d5
commit
f0a9c00482
@@ -8159,9 +8159,32 @@ init_srand(UINT32_T *x)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (dev_urandom_state != OK)
|
if (dev_urandom_state != OK)
|
||||||
// Reading /dev/urandom doesn't work, fall back to time().
|
|
||||||
#endif
|
#endif
|
||||||
|
{
|
||||||
|
// Reading /dev/urandom doesn't work, fall back to:
|
||||||
|
// - randombytes_random()
|
||||||
|
// - reltime() or time()
|
||||||
|
// - XOR with process ID
|
||||||
|
#if defined(FEAT_SODIUM)
|
||||||
|
if (sodium_init() >= 0)
|
||||||
|
*x = randombytes_random();
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
#if defined(FEAT_RELTIME)
|
||||||
|
proftime_T res;
|
||||||
|
profile_start(&res);
|
||||||
|
# if defined(MSWIN)
|
||||||
|
*x = (UINT32_T)res.LowPart;
|
||||||
|
# else
|
||||||
|
*x = (UINT32_T)res.tv_usec;
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
*x = vim_time();
|
*x = vim_time();
|
||||||
|
#endif
|
||||||
|
*x ^= mch_get_pid();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ROTL(x, k) (((x) << (k)) | ((x) >> (32 - (k))))
|
#define ROTL(x, k) (((x) << (k)) | ((x) >> (32 - (k))))
|
||||||
|
@@ -1,5 +1,8 @@
|
|||||||
" Tests for srand() and rand()
|
" Tests for srand() and rand()
|
||||||
|
|
||||||
|
source check.vim
|
||||||
|
source shared.vim
|
||||||
|
|
||||||
func Test_Rand()
|
func Test_Rand()
|
||||||
let r = srand(123456789)
|
let r = srand(123456789)
|
||||||
call assert_equal([1573771921, 319883699, 2742014374, 1324369493], r)
|
call assert_equal([1573771921, 319883699, 2742014374, 1324369493], r)
|
||||||
@@ -44,4 +47,20 @@ func Test_issue_5587()
|
|||||||
call rand()
|
call rand()
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_srand()
|
||||||
|
CheckNotGui
|
||||||
|
|
||||||
|
let cmd = GetVimCommand() .. ' -V -es -c "echo rand()" -c qa!'
|
||||||
|
let bad = 0
|
||||||
|
for _ in range(10)
|
||||||
|
echo cmd
|
||||||
|
let result1 = system(cmd)
|
||||||
|
let result2 = system(cmd)
|
||||||
|
if result1 ==# result2
|
||||||
|
let bad += 1
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
call assert_inrange(0, 4, bad)
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -695,6 +695,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1015,
|
||||||
/**/
|
/**/
|
||||||
1014,
|
1014,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user