]> git.sesse.net Git - ffmpeg/blobdiff - libavutil/random_seed.c
Merge remote-tracking branch 'qatar/master'
[ffmpeg] / libavutil / random_seed.c
index 86c60f3838e0c0b02199998fd47da56b02ced904..81805e5db0db09abfbbe4352ec8ef8cc96b773df 100644 (file)
 
 #include <unistd.h>
 #include <fcntl.h>
+#include <math.h>
+#include <time.h>
 #include "timer.h"
 #include "random_seed.h"
-#include "avutil.h"
 
 static int read_random(uint32_t *dst, const char *file)
 {
@@ -37,6 +38,38 @@ static int read_random(uint32_t *dst, const char *file)
     return err;
 }
 
+static uint32_t get_generic_seed(void)
+{
+    clock_t last_t=0;
+    int bits=0;
+    uint64_t random=0;
+    unsigned i;
+    float s=0.000000000001;
+
+    for(i=0;bits<64;i++){
+        clock_t t= clock();
+        if(last_t && fabs(t-last_t)>s || t==(clock_t)-1){
+            if(i<10000 && s<(1<<24)){
+                s+=s;
+                i=t=0;
+            }else{
+                random= 2*random + (i&1);
+                bits++;
+            }
+        }
+        last_t= t;
+    }
+#ifdef AV_READ_TIME
+    random ^= AV_READ_TIME();
+#else
+    random ^= clock();
+#endif
+
+    random += random>>32;
+
+    return random;
+}
+
 uint32_t av_get_random_seed(void)
 {
     uint32_t seed;
@@ -45,18 +78,5 @@ uint32_t av_get_random_seed(void)
         return seed;
     if (read_random(&seed, "/dev/random")  == sizeof(seed))
         return seed;
-
-#ifdef AV_READ_TIME
-    seed = AV_READ_TIME();
-#endif
-    // XXX what to do ?
-    return seed;
+    return get_generic_seed();
 }
-
-#if LIBAVUTIL_VERSION_MAJOR < 51
-attribute_deprecated uint32_t ff_random_get_seed(void);
-uint32_t ff_random_get_seed(void)
-{
-    return av_get_random_seed();
-}
-#endif