Tags:
create new tag
view all tags
Memory Error (ME)

  • Per permettervi di capire meglio perchŔ qualcosa non funziona ho creato un log degli errori di gestione di memoria evidenziati dal tool valgrind (vedi Valgrind tutorial)
  • Se valgrind si lamenta vi viene aggiunta un ME nel vostro risultato, date un'occhiata al vostro log di valgrind per scoprire dove pu˛ essere l'errore.
  • Ad esempio, se avete segmentation faults forse con il file valgrind.log potete capire perchŔ e dove Ŕ successo
  • NOTA: questi errori non vi penalizzano nella valutazione, ma servono solo a darvi maggiori indicazioni per scoprire perchŔ il vostro programma va in SF

SF e TF

Mi hanno fatto notare che con il test globale anche un solo SF o TF fa fallire tutta una valutazione. Non mi Ŕ possibile fare i test separatamente, mandate una patch che elimina (basta che la rinomini) la funzione che volete che non sia testata.

SEGMENTATION FAULT e NON COMPILA

  • In questi casi vuol dire che c'e' un errore. Il fatto che sulla vostra macchina il programma abbia funzionato non vuol dire che l'errore non ci sia. Abbiamo quindi pensato di permettervi di recuperare:
    • Avete la possibilitÓ di trovare il baco e mandarmi una patch che lo corregga.
      • per creare la patch usate il comando
        diff -ubBw filevecchio.c filenuovo.c > file.patch 
    • Il modulo otterrÓ il punteggio dato dai test meno una penalizzazione che verrÓ decisa caso per caso.
    • La patch deve essere piccolissima (non riscrivete tutto il modulo).
    • AVETE 30 GIORNI DI TEMPO
    • per i moduli 1 e 2 fanno fede i test di Sterbini.
    • per i moduli 3 e 4 potremmo far girare i test su pi¨ macchine. In tal caso vale la situazione peggiore (ovvero basta un SEGFAULT su una delle macchine per dover cercare il baco)
  • alcuni non hanno mandato il file LPC_M1_Include.h, lo mandino

TIMEOUT O FREE ERROR

  • Talvolta fate un errore deallocando una zona non allocata (ad esempio facendo free di un puntatore non inizializzato). In questi casi viene un errore che non appare nei log (perchŔ non stampa su stderr) e il programma si blocca. Dopo 5 secondi il processo viene ucciso e vi appare un errore TIMEOUT.

COME CERCARE ERRORI DI USO DELLA MEMORIA

  • Usate la libreria Electric Fence che controlla se sbordate dalle aree di memoria allocata.
    • la documentazione la trovate con
      man efence
    • eseguite il programma scrivendo
      LD_PRELOAD=libefence.so.0.0 ./TestM1 
  • eseguite passo passo il programma col debugger per capire su quale istruzione fa casino
    gdb ./TestM1 
    run 
  • eseguite il programma con valgrind per capire su quale istruzione fa casino
    valgrind -q ./TestM1 

NOTA

  • non vi preoccupate dei warning che seguono, non vengono considerati come errore
  • abbiamo linkato una versione vuota delle funzioni in modo da far compilare anche a chi ha consegnata solo una, dal prossimo modulo dovrete inserire voi una versione vuota delle funzioni che non implementate
/usr/bin/ld: Warning: size of symbol `CreateDatabaseFile' changed from 2132 in lib/Modulo1.a(LPC_CreateDBF?.o) to 10 in obj/LPC_Dummy.o 
/usr/bin/ld: Warning: size of symbol `DeleteDatabaseFile' changed from 903 in lib/Modulo1.a(LPC_DeleteDBF?.o) to 10 in obj/LPC_Dummy.o

Non avete seguito molto bene le specifiche

  • a breve pubblicheremo una valutazione precisa dell'importanza che diamo al non aderire alle specifiche.
  • per questo modulo e per il ModuloDue la valutazione di aderenza alle specifiche non viene applicata
  • nei moduli 3 e 4 verrÓ applicata anche l'aderenza alle specifiche

-- AndreaSterbini - 05 May 2006

Edit | Attach | Watch | Print version | History: r3 < r2 < r1 | Backlinks | Raw View | Raw edit | More topic actions
Topic revision: r3 - 2006-05-14 - AndreaSterbini






 
Questo sito usa cookies, usandolo ne accettate la presenza. (CookiePolicy)
Torna al Dipartimento di Informatica
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 2008-2021 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback