[reSIProcate] Valgrind complains with Resiprocate

Adam Roach adam at nostrum.com
Sat May 3 00:52:04 CDT 2008


Byron Campen wrote:
>     Yeah, I have seen this too, and I haven't had time to get to the 
> bottom of it. Anyone else?

I can't reproduce with anything that uses getRandomHex() in the current 
tree on my system. I *was* able to reproduce and track down the problem 
using getCryptoRandomHex(). It turns out that many pseudo-random number 
generators don't bother with initializing the buffers they start 
permuting to produce random numbers. Consequently, you can end up with 
valgrind complaining about use of uninitialized values whenever you 
start using these random numbers for certain purposes (such as indexing 
arrays or making branch decisions). It's a real pain to track down, too, 
since valgrind doesn't point out when you assign uninitialized values 
(or perform other operations with them, such as simple math) -- it 
simply marks the result of these copies as uninitialized also.

However, it looks like the normal linux pseudo-random number generator 
doesn't have this property. So, to eliminate what I think is the most 
probable suspect, I have to ask Aron: have you made any modifications to 
the Random class that either use an alternate PRNG, or shunt over to 
OpenSSL for calls to getRandom()?

/a



More information about the resiprocate-devel mailing list