2016-05-17 33 views
6

Inspired by SQLite, sto utilizzando lo strumento "cachegrind" di valgrind per eseguire benchmark delle prestazioni riproducibili. I numeri che emette sono molto più stabili di qualsiasi altro metodo di temporizzazione che ho trovato, ma non sono ancora deterministici. A titolo di esempio, ecco un semplice programma C:Perché la cachegrind non è completamente deterministica?

int main() { 
    volatile int x; 
    while (x < 1000000) { 
    x++; 
    } 
} 

Se compilo ed eseguirlo sotto cachegrind, ottengo i seguenti risultati:

$ gcc -O2 x.c -o x 
$ valgrind --tool=cachegrind ./x 
==11949== Cachegrind, a cache and branch-prediction profiler 
==11949== Copyright (C) 2002-2015, and GNU GPL'd, by Nicholas Nethercote et al. 
==11949== Using Valgrind-3.11.0.SVN and LibVEX; rerun with -h for copyright info 
==11949== Command: ./x 
==11949== 
--11949-- warning: L3 cache found, using its data for the LL simulation. 
==11949== 
==11949== I refs:  11,158,333 
==11949== I1 misses:   3,565 
==11949== LLi misses:   2,611 
==11949== I1 miss rate:  0.03% 
==11949== LLi miss rate:  0.02% 
==11949== 
==11949== D refs:  4,116,700 (3,552,970 rd + 563,730 wr) 
==11949== D1 misses:  21,119 ( 19,041 rd + 2,078 wr) 
==11949== LLd misses:   7,487 ( 6,148 rd + 1,339 wr) 
==11949== D1 miss rate:  0.5% (  0.5%  +  0.4% ) 
==11949== LLd miss rate:  0.2% (  0.2%  +  0.2% ) 
==11949== 
==11949== LL refs:   24,684 ( 22,606 rd + 2,078 wr) 
==11949== LL misses:   10,098 ( 8,759 rd + 1,339 wr) 
==11949== LL miss rate:   0.1% (  0.1%  +  0.2% ) 
$ valgrind --tool=cachegrind ./x 
==11982== Cachegrind, a cache and branch-prediction profiler 
==11982== Copyright (C) 2002-2015, and GNU GPL'd, by Nicholas Nethercote et al. 
==11982== Using Valgrind-3.11.0.SVN and LibVEX; rerun with -h for copyright info 
==11982== Command: ./x 
==11982== 
--11982-- warning: L3 cache found, using its data for the LL simulation. 
==11982== 
==11982== I refs:  11,159,225 
==11982== I1 misses:   3,611 
==11982== LLi misses:   2,611 
==11982== I1 miss rate:  0.03% 
==11982== LLi miss rate:  0.02% 
==11982== 
==11982== D refs:  4,117,029 (3,553,176 rd + 563,853 wr) 
==11982== D1 misses:  21,174 ( 19,090 rd + 2,084 wr) 
==11982== LLd misses:   7,496 ( 6,154 rd + 1,342 wr) 
==11982== D1 miss rate:  0.5% (  0.5%  +  0.4% ) 
==11982== LLd miss rate:  0.2% (  0.2%  +  0.2% ) 
==11982== 
==11982== LL refs:   24,785 ( 22,701 rd + 2,084 wr) 
==11982== LL misses:   10,107 ( 8,765 rd + 1,342 wr) 
==11982== LL miss rate:   0.1% (  0.1%  +  0.2% ) 
$ 

In questo caso, "Io arbitri" differisce dalla solo lo 0,008% tra le due piste ma mi chiedo ancora perché queste sono diverse. In programmi più complessi (decine di millisecondi) possono variare di più. C'è un modo per rendere le piste completamente riproducibili?

+0

Utilizzare una CPU meno sofisticata che, ad esempio, non esegue la previsione di diramazione. –

+1

Se ho capito bene, valgrind simula la propria CPU e non esegue la previsione del ramo a meno che non si passi --branch-sim = yes. Anche così, perché la previsione delle branch non può essere deterministica quando si simula una CPU? –

risposta

5

Alla fine del a topic in gmane.comp.debugging.valgrind, Nicholas Nethercote (uno sviluppatore di Mozilla che lavora nel team di sviluppo Valgrind) dice che minime variazioni sono comuni utilizzando Cachegrind (e posso dedurre che non porterà a grandi problemi).

Cachegrind’s manual indica che il programma è molto sensibile. Per esempio, su Linux, la randomizzazione dello spazio degli indirizzi (usata per migliorare la sicurezza) può essere la fonte del non-determinismo.

Un'altra cosa degna di nota è che i risultati sono molto sensibili. Se si modifica la dimensione del file eseguibile da profilare o le dimensioni di una qualsiasi delle librerie condivise che utilizza, o anche la lunghezza dei nomi dei file , è possibile che i risultati vengano perturbati. Le variazioni saranno piccole, ma non aspettarsi risultati perfettamente ripetibili se il programma cambia affatto.

più recenti distribuzioni GNU/Linux fare indirizzo spazio randomizzazione, in che corre identiche dello stesso programma hanno le loro librerie condivise caricati in luoghi diversi, come misura di sicurezza. Anche questo perturba i risultati.

Mentre questi fattori significano che non ci si deve fidare che i risultati siano super-accurati, dovrebbero essere abbastanza vicini da essere utili.