2014-07-11 22:12:11 +02:00
|
|
|
/*
|
|
|
|
This file is part of libcapwap.
|
|
|
|
|
|
|
|
libcapwap is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
libcapwap is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with Foobar. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2015-03-08 11:36:30 +01:00
|
|
|
#include <stdlib.h>
|
2014-07-11 22:12:11 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
#include "cw_util.h"
|
|
|
|
#include "cw_log.h"
|
|
|
|
|
|
|
|
char * cw_rand_dev = "/dev/random";
|
|
|
|
|
2015-03-08 11:36:30 +01:00
|
|
|
int cw_rand_r(uint8_t*dst, int len)
|
2014-07-11 22:12:11 +02:00
|
|
|
{
|
|
|
|
int rf;
|
|
|
|
int l;
|
|
|
|
|
|
|
|
rf = open(cw_rand_dev, O_RDONLY | O_NDELAY);
|
|
|
|
if (rf<0){
|
|
|
|
|
|
|
|
cw_log(LOG_ERR,"Can't open %s: %s",cw_rand_dev,strerror(errno));
|
2015-03-08 11:36:30 +01:00
|
|
|
return 0;
|
2014-07-11 22:12:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
l = read(rf, dst, len);
|
|
|
|
close(rf);
|
|
|
|
|
|
|
|
if ((l<0) && (errno != EAGAIN)){
|
|
|
|
cw_log(LOG_ERR,"Cant read from %s: %s",cw_rand_dev,strerror(errno));
|
2015-03-08 11:36:30 +01:00
|
|
|
return 0;
|
2014-07-11 22:12:11 +02:00
|
|
|
}
|
|
|
|
|
2015-03-08 11:36:30 +01:00
|
|
|
/* if (l<len){
|
2015-02-07 11:51:29 +01:00
|
|
|
cw_dbg(DBG_CW_INFO,"Not enough entropy reading from %s, using pseudo rand",cw_rand_dev);
|
2014-07-11 22:12:11 +02:00
|
|
|
return cw_pseudo_rand(dst,len);
|
|
|
|
}
|
2015-03-08 11:36:30 +01:00
|
|
|
*/
|
2014-07-11 22:12:11 +02:00
|
|
|
return l;
|
|
|
|
}
|
2015-03-08 11:36:30 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int cw_rand(uint8_t *dst, int len)
|
|
|
|
{
|
|
|
|
static int init = 1;
|
|
|
|
if (init){
|
|
|
|
uint32_t rinit=time(NULL);
|
|
|
|
|
|
|
|
int l = cw_rand_r((uint8_t*)(&rinit),sizeof(uint32_t));
|
|
|
|
if (l<sizeof(uint32_t))
|
|
|
|
cw_dbg(DBG_CW_INFO,"Not enough entropy reading from %s, using pseudo rand",cw_rand_dev);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
srand(rinit);
|
|
|
|
init =0;
|
|
|
|
}
|
|
|
|
int i;
|
|
|
|
for (i=0; i<len; i++){
|
|
|
|
dst[i]=rand();
|
|
|
|
}
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
|
|
|
|