apr-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Max Bowsher <ma...@ukf.net>
Subject Re: APR-util UUID generator broken
Date Fri, 14 Apr 2006 17:17:24 GMT
Hash: SHA1

Ralf S. Engelschall wrote:
> On Fri, Apr 14, 2006, Max Bowsher wrote:
>> [...]
>>> ...I've reviewed the UUID generator in APR-util. It unfortunately is
>>> totally broken and generates neither valid (format) nor useful (content)
>>> RFC4122 UUIDs.
>> REMOVING CC to dev@subversion, as this is entirely an APR issue.
> Please keep in mind that Subversion ships with a _copy_ of APR (and seem
> to not very often upgrade their copy) and hence they have to fix it in
> their copy (or upgrade once your released a fixed APR version ;-), too.

I'm a Subversion committer, so I can say with complete certainty that
your understanding of the Subversion release process with respect to APR
is wildly inaccurate.

Subversion bundles the latest released version of APR 0.9.x. We do not
do anything as nastily inelegant as keeping a local copy that is allowed
to get stale.

>> Thankyou for taking the time to hunt down bugs, but you could have saved
>> yourself a lot of time by just checking trunk. Both of the above are
>> already fixed.
>> I did not propose a backport at the time I fixed the bugs, but I take it
>> from your considerable action on this topic that you would like one. I
>> guess that's fine - the change does not have compatibility issues that I
>> am aware of.
> Yes, please backport those fixes to your APR 1.2 branch as you yesterday
> even released APR 1.2.7 (from that branch, yes, I know) which still
> contains the same buggy UUID generator. As long as those fixes are not
> part of an official APR release the generated bogus UUIDs are still
> spreading around...

OK, I'll backport it. Just out of curiosity, is there any problem caused
by the weird UUIDs?

Should I be considering backporting it to 0.9.x as well? (Anyone using
Apache 2.0.x must continue to use APR 0.9.x, and 0.9.x will remain the
default bundled with Subversion for the forseeable future.)

>>> 3. OPTIMIZATION: for generating random content the local
>>>    get_system_time() function (which is based on apr_time_now()) is used
>>>    which time-adjusts for the UUID vs Unix Epoch time. For generating
>>>    random bytes it is fully sufficient to just use plain apr_time_now().
>>> Index: apr-util-1.2.6/crypto/getuuid.c
>>> --- apr-util-1.2.6/crypto/getuuid.c.orig	2005-02-04 21:45:35 +0100
>>> +++ apr-util-1.2.6/crypto/getuuid.c	2006-04-04 19:49:37 +0200
>>> @@ -131,7 +131,7 @@
>>>      /* crap. this isn't crypto quality, but it will be Good Enough */
>>> -    get_system_time(&time_now);
>>> +    time_now = apr_time_now();
>>>      srand((unsigned int)(((time_now >> 32) ^ time_now) & 0xffffffff));
>>>      return rand() & 0x0FFFF;
>> This seems sensible to me.
>> Could someone give a second opinion that this is fine, and isn't going
>> to impact the randomness quality?
> The difference between your get_system_time() and apr_time_now() is
> nothing more than the time offset between Unix epoch and the one used
> by UUIDs. Adding a value doesn't change the randomness _quality_ of an
> integer at all (it still is as bad or good as it was before)...

Naturally. I was mainly wondering about the multiplication combined with
the 64bit->32bit folding.

Version: GnuPG v1.4.2.1 (Cygwin)


View raw message