Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Le novità MSI del 2026 per i videogiocatori
Le novità MSI del 2026 per i videogiocatori
Con le nuove soluzioni della serie MEG, acronimo di MSI Enthusiast Gaming, l'azienda taiwanese vuole proporre per il 2026 una gamma di proposte desktop che si rivolgono direttamente all'utente più appassionato con schede madri, chassis e sistemi di raffreddamento. Non da ultimi troviamo anche gli alimentatori, che abbinano potenza a ricerca della massima sicurezza di funzionamento.
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


Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
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...
Fibra di carbonio, lega di magnesio e 8....
Inaugurato il Padiglione Italia al CES 2...
AGON PRO AG276QSG2: NVIDIA G-Sync Pulsar...
MSI mostra la scheda madre consumer con ...
MSI rinnova l'intera offerta notebook al...
Laifen Wave Pro: debutta al CES lo spazz...
XGIMI Titan Noir Max: al CES il videopro...
Atlas di Boston Dynamics: il robot umano...
TV da 130 pollici ed elettrodomestici, p...
I giochi classici cambiano volto con RTX...
OpenAI testa la pubblicità in Cha...
Plaud riscrive il modo di prendere appun...
Narwal presenta a Las Vegas la nuova gam...
1000W solo per la scheda video: la GeFor...
NVIDIA espande GeForce NOW: nuove app Li...
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: 01:28.


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