|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
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. |
|
|
|
|
|
#2 |
|
Senior Member
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 |
|
|
|
|
|
#3 | ||
|
Senior Member
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
|
Quote:
Quote:
|
||
|
|
|
|
|
#4 | |
|
Member
Iscritto dal: Oct 2005
Messaggi: 258
|
Quote:
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);
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);
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. |
|
|
|
|
|
|
#5 |
|
Senior Member
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
|
|
|
|
|
|
#6 |
|
Member
Iscritto dal: Oct 2005
Messaggi: 258
|
|
|
|
|
|
|
#7 |
|
Senior Member
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! |
|
|
|
|
|
#8 |
|
Member
Iscritto dal: Oct 2005
Messaggi: 258
|
|
|
|
|
|
|
#9 |
|
Senior Member
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! |
|
|
|
|
|
#10 |
|
Senior Member
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! |
|
|
|
|
|
#11 |
|
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 : \ |
|
|
|
|
|
#12 |
|
Senior Member
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...
Ultima modifica di Tommo : 05-02-2009 alle 16:23. |
|
|
|
|
|
#13 |
|
Senior Member
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! |
|
|
|
|
|
#14 |
|
Senior Member
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. |
|
|
|
|
|
#15 |
|
Senior Member
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! |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 08:33.





















