[FFmpeg-cvslog] libavutil/random_seed: Ensure that get_generic_seed() spends at least 1/ 32 sec gathering entropy
Michael Niedermayer
git at videolan.org
Sat Dec 31 18:20:19 EET 2016
ffmpeg | branch: master | Michael Niedermayer <michael at niedermayer.cc> | Thu Dec 29 00:34:57 2016 +0100| [7525517593dff427021c893a1b21333510b7803b] | committer: Michael Niedermayer
libavutil/random_seed: Ensure that get_generic_seed() spends at least 1/32 sec gathering entropy
This may fix the failures on windows
Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=7525517593dff427021c893a1b21333510b7803b
---
libavutil/random_seed.c | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/libavutil/random_seed.c b/libavutil/random_seed.c
index 0c58c8f..d1c9a3f 100644
--- a/libavutil/random_seed.c
+++ b/libavutil/random_seed.c
@@ -68,6 +68,7 @@ static uint32_t get_generic_seed(void)
struct AVSHA *sha = (void*)tmp;
clock_t last_t = 0;
clock_t last_td = 0;
+ clock_t init_t = 0;
static uint64_t i = 0;
static uint32_t buffer[512] = { 0 };
unsigned char digest[20];
@@ -93,10 +94,13 @@ static uint32_t get_generic_seed(void)
} else {
last_td = t - last_t;
buffer[++i & 511] += last_td % 3294638521U;
- if (last_i && i - last_i > 4 || i - last_i > 64 || TEST && i - last_i > 8)
- break;
+ if ((t - init_t) >= CLOCKS_PER_SEC>>5)
+ if (last_i && i - last_i > 4 || i - last_i > 64 || TEST && i - last_i > 8)
+ break;
}
last_t = t;
+ if (!init_t)
+ init_t = t;
}
if(TEST) {
More information about the ffmpeg-cvslog
mailing list