Torna indietro   Hardware Upgrade Forum > Software > Programmazione

I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
MSI continua ad investire nel proporre schermi pensati per rispondere alle esigenze dei videogiocatori, utilizzando la quinta generazione di tecnologia QD-OLED sviluppata da Samsung. Il modello MPG 341CQR QD-OLED X36 è lpultima novità al debutto in concomitanza con il CES 2026, uno schermo curvo di ampia risoluzione pensato per i videogiocatori più esigenti
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-02-2009, 01:36   #1
Pompolus
Member
 
Iscritto dal: Oct 2005
Messaggi: 258
[C] copiare aree di memoria

Salve a tutti,

per un programma che simuli la gestione dell'allocazione della memoria, devo copiare un'area di memoria in un'altra area di memoria.

In pratica ho un'applicazione SERVER in ascolto...
Un'applicazione CLIENT alloca una determinata area di memoria, ci scrive dentro qualcosa, poi chiama una funzione del server passandogli il (void *) all'area di memoria allocata.

A questo punto il SERVER dovrà andare a leggere nell'area di memoria suddetta e copiare byte per byte i dati in un'altra area di memoria.


per fare ciò uso la funzione memcpy, il problema è che sembra che il SERVER non riesca ad accedere all'area di memoria allocata dal CLIENT, riesco ad ottenere il giusto indirizzo tramite FIFO, ma quando si tratta di accedervi sembra impossibile, infatti la memcpy non fa un bel niente...

E' possibile accedere da un processo ad un'area di memoria allocato da un altro processo? Un modo deve esserci ma non so quale.
Se può essere utile sto lavorando sotto linux.

Qualcuno sa aiutarmi?

Ultima modifica di Pompolus : 04-02-2009 alle 02:03.
Pompolus è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 09:08   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Sono processi distinti, il loro indirizzamento è diverso, è normale che non ti funzioni.
http://www.cact.unile.it/facilities/...apilsu190.html
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 10:20   #3
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da Pompolus Guarda i messaggi
E' possibile accedere da un processo ad un'area di memoria allocato da un altro processo?
pensa un po' alle conseguenze se questo si potesse fare: la memoria allocata da un certo processo potrebbe contenere dati sensibili, come password o numeri di carte di credito oppure informazioni la cui corruzione potrebbe causare il malfunzionamento del sistema, e non sarebbe positivo se qualunque processo (virus compresi) potesse accedervi. una volta (20 anni fa, ai tempi del DOS) in effetti si poteva fare, poi visto che non andava affatto bene l'uomo ha introdotto svariati meccanismi di protezione. oggi... si puó ancora fare ma non in tutti i sistemi operativi e non in maniera diretta, e comunque sotto la supervisione di un opportuno sistema di sicurezza che consenta solo determinati accessi. di certo non lo fai con memcpy, ne' dereferenziando puntatori; in particolare quest'ultima cosa non ha neanche piu senso perché oggi a ciascun processo viene assegnato uno spazio di indirizzamento virtuale (ciascun processo ha i suoi 4 GB virtuali) e tutti i puntatori che esso puó generare si riferiscono per definizione al suo spazio di indirizzamento, non c'é modo di riferirsi con un puntatore allo spazio di indirizzamento di un altro processo.


Quote:
Un modo deve esserci ma non so quale.
devi copiare i dati manualmente sulla FIFO.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 13:36   #4
Pompolus
Member
 
Iscritto dal: Oct 2005
Messaggi: 258
Quote:
Originariamente inviato da fero86 Guarda i messaggi
pensa un po' alle conseguenze se questo si potesse fare: la memoria allocata da un certo processo potrebbe contenere dati sensibili, come password o numeri di carte di credito oppure informazioni la cui corruzione potrebbe causare il malfunzionamento del sistema, e non sarebbe positivo se qualunque processo (virus compresi) potesse accedervi. una volta (20 anni fa, ai tempi del DOS) in effetti si poteva fare, poi visto che non andava affatto bene l'uomo ha introdotto svariati meccanismi di protezione. oggi... si puó ancora fare ma non in tutti i sistemi operativi e non in maniera diretta, e comunque sotto la supervisione di un opportuno sistema di sicurezza che consenta solo determinati accessi. di certo non lo fai con memcpy, ne' dereferenziando puntatori; in particolare quest'ultima cosa non ha neanche piu senso perché oggi a ciascun processo viene assegnato uno spazio di indirizzamento virtuale (ciascun processo ha i suoi 4 GB virtuali) e tutti i puntatori che esso puó generare si riferiscono per definizione al suo spazio di indirizzamento, non c'é modo di riferirsi con un puntatore allo spazio di indirizzamento di un altro processo.


devi copiare i dati manualmente sulla FIFO.
Ciao, grazie della risposta.

Allora ho rifatto il tutto e ora mando i dati tramite FIFO, però ho un problema.

Dopo che il SERVER legge la FIFO, le memcpy non funziona più, sembra rimanere in stallo. Tutti i dati dentro le fifo vengono letti correttamente, ma la funzione memcpy dopo non funziona proprio più, anche usando dati che non sono stati passati tramite FIFO, non capisco perchè!

faccio un esempio, questa è la parte del server:

Codice:
//////////////////////faccio una memcpy prima della READ/////////////////////////////////////////////
char s1[30] = "ciao a tutti";
char s2[30];
char s3[30];

void * buffer;
int n_byte;
int buffer_dim = 30;

memcpy(s2, s1, 30);

if ((n_byte = read(FIFO_to_read, buffer, buffer_dim) )== -1) 
	perror(" Errore nella lettura della fifo");
else 
	printf(" nella fifo sono stati letti %d byte e in buffer c'è %s\n", n_byte, buffer);
			

////////////////faccio una memcpy dopo la READ///////////////////////////////////////////
memcpy(s3, s1, 30);
questa è la parte del CLIENT:

Codice:

char stringa[30] ="sono la stringa da inviare";
int size = 30;
void *buffer = stringa;

	n_byte = write(FIFO_to_write, buffer, size); 

	if (n_byte == -1)
		perror(" Error while writing FIFO");
	else 
		printf("nella fifo sono stati scritti %d byte \n",n_byte);
tutte le memcpy prima della read vengono effettuate normalmente, ma dopo la read la memcpy non va più il programma si blocca sulla sua istruzione.

La cosa strana è che prima faccio altre READ tramite FIFO, ma c'è una READ in particolare dopo la quale la memcpy non funziona più, eppure i dati dalla fifo vengono letti normalmente, se provo a stamparli ci sono e sono giusti.


Quel che sembra che gli dia fastidio è che dalla parte del client invio la stringa, il server la riceve correttamente ma dopodichè si blocca la memcpy, se invece invio l'indirizzo della stringa, il server riesce poi afare le varie memcpy, ma ovviamente poi non può accedere alla stringa perchè è stata dichiarata dall'altra applicazione.

COME DIAVOLO NE ESCO!?!?!

Se non sono stato chiaro fate pure domande che qui sto nella m... ehm pupù fino al collo!


Vi ringrazio per l'aiuto

Ultima modifica di Pompolus : 04-02-2009 alle 16:29.
Pompolus è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 14:31   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Guarda il link che ti ho dato sopra
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 14:57   #6
Pompolus
Member
 
Iscritto dal: Oct 2005
Messaggi: 258
Quote:
Originariamente inviato da cionci Guarda i messaggi
Guarda il link che ti ho dato sopra
purtroppo non posso usare la memoria condivisa ma devo utilizzare le FIFO per forza di cose. : \
Pompolus è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 16:15   #7
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989


Laboratorio di sistemi operativi 1? Non è difficile dai, in bocca al lupo!
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 16:30   #8
Pompolus
Member
 
Iscritto dal: Oct 2005
Messaggi: 258
Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi


Laboratorio di sistemi operativi 1? Non è difficile dai, in bocca al lupo!
crepi, ma se non è difficile, dove sta il problema? : \
Pompolus è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 16:53   #9
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Conta che solo un processo può scrivere nella sua memoria, quindi avendo server e client separati non devi far scrivere al primo nella memoria del secondo, devi farli "comunicare" e trasferire così i dati che ti servono. Poi sarà l'applicazione interessata (server o client a seconda del tipo di trasferimento che fai) a scrivere i dati nella zona che ti serve. Consiglio: pensa alla libreria e a dove va a finire, poi c'è bisogno solo di "incollare i pezzi".

P.S.: sicuro che sia la memcpy() a bloccarsi? I casi sono due: o si blocca sulla FIFO o ti si termina il server per segmentation fault (il che è probabilissimo visto che fai memcpy() dove magari non potresti, se ho capito bene).
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2009, 16:55   #10
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Altro consiglio: usa un debugger. Lancia il server, recuperane il PID, poi lancia gdb e dagli come comando "attach <PIDserver>" e "continue", almeno sarai sicuro nel caso si verifichi un segmentation fault.

Buon lavoro!
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2009, 11:45   #11
Pompolus
Member
 
Iscritto dal: Oct 2005
Messaggi: 258
no, era proprio la memcpy a bloccarsi per cause ancora sconosciute, comunque ho risolto evitando proprio di usarlo e facendo scrivere direttamente alla FIFO nell'indirizzo di memoria desiderato...

Resta ancora un mistero perchè sta memcpy non funzionava, mah : \
Pompolus è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2009, 16:20   #12
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Sei sicuro che le due applicazioni girassero nello stesso thread?

Perchè, se l'esecuzione delle 2 è asincrona, è possibile che il server si accorga che la memoria è stata scritta dalla FIFO, ma tenta di copiarla quando la scrittura non è ancora terminata, appunto crashando.

Prova a fargli "perdere tempo" tra la read e il memcpy...
__________________
*ToMmO*

devlog | twitter

Ultima modifica di Tommo : 05-02-2009 alle 16:23.
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2009, 16:29   #13
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Non credo sia quello il problema, la read() e la write() sono bloccanti, il server legge solo quando il client ha scritto, il client legge solo quando il server ha scritto... Non ho capito come viene effettuata questa memcpy() e in che modo "blocchi" il tutto, non mi sembra possibile, onestamente.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2009, 17:27   #14
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Bho mi sembrava una cosa possibile
Cmq è strano, in effetti il memcpy che viene chiamato dopo read(), e crasha, non coinvolge nessuno dei parametri del read stesso... per cui la memoria viene scombinata in qualche modo.
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2009, 17:35   #15
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
La cosa che mi sembra più probabile è che un segmentation fault mandi in crash una delle due applicazioni (client o server) e che l'altra cerchi di leggere una FIFO che resta sempre vuota perché non ha più chi vi fornisca dei dati.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
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...
Lo smartphone da comprare oggi è ...
2 super caricatori multipli da 600W o 22...
La Russia prosegue lo sviluppo di reatto...
Roscosmos: da quest'anno ci potrà...
Amazon, tutte le offerte e qualche novit...
Sedie gaming in offerta su Amazon: desig...
Scope elettriche in offerta Amazon: mode...
Ricarica EV fino a 22 kW spendendo poco:...
Costa solo 139€ ma fa tutto: Lefant M330...
Amazon Haul spinge sul risparmio: sconti...
Oral-B iO in offerta su Amazon: maxi sco...
I cosmonauti avrebbero riparato tutte le...
Artemis II: la NASA conferma il lancio d...
Il CEO di Embrak Studios difende l'uso d...
Il Trump Phone è sempre più un mistero: ...
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: 08:33.


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