MINOR: backend: use a single call to ha_random32() for the random LB algo

For the random LB algorithm we need a random 32-bit hashing key that used
to be made of two calls to random(). Now we can simply perform a single
call to ha_random32() and get rid of the useless operations.
This commit is contained in:
Willy Tarreau 2020-03-08 17:31:39 +01:00
parent 52bf839394
commit b9f54c5592

View File

@ -540,8 +540,7 @@ static struct server *get_server_rnd(struct stream *s, const struct server *avoi
curr = NULL; curr = NULL;
do { do {
prev = curr; prev = curr;
/* ensure all 32 bits are covered as long as RAND_MAX >= 65535 */ hash = ha_random32();
hash = ((uint64_t)ha_random() * ((uint64_t)RAND_MAX + 1)) ^ ha_random();
curr = chash_get_server_hash(px, hash, avoid); curr = chash_get_server_hash(px, hash, avoid);
if (!curr) if (!curr)
break; break;