X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fuuid.c;h=df1206e1c80a9af45745c5ef3edabe4f5c6ef003;hb=003ce655b7116d18c86a74c50391e54990346931;hp=7b03fe0b6d81c28c6f5d48a81befe30d816d348c;hpb=954b526eed5eb2822b38ea6078bfee26c02c220e;p=sliver-openvswitch.git diff --git a/lib/uuid.c b/lib/uuid.c index 7b03fe0b6..df1206e1c 100644 --- a/lib/uuid.c +++ b/lib/uuid.c @@ -81,19 +81,19 @@ uuid_init(void) void uuid_generate(struct uuid *uuid) { - static pthread_mutex_t mutex = PTHREAD_ADAPTIVE_MUTEX_INITIALIZER; + static struct ovs_mutex mutex = OVS_MUTEX_INITIALIZER; uint64_t copy[2]; uuid_init(); /* Copy out the counter's current value, then increment it. */ - xpthread_mutex_lock(&mutex); + ovs_mutex_lock(&mutex); copy[0] = counter[0]; copy[1] = counter[1]; if (++counter[1] == 0) { counter[0]++; } - xpthread_mutex_unlock(&mutex); + ovs_mutex_unlock(&mutex); /* AES output is exactly 16 bytes, so we encrypt directly into 'uuid'. */ aes128_encrypt(&key, copy, uuid); @@ -205,6 +205,12 @@ error: return false; } +static void +sha1_update_int(struct sha1_ctx *sha1_ctx, uintmax_t x) +{ + sha1_update(sha1_ctx, &x, sizeof x); +} + static void do_init(void) { @@ -212,25 +218,21 @@ do_init(void) struct sha1_ctx sha1_ctx; uint8_t random_seed[16]; struct timeval now; - pid_t pid, ppid; - uid_t uid; - gid_t gid; /* Get seed data. */ get_entropy_or_die(random_seed, sizeof random_seed); xgettimeofday(&now); - pid = getpid(); - ppid = getppid(); - uid = getuid(); - gid = getgid(); /* Convert seed into key. */ sha1_init(&sha1_ctx); sha1_update(&sha1_ctx, random_seed, sizeof random_seed); - sha1_update(&sha1_ctx, &pid, sizeof pid); - sha1_update(&sha1_ctx, &ppid, sizeof ppid); - sha1_update(&sha1_ctx, &uid, sizeof uid); - sha1_update(&sha1_ctx, &gid, sizeof gid); + sha1_update(&sha1_ctx, &now, sizeof now); + sha1_update_int(&sha1_ctx, getpid()); +#ifndef _WIN32 + sha1_update_int(&sha1_ctx, getppid()); + sha1_update_int(&sha1_ctx, getuid()); + sha1_update_int(&sha1_ctx, getgid()); +#endif sha1_final(&sha1_ctx, sha1); /* Generate key. */