Merge pull request #39 from antma/master
improve portability by removing rdtsc calls
This commit is contained in:
commit
ea2dbbdf61
@ -90,14 +90,13 @@ struct connection_methods auth_methods = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
long long precise_time;
|
long long precise_time;
|
||||||
long long precise_time_rdtsc;
|
|
||||||
double get_utime (int clock_id) {
|
double get_utime (int clock_id) {
|
||||||
struct timespec T;
|
struct timespec T;
|
||||||
my_clock_gettime (clock_id, &T);
|
my_clock_gettime (clock_id, &T);
|
||||||
double res = T.tv_sec + (double) T.tv_nsec * 1e-9;
|
double res = T.tv_sec + (double) T.tv_nsec * 1e-9;
|
||||||
if (clock_id == CLOCK_REALTIME) {
|
if (clock_id == CLOCK_REALTIME) {
|
||||||
precise_time = (long long) (res * (1LL << 32));
|
precise_time = (long long) (res * (1LL << 32));
|
||||||
precise_time_rdtsc = rdtsc ();
|
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -65,6 +65,8 @@ int get_random_bytes (unsigned char *buf, int n) {
|
|||||||
if (verbosity >= 3) {
|
if (verbosity >= 3) {
|
||||||
logprintf ( "added %d bytes of real entropy to secure random numbers seed\n", r);
|
logprintf ( "added %d bytes of real entropy to secure random numbers seed\n", r);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
r = 0;
|
||||||
}
|
}
|
||||||
close (h);
|
close (h);
|
||||||
}
|
}
|
||||||
@ -76,13 +78,12 @@ int get_random_bytes (unsigned char *buf, int n) {
|
|||||||
}
|
}
|
||||||
int s = read (h, buf + r, n - r);
|
int s = read (h, buf + r, n - r);
|
||||||
close (h);
|
close (h);
|
||||||
if (s < 0) {
|
if (s > 0) {
|
||||||
return r;
|
r += s;
|
||||||
}
|
}
|
||||||
r += s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (r >= (int)sizeof (long)) {
|
if (r >= (int) sizeof (long)) {
|
||||||
*(long *)buf ^= lrand48 ();
|
*(long *)buf ^= lrand48 ();
|
||||||
srand48 (*(long *)buf);
|
srand48 (*(long *)buf);
|
||||||
}
|
}
|
||||||
@ -105,38 +106,62 @@ void my_clock_gettime (int clock_id UU, struct timespec *T) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* RDTSC */
|
||||||
|
#if defined(__i386__)
|
||||||
|
#define HAVE_RDTSC
|
||||||
|
static __inline__ unsigned long long rdtsc (void) {
|
||||||
|
unsigned long long int x;
|
||||||
|
__asm__ volatile ("rdtsc" : "=A" (x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#elif defined(__x86_64__)
|
||||||
|
#define HAVE_RDTSC
|
||||||
|
static __inline__ unsigned long long rdtsc (void) {
|
||||||
|
unsigned hi, lo;
|
||||||
|
__asm__ __volatile__ ("rdtsc" : "=a"(lo), "=d"(hi));
|
||||||
|
return ((unsigned long long) lo) | (((unsigned long long) hi) << 32);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void prng_seed (const char *password_filename, int password_length) {
|
void prng_seed (const char *password_filename, int password_length) {
|
||||||
unsigned char *a = talloc0 (64 + password_length);
|
|
||||||
long long r = rdtsc ();
|
|
||||||
struct timespec T;
|
struct timespec T;
|
||||||
my_clock_gettime (CLOCK_REALTIME, &T);
|
my_clock_gettime (CLOCK_REALTIME, &T);
|
||||||
memcpy (a, &T.tv_sec, 4);
|
RAND_add (&T, sizeof (T), 4.0);
|
||||||
memcpy (a+4, &T.tv_nsec, 4);
|
#ifdef HAVE_RDTSC
|
||||||
memcpy (a+8, &r, 8);
|
unsigned long long r = rdtsc ();
|
||||||
|
RAND_add (&r, 8, 4.0);
|
||||||
|
#endif
|
||||||
unsigned short p = getpid ();
|
unsigned short p = getpid ();
|
||||||
memcpy (a + 16, &p, 2);
|
RAND_add (&p, sizeof (p), 0.0);
|
||||||
int s = get_random_bytes (a + 18, 32) + 18;
|
p = getppid ();
|
||||||
if (password_filename) {
|
RAND_add (&p, sizeof (p), 0.0);
|
||||||
|
unsigned char rb[32];
|
||||||
|
int s = get_random_bytes (rb, 32);
|
||||||
|
if (s > 0) {
|
||||||
|
RAND_add (rb, s, s);
|
||||||
|
}
|
||||||
|
memset (rb, 0, sizeof (rb));
|
||||||
|
if (password_filename && password_length > 0) {
|
||||||
int fd = open (password_filename, O_RDONLY);
|
int fd = open (password_filename, O_RDONLY);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
logprintf ( "Warning: fail to open password file - \"%s\", %m.\n", password_filename);
|
logprintf ( "Warning: fail to open password file - \"%s\", %m.\n", password_filename);
|
||||||
} else {
|
} else {
|
||||||
int l = read (fd, a + s, password_length);
|
unsigned char *a = talloc0 (password_length);
|
||||||
|
int l = read (fd, a, password_length);
|
||||||
if (l < 0) {
|
if (l < 0) {
|
||||||
logprintf ( "Warning: fail to read password file - \"%s\", %m.\n", password_filename);
|
logprintf ( "Warning: fail to read password file - \"%s\", %m.\n", password_filename);
|
||||||
} else {
|
} else {
|
||||||
if (verbosity > 0) {
|
if (verbosity > 0) {
|
||||||
logprintf ( "read %d bytes from password file.\n", l);
|
logprintf ( "read %d bytes from password file.\n", l);
|
||||||
}
|
}
|
||||||
s += l;
|
RAND_add (a, l, l);
|
||||||
}
|
}
|
||||||
close (fd);
|
close (fd);
|
||||||
|
tfree_secure (a, password_length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RAND_seed (a, s);
|
|
||||||
BN_ctx = BN_CTX_new ();
|
BN_ctx = BN_CTX_new ();
|
||||||
tfree_secure (a, 64 + password_length);
|
ensure_ptr (BN_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
int serialize_bignum (BIGNUM *b, char *buffer, int maxlen) {
|
int serialize_bignum (BIGNUM *b, char *buffer, int maxlen) {
|
||||||
|
@ -375,12 +375,6 @@ static inline void fetch_skip_str (void) {
|
|||||||
fetch_str (l);
|
fetch_str (l);
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline__ unsigned long long rdtsc(void) {
|
|
||||||
unsigned hi, lo;
|
|
||||||
__asm__ __volatile__ ("rdtsc" : "=a"(lo), "=d"(hi));
|
|
||||||
return ( (unsigned long long)lo)|( ((unsigned long long)hi)<<32 );
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline long have_prefetch_ints (void) {
|
static inline long have_prefetch_ints (void) {
|
||||||
return in_end - in_ptr;
|
return in_end - in_ptr;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user