Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-03-2011, 17:37   #1
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
[C] glibc difettose o cosa?

Salve a tutti,

è ormai qualche mese che uso un programma scritto da me in C per fare dei test, e in genere nel 99% dei casi ha sempre funzionato.
Ora, ogni volta che lancio il programma ottengo questo:
Codice:
*** glibc detected *** /home/user/workspace/EncryptFiles/Debug/EncryptFiles: double free or corruption (out): 0x000000000060a8e0 ***
======= Backtrace: =========
/lib/libc.so.6(+0x72b36)[0x7fb257272b36]
/lib/libc.so.6(cfree+0x6c)[0x7fb2572778ec]
/home/user/workspace/EncryptFiles/Debug/EncryptFiles[0x402b3f]
/home/user/workspace/EncryptFiles/Debug/EncryptFiles[0x401a06]
/lib/libc.so.6(__libc_start_main+0xfd)[0x7fb25721ebbd]
/home/user/workspace/EncryptFiles/Debug/EncryptFiles[0x401559]
======= Memory map: ========
00400000-00404000 r-xp 00000000 09:04 2113799                            /home/user/workspace/EncryptFiles/Debug/EncryptFiles
00604000-00605000 r--p 00004000 09:04 2113799                            /home/user/workspace/EncryptFiles/Debug/EncryptFiles
00605000-00606000 rw-p 00005000 09:04 2113799                            /home/user/workspace/EncryptFiles/Debug/EncryptFiles
00606000-00641000 rw-p 00000000 00:00 0                                  [heap]
7fb250000000-7fb250021000 rw-p 00000000 00:00 0 
7fb250021000-7fb254000000 ---p 00000000 00:00 0 
7fb254fe5000-7fb254ffb000 r-xp 00000000 09:01 311158                     /lib64/libgcc_s.so.1
7fb254ffb000-7fb2551fa000 ---p 00016000 09:01 311158                     /lib64/libgcc_s.so.1
7fb2551fa000-7fb2551fb000 r--p 00015000 09:01 311158                     /lib64/libgcc_s.so.1
7fb2551fb000-7fb2551fc000 rw-p 00016000 09:01 311158                     /lib64/libgcc_s.so.1
7fb2551fc000-7fb2551fd000 ---p 00000000 00:00 0 
7fb2551fd000-7fb2559fd000 rw-p 00000000 00:00 0 
7fb2559fd000-7fb2559fe000 ---p 00000000 00:00 0 
7fb2559fe000-7fb2561fe000 rw-p 00000000 00:00 0 
7fb2561fe000-7fb2561ff000 ---p 00000000 00:00 0 
7fb2561ff000-7fb2569ff000 rw-p 00000000 00:00 0 
7fb2569ff000-7fb256a00000 ---p 00000000 00:00 0 
7fb256a00000-7fb257200000 rw-p 00000000 00:00 0 
7fb257200000-7fb257350000 r-xp 00000000 09:01 220815                     /lib64/libc-2.11.3.so
7fb257350000-7fb257550000 ---p 00150000 09:01 220815                     /lib64/libc-2.11.3.so
7fb257550000-7fb257554000 r--p 00150000 09:01 220815                     /lib64/libc-2.11.3.so
7fb257554000-7fb257555000 rw-p 00154000 09:01 220815                     /lib64/libc-2.11.3.so
7fb257555000-7fb25755a000 rw-p 00000000 00:00 0 
7fb25755a000-7fb2575b1000 r-xp 00000000 09:01 1122129                    /usr/lib64/libgmp.so.3.5.2
7fb2575b1000-7fb2577b1000 ---p 00057000 09:01 1122129                    /usr/lib64/libgmp.so.3.5.2
7fb2577b1000-7fb2577b2000 r--p 00057000 09:01 1122129                    /usr/lib64/libgmp.so.3.5.2
7fb2577b2000-7fb2577b3000 rw-p 00058000 09:01 1122129                    /usr/lib64/libgmp.so.3.5.2
7fb2577b3000-7fb2577ca000 r-xp 00000000 09:01 220779                     /lib64/libpthread-2.11.3.so
7fb2577ca000-7fb2579c9000 ---p 00017000 09:01 220779                     /lib64/libpthread-2.11.3.so
7fb2579c9000-7fb2579ca000 r--p 00016000 09:01 220779                     /lib64/libpthread-2.11.3.so
7fb2579ca000-7fb2579cb000 rw-p 00017000 09:01 220779                     /lib64/libpthread-2.11.3.so
7fb2579cb000-7fb2579cf000 rw-p 00000000 00:00 0 
7fb2579cf000-7fb2579ed000 r-xp 00000000 09:01 220814                     /lib64/ld-2.11.3.so
7fb257bad000-7fb257bb1000 rw-p 00000000 00:00 0 
7fb257bea000-7fb257bec000 rw-p 00000000 00:00 0 
7fb257bec000-7fb257bed000 r--p 0001d000 09:01 220814                     /lib64/ld-2.11.3.so
7fb257bed000-7fb257bee000 rw-p 0001e000 09:01 220814                     /lib64/ld-2.11.3.so
7fb257bee000-7fb257bef000 rw-p 00000000 00:00 0 
7fff43092000-7fff430b3000 rw-p 00000000 00:00 0                          [stack]
7fff4311f000-7fff43120000 r-xp 00000000 00:00 0                          [vdso]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0                  [vsyscall]
Non so da che dipenda. Ultimamente ho solo aggiornato il kernel alla versione 2.6.37-r1. E comunque il programma sembra che giri correttamente!

Io quell'output non lo capisco. Qualcuno mi aiuta per favore?
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2011, 19:27   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12904
L'errore è questo: double free or corruption.

Questo accade in genere quando si chiama 2 volte free su un puntatore che indirizza un'area di memoria oppure quando c'è corruzione nell'area di memoria (magari fai scritture che non dovresti fare).

Usa il tool valgrind per scoprire quali sono i problemi di gestione della memoria che ha il tuo programma.

Se il tool non segnala alcun errore e tutti i memory leaks sono risolti allora il problema dev'essere un altro.

Ultima modifica di WarDuck : 11-03-2011 alle 19:29.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2011, 20:47   #3
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Ciao WarDuck, grazie infinite per la risposta. Ammetto che ora che mi ci fai pensare, quel double free avrebbe dovuto farmi capire che fosse qualche free sbagliata. Però non sono una cima in C, purtroppo!

Commentando le free incriminate infatti il problema sparisce.

Dunque, senza usare Valgrind, sono riuscito a isolare il problema. In pratica sono delle free apposite che mette a disposizione la libreria libpaillier, che io lancio per liberare la memoria, ovvero:
Codice:
void *free_plaintext(paillier_plaintext_t **decrypted, int len){
	int i;
	for(i=0;i<len;i++){
		paillier_freeplaintext(decrypted[i]);
	}
}

void *free_ciphertext(paillier_ciphertext_t **encrypted, int len){
	int i;
	for(i=0;i<len;i++){
		paillier_freeciphertext(encrypted[i]);
	}
}
E le chiamo dall'esterno con:
Codice:
free_plaintext(plain,block_st.num_of_blocks);
free_ciphertext(encrypted,block_st.num_of_blocks);
free_plaintext(decrypted,block_st.num_of_blocks);
Ora mi rendo conto che non sia immediato capire cosa sto facendo da queste poche righe, ma il concetto è che sto liberando array di paillier_ciphertext_t e paillier_plaintext_t. E quindi devo fare un'operazione iterativa. Quello che non mi spiego è il perché del fatto che prima me lo faceva molto saltuariamente ed ora succede sempre.

Nella documentazione quelle funzioni sono definite così:
Codice:
void paillier_freeplaintext( paillier_plaintext_t* pt );
void paillier_freeciphertext( paillier_ciphertext_t* ct );
Le variabili le dichiaro all'inizio con:
Codice:
paillier_plaintext_t *plain[block_st.num_of_blocks];
paillier_ciphertext_t *encrypted[block_st.num_of_blocks];
paillier_plaintext_t *decrypted[block_st.num_of_blocks];
Immagino già una tua precisazione per farmi notare un errore, però ora non mi pronuncio, magari dico cavolate.

Grazie ancora.
__________________
^ThE CyBoRg^

Ultima modifica di fbcyborg : 11-03-2011 alle 21:09.
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 12-03-2011, 17:35   #4
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Succede una cosa incredibile. Sul mio portatile, un dual core, questo problema non si presenta mai! È vero che questo software è multithread ma non per quanto riguarda le varie free che menzionavo anche prima.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 12-03-2011, 19:29   #5
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12904
Ribadisco che secondo me ti conviene analizzare il software con valgrind, dato che è l'unico modo "accessibile" per capire cosa c'è che non va.

Inoltre con esso puoi capire meglio se è un problema del tuo programma oppure delle librerie che stai usando.

Se fossero queste ultime e se queste fossero di terza parte, ti consiglierei di contattare lo sviluppatore.

I problemi relativi alla gestione della memoria sono molto insidiosi.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 12-03-2011, 20:31   #6
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Ok, ti ringrazio. Ora farò qualche prova.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2011, 18:38   #7
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Ciao,

dunque eccomi di nuovo; ho usato valgrind come mi hai suggerito, e l'ho fatto anche su altri software, ma vorrei concentrarmi su questo per il momento, che riguarda il pezzo di codice in cui faccio delle free.
Dunque, qualcosa intuisco ma non è proprio semplice per me, visto che lo sto usando solo da un'ora, però ecco quanto sputa fuori.
Ovviamente quando lancio valgrind tutto quel Memory map di prima non lo sputa fuori.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2011, 15:08   #8
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Alla fine poi ho risolto.
C'era un problema di malloc da un'altra parte nel codice, e risolto quello si è risolto anche questo problema.

Grazie comunque.
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2011, 15:25   #9
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12904
Scusami ho visto solo ora, valgrind ti da un'idea di massima di dove andare a cercare il problema (in pratica vedi quali sono le funzioni in cui sono presenti eventuali errori e cerchi di capire dove sia il problema).
Tra l'altro dal log si evince che ci sono dei memory leaks, ovvero fai delle malloc ma non liberi la memoria alla fine...

Comunque bene che tu abbia risolto, è bene controllare sempre con valgrind che non ci siano errori, così sei ragionevolmente sicuro che il tuo programma non ha problemi di gestione della memoria, e ciò significa avere un programma molto più stabile.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2011, 15:28   #10
fbcyborg
Senior Member
 
L'Avatar di fbcyborg
 
Iscritto dal: Jan 2004
Città: ROMA
Messaggi: 2055
Ottimo!

Grazie ancora!!
__________________
^ThE CyBoRg^
fbcyborg è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
Nuove scorte: torna il portatile tuttofa...
Toyota usa giochi e premi per spingere i...
HarmonyOS ha raggiunto la soglia di sopr...
Le offerte Amazon più convenienti...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 11:29.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v