aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2011-09-03 16:17:52 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2011-09-03 16:17:52 -0400
commita0634241bcaf71886eeaf1cb49d43a5426bfa4de (patch)
treecd23ab378a7e4564f81585ea94ed729423c7685d
parent007e7acab2eac915a0c9fd1aad124289f025297a (diff)
downloadpostgresql-a0634241bcaf71886eeaf1cb49d43a5426bfa4de.tar.gz
postgresql-a0634241bcaf71886eeaf1cb49d43a5426bfa4de.zip
Fix typo in pg_srand48 (srand48 in older branches).
">" should be ">>". This typo results in failure to use all of the bits of the provided seed. This might rise to the level of a security bug if we were relying on srand48 for any security-critical purposes, but we are not --- in fact, it's not used at all unless the platform lacks srandom(), which is improbable. Even on such a platform the exposure seems minimal. Reported privately by Andres Freund.
-rw-r--r--src/port/rand.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/port/rand.c b/src/port/rand.c
index 8559ef8c175..5982ef9cb72 100644
--- a/src/port/rand.c
+++ b/src/port/rand.c
@@ -74,7 +74,7 @@ srand48(long seed)
{
_rand48_seed[0] = RAND48_SEED_0;
_rand48_seed[1] = (unsigned short) seed;
- _rand48_seed[2] = (unsigned short) (seed > 16);
+ _rand48_seed[2] = (unsigned short) (seed >> 16);
_rand48_mult[0] = RAND48_MULT_0;
_rand48_mult[1] = RAND48_MULT_1;
_rand48_mult[2] = RAND48_MULT_2;