[FFmpeg-cvslog] r24102 - trunk/libavutil/random_seed.c

michael subversion
Thu Jul 8 01:47:49 CEST 2010


Author: michael
Date: Thu Jul  8 01:47:48 2010
New Revision: 24102

Log:
get_generic_seed() for the cases without /dev/random and AV_READ_TIME

Modified:
   trunk/libavutil/random_seed.c

Modified: trunk/libavutil/random_seed.c
==============================================================================
--- trunk/libavutil/random_seed.c	Thu Jul  8 01:41:42 2010	(r24101)
+++ trunk/libavutil/random_seed.c	Thu Jul  8 01:47:48 2010	(r24102)
@@ -21,6 +21,7 @@
 #include <unistd.h>
 #include <fcntl.h>
 #include "timer.h"
+#include "time.h"
 #include "random_seed.h"
 #include "avutil.h"
 
@@ -37,6 +38,38 @@ static int read_random(uint32_t *dst, co
     return err;
 }
 
+static uint32_t get_generic_seed(void)
+{
+    int last_t=0;
+    int bits=0;
+    uint64_t random=0;
+    int i;
+    int s=0;
+
+    for(i=0;bits<64;i++){
+        int t= clock()>>s;
+        if(last_t && t != last_t){
+            if(i<10000U && s<24){
+                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,12 +78,7 @@ 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



More information about the ffmpeg-cvslog mailing list