00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021 #include <unistd.h>
00022 #include <fcntl.h>
00023 #include "timer.h"
00024 #include "time.h"
00025 #include "random_seed.h"
00026 #include "avutil.h"
00027
00028 static int read_random(uint32_t *dst, const char *file)
00029 {
00030 int fd = open(file, O_RDONLY);
00031 int err = -1;
00032
00033 if (fd == -1)
00034 return -1;
00035 err = read(fd, dst, sizeof(*dst));
00036 close(fd);
00037
00038 return err;
00039 }
00040
00041 static uint32_t get_generic_seed(void)
00042 {
00043 clock_t last_t=0;
00044 int bits=0;
00045 uint64_t random=0;
00046 unsigned i;
00047 float s=0.000000000001;
00048
00049 for(i=0;bits<64;i++){
00050 clock_t t= clock();
00051 if(last_t && fabs(t-last_t)>s || t==(clock_t)-1){
00052 if(i<10000 && s<(1<<24)){
00053 s+=s;
00054 i=t=0;
00055 }else{
00056 random= 2*random + (i&1);
00057 bits++;
00058 }
00059 }
00060 last_t= t;
00061 }
00062 #ifdef AV_READ_TIME
00063 random ^= AV_READ_TIME();
00064 #else
00065 random ^= clock();
00066 #endif
00067
00068 random += random>>32;
00069
00070 return random;
00071 }
00072
00073 uint32_t av_get_random_seed(void)
00074 {
00075 uint32_t seed;
00076
00077 if (read_random(&seed, "/dev/urandom") == sizeof(seed))
00078 return seed;
00079 if (read_random(&seed, "/dev/random") == sizeof(seed))
00080 return seed;
00081 return get_generic_seed();
00082 }