Merge "Bug 3330205 Thread safety for bignum powers of 5"

This commit is contained in:
David Turner 2011-02-03 04:45:51 -08:00 committed by Android (Google) Code Review
commit 820e6867e2

View file

@ -754,6 +754,7 @@ mult
}
static Bigint *p5s;
static pthread_mutex_t p5s_mutex = PTHREAD_MUTEX_INITIALIZER;
static Bigint *
pow5mult
@ -775,11 +776,13 @@ pow5mult
if (!(k = (unsigned int) k >> 2))
return b;
mutex_lock(&p5s_mutex);
if (!(p5 = p5s)) {
/* first time */
p5 = i2b(625);
if (p5 == BIGINT_INVALID) {
Bfree(b);
mutex_unlock(&p5s_mutex);
return p5;
}
p5s = p5;
@ -797,6 +800,7 @@ pow5mult
p51 = mult(p5,p5);
if (p51 == BIGINT_INVALID) {
Bfree(b);
mutex_unlock(&p5s_mutex);
return p51;
}
p5->next = p51;
@ -804,6 +808,7 @@ pow5mult
}
p5 = p51;
}
mutex_unlock(&p5s_mutex);
return b;
}