Did I implement clock drift properly?

Posted by David Titarenco on Stack Overflow See other posts from Stack Overflow or by David Titarenco
Published on 2010-05-29T07:33:36Z Indexed on 2010/05/29 7:42 UTC
Read the original article Hit count: 275

Filed under:
|
|
|

I couldn't find any clock drift RNG code for Windows anywhere so I attempted to implement it myself. I haven't run the numbers through ent or DIEHARD yet, and I'm just wondering if this is even remotely correct...

void QueryRDTSC(__int64* tick) {
    __asm {
        xor eax, eax
        cpuid
        rdtsc
        mov edi, dword ptr tick
        mov dword ptr [edi], eax
        mov dword ptr [edi+4], edx
    }
}

__int64 clockDriftRNG() {
    __int64 CPU_start, CPU_end, OS_start, OS_end;

    // get CPU ticks -- uses RDTSC on the Processor
    QueryRDTSC(&CPU_start);
    Sleep(1);
    QueryRDTSC(&CPU_end);


    // get OS ticks -- uses the Motherboard clock
    QueryPerformanceCounter((LARGE_INTEGER*)&OS_start);
    Sleep(1);
    QueryPerformanceCounter((LARGE_INTEGER*)&OS_end);

    // CPU clock is ~1000x faster than mobo clock    
    // return raw
    return ((CPU_end - CPU_start)/(OS_end - OS_start));

    // or
    // return a random number from 0 to 9
    // return ((CPU_end - CPU_start)/(OS_end - OS_start)%10);
}

If you're wondering why I Sleep(1), it's because if I don't, OS_end - OS_start returns 0 consistently (because of the bad timer resolution, I presume).

Basically, (CPU_end - CPU_start)/(OS_end - OS_start) always returns around 1000 with a slight variation based on the entropy of CPU load, maybe temperature, quartz crystal vibration imperfections, etc.

Anyway, the numbers have a pretty decent distribution, but this could be totally wrong. I have no idea.

© Stack Overflow or respective owner

Related posts about c++

Related posts about c