|
|
|
|
Strumenti |
27-12-2006, 14:42 | #1 |
Senior Member
Iscritto dal: May 2004
Messaggi: 1136
|
[C/C++] Flag di ottimizzazione
Ho un certo programma scritto in c++ che se compilato con qualsiasi flag della famiglia "O" (Quindi da O1 in poi), restituisce durante l'esecuzione segmatation fault per cause ancora ignote (il codice imputato non è mio ed è discretamente complesso e vasto per una veloce debuggata). Se viene compilato senza ottimizzazioni il programma funziona normalemente.
A volte però, per alcuni valori iniziali di certe variabili, il programma compilato con O3 terminava l'esecuzione normalmente: in questo caso ho osservato prestazioni notevolemente migliori (esecuzioni 4-5 volte più rapide). L'unica opzione di ottimizzazione che non dà mai problemi è l'architettura el processore, ma aumenta le prestazioni marginalmente. Andando a spulciare il manuale di gcc, ho trovato quali sono in realtà le opzioni incluse nelle varie O1, O2, O3. Inserendo queste opzioni manualmente non ho mai ottenuto segmentation fault (anche nei casi in cui O1 lo dava), ma neanche miglioramenti così rilevanti sotto il profilo prestazionale. Non sono quindi riuscito neppure ad isolare l'opzione che generava il segmentation fault. Mi sapete spiegare il perché? Per lanciare la compilazione uso g++ e il comando "gcc -v" restituisce: Reading specs from /usr/lib/gcc/i486-slackware-linux/3.4.6/specs Configured with: ../gcc-3.4.6/configure --prefix=/usr --enable-shared --enable-threads=posix --enable-__cxa_atexit --disable-checking --with-gnu-ld --verbose --target=i486-slackware-linux --host=i486-slackware-linux Thread model: posix gcc version 3.4.6 Grazie. |
27-12-2006, 14:46 | #2 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
E' ovviamente un bug nel programma, dovuto probabilmente a dati non inizializzati o buffer overflow.
Se hai i sorgenti, puoi compilare il programma con -O -g3 e lanciare il programma sotto gdb, in modo da cercare di capire dove va in segfault e perché.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
27-12-2006, 14:51 | #3 |
Senior Member
Iscritto dal: May 2004
Messaggi: 1136
|
Sì è un bug del programma, ma perché mettendo i flag a mano non ottengo l'errore ma nenache le prestazioni migliori? C'è qualcosa in più nel "-O1"?
|
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 21:15.