Torna indietro   Hardware Upgrade Forum > Software > Programmazione

 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-06-2004, 16:08   #1
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9505
[C] Dubbietto su pipe...

Ciao, vorrei un chiarimento su una tipica situazione di utilizzo delle pipe:

supponiamo di avere una pipe con nome e poi due processi: un lettore ed uno scrittore. Lo scrittore invia sulla pipe una stringa di 20 caratteri. (Pipe gia' aperte con i diritti "idonei"...)
Lo scrittore fara':
Codice:
...
char buffer[] = "LivingAfter Midnight";
if (write("nomepipe.p", buffer, strlen(buffer)) != strlen(buffer))
    {
      perror("Errore nella write");
      exit(-1);
    }
/*A questo punto nella pipe ci sono 20 caratteri pronti per essere letti*/
...
Il lettore "dall'altro capo della pipe" li riceve. Nel caso faccia:
Codice:
...
char buffer[20];
read("nomepipe.p", buffer, strlen(buffer);
...
sapendo che ci sono esattamente 20 caratteri da leggere ho la certezza che la lettura di tali caratteri avverra' in un sol colpo ovvero con una sola read(...) (Come sopra) oppure potrebbero servire 2 o piu' read(...) ?!?! Ad esempio potrebbe accadere che sia necessario leggere prima 12 caratteri e poi leggerne altri 8 pur avendo specificato alla read(...) che sono disposto a leggere sino a 20 caratteri in un colpo solo ?!?

thks
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 09:48   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Nel tuo caso dovrebbero essere letti in un sol colpo. Nota che non puoi comunque fare assunzioni su questo: sicuramente se trasferisci più di 4096 byte, la lettura deve essere fatta in più passi (e la scrittura rischia di essere bloccante). Per trasferimenti < 4096 la read dovrebbe essere unica, per come funzionano le pipe, ma lo standard non te lo garantisce.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 09:59   #3
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Re: [C] Dubbietto su pipe...

Argh...
Quote:
Originariamente inviato da Ed_Bunker
Codice:
char buffer[20];
read("nomepipe.p", buffer, strlen(buffer);
UCCIDI quello strlen, disgraziato!
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 10:25   #4
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9505
Re: Re: [C] Dubbietto su pipe...

Quote:
Originariamente inviato da ilsensine
Argh...


UCCIDI quello strlen, disgraziato!
Perche' ? Non devo passare anche il numero di bytes da scrivere?!? Un char e' 1 byte percio' la lunghezza della stringa dovrebbe indicare il numero di bytes esatti da scrivere. Dov'e' la disgrazia !??

thks
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 10:33   #5
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quant'è la lunghezza della stringa contenuta in buffer, se ancora non ci hai scritto nulla?
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 10:39   #6
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Re: Re: Re: [C] Dubbietto su pipe...

Quote:
Originariamente inviato da Ed_Bunker
Perche' ? Non devo passare anche il numero di bytes da scrivere?!? Un char e' 1 byte percio' la lunghezza della stringa dovrebbe indicare il numero di bytes esatti da scrivere. Dov'e' la disgrazia !??

thks
Penso che quello che intende ilsensine è che qui c'è un buffer overflow grosso quanto una casa.

Un strlen su un array di char non ancora inizializzato non ritorna mai la lunghezza del array. Non sai che cosa c'è in memoria e quindi non puoi sapere che valore ritorna la strlen.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2004, 11:08   #7
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9505
Re: Re: Re: Re: [C] Dubbietto su pipe...

Quote:
Originariamente inviato da VICIUS
Penso che quello che intende ilsensine è che qui c'è un buffer overflow grosso quanto una casa.

Un strlen su un array di char non ancora inizializzato non ritorna mai la lunghezza del array. Non sai che cosa c'è in memoria e quindi non puoi sapere che valore ritorna la strlen.

ciao
Vero, vero... il problema e' che ho fatto il "vecchio" copia e incolla prendendo i parametri dalla write mentre, in realta', quando faccio la read indico esplicitamente il massimo numero di bytes che sono disposto a leggere. In questo caso 20.

Sorry.
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
Google condannata in Svezia: dovrà...
Samsung Foundry aggiorna la roadmap: il ...
La Cina risponde a NVIDIA con LongCat-2....
Godox C100: la prima fotocamera del marc...
Boom IA e affitti fuori controllo: chi l...
Le RTX 5000 abbattono il muro dei 4 GHz,...
Onimusha: Way of the Sword non sar&agrav...
Anche Microsoft anticipa al 2029 il pass...
Sei falle in AirDrop e Quick Share: cras...
Altri tagli in arrivo in casa XBOX: a ri...
Quando l'IA entra nei processi: due part...
La contea con più data center del...
Galaxy Ring 2, Samsung conferma lo svilu...
1TB e velocità di scrittura garan...
Volkswagen apre alla produzione europea ...
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: 23:16.


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