|
|
|
![]() |
|
Strumenti |
![]() |
#61 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Compila con -D_GNU_SOURCE
__________________
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 |
![]() |
![]() |
![]() |
#62 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
|
|
![]() |
![]() |
![]() |
#63 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
...segreti del mestiere
![]() (...e una omissione/dimenticanza nella pagina man)
__________________
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 |
![]() |
![]() |
![]() |
#64 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
![]() |
|
![]() |
![]() |
![]() |
#65 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Alcune funzionalità delle libc sono proprie di standard particolari e non sono disponibili a meno di definire delle macro specifiche. Definendo _GNU_SOURCE hai accesso a tutte le funzionalità delle libc.
Altri esempi sono: sched_yield() formato esteso di sigaction strndup ecc.
__________________
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 |
![]() |
![]() |
![]() |
#66 |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Se io ho un server con un certo indirizzo ip: e ho n figli che cercano di aprire listening socket in mutua esclusione senno' la bind si arrabbia, perche' assegna 2 volte lo stesso socketfd a 2 client differenti che si sono collegati?
C'e' qualche variabile che devo condividere con tutti gli n figli? |
![]() |
![]() |
![]() |
#67 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quando un processo forka, i due processi risultanti avranno una propria storia. Quindi un fd di uno sarà un descrittore a parte rispetto l'fd dell'altro, indipendentemente che abbiano o no lo stesso valore. Solo gli fd già aperti possono venir ereditati dal child, ma in tal caso viene in effetti duplicato il descrittore da condividere.
__________________
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 |
![]() |
![]() |
![]() |
#68 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
A1 e A2 sono figli di A con lo stesso indirizzo e stessa cosa dicasi per B1 e B2. |
|
![]() |
![]() |
![]() |
#69 | |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
__________________
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 |
|
![]() |
![]() |
![]() |
#70 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
Per capire meglio se io ho A1 che si connette a B1 e voglio che anche A2 e B2 si connettano insieme devo fare 2 connessioni completamente differenti? Questo anche se sono entrambi figli di A (A1 e A2) e quindi hanno lo stesso indirizzo e porta ip? In alternativa non e' fattibile che io allacci una connessione tra A e B (i padri) e poi tutti i figli di A (A1, A2...) possono usare il canale e cosi' anche tutti i figli di B (B1, B2...). Questo e' molto importante, grazie ancora per rispondere sempre tempestivamente alle domane, sto facendo un progetto per niente semplice... |
|
![]() |
![]() |
![]() |
#71 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Non capisco qual è il problema...
A dovrebbe stare in listen e creare un child ad ogni nuova connessione, ok? Ogni figlio By di B effettua una connect() con A, il quale crea un child Ax per gestire la connessione...in genere si fa così
__________________
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 |
![]() |
![]() |
![]() |
#72 |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Ok io invece prima creavo il figlio e poi la connessione veniva generata dallo stesso figlio, speravo poi di poter recuperare da un altro figlio la connessione avvenuta mantenendo lo stesso socketfd, ma cosi' non funzia...
ma io posso fare cosi'? 1) il padre crea il figlio 2) il figlio si mette in attesa che il padre gli procuri una connessione 3) il padre crea tutti i figli che si mettono in attesa 4) il padre si mette in attesa di una connessione appena gliene arriva una lui passa il numero del socketfd al/ai figlio/i interessati e poi ritorna al punto 4) cioe' in attesa di altre connessioni. E' un po' diverso dal aspettare la connessione e poi creare, pero' mi sembra che il conto torni...o mi sbaglio? |
![]() |
![]() |
![]() |
#73 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Ok certo, se vuoi perdere tutti i capelli prima del tempo, è la procedura migliore
![]()
__________________
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 |
![]() |
![]() |
![]() |
#74 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
Ma se io devo fare gestire tutto dal padre, come faccio contemporaneamente a mettermi in ascolto e a connettermi? Questo perche' il programma che sto cercando di fare fa sia da server che da client, quindi fino a poco fa, un client si collegava al server (erano 2 figli differenti di 2 istante differenti non so se ho reso l'idea) ora pero' se il padre si mette in ascolto, quello si inchioda li' e come faccio contemporaneamente a cercare di connettermi? ARGH AIUTO! |
|
![]() |
![]() |
![]() |
#75 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Non intendevo di far fare tutto a un padre, ma di creare i child solo quando servivano, per uno scopo ben preciso, e in maniera che possano essere autonomi una volta creati e inizializzati.
Cmq dovresti analizzare l'opportunità di usare i pthread al posto di processi distinti (è più facile l'ipc, non serve shm, semafori o altro).
__________________
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 |
![]() |
![]() |
![]() |
#76 | |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Quote:
Il primo processo crea inoltre un altro processo figlio client quando serve (se puoi gestire più client contemporaneamente, altrimenti è lo stesso processo padre che fa da client)... Segui il consiglio di ilsensine sui pthread... I thread a differenza dei processi sono a memoria comune ![]() |
|
![]() |
![]() |
![]() |
#77 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
Ora: se io creo un primo figlio che si mette in ascolto e poi appena si connette a sua volta crea un figlio che gestisce la connessione ok questo il lato server, il lato client pero' dove lo metto? Faccio fare un secondo figlio al padre e poi cerco a sua volta di connettermi e se ci riesco creo un figlio? Pero' in questo caso e' sempre la stessa storia la connessione raggiunta dal client o dal server non e' gestibile dall'altra parte. Mi sono spiegato? Se no vi faccio pure un disegno pure di farvi capire...rispondetemi sono in kernel panic ![]() |
|
![]() |
![]() |
![]() |
#78 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Spiegami meglio...
Il server quante connessioni accetta ? Una sola ? E il client a quenti server si può conenttere ? |
![]() |
![]() |
![]() |
#79 | |
Senior Member
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
|
Quote:
Il client puo' anche lui connettersi da 0 a n host. Siccome molte volte il client e il server della stessa istanza del software possono (ma non e' detto) connettersi allo stesso host (che altro non e' che un'altra istanza del medesimo software) vorrei che questa connessione venga condivisa! Ti spedisco anche un disegno scannerizzato per rendere l'idea...immagina che di istanze del mio software ce ne puo' essere da 1 a n anche per quella. Spero di essere stato piu' chiaro...fammi sapere... |
|
![]() |
![]() |
![]() |
#80 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Un processo "listener" sta in ascolto con la accept su una porta...
Ogni volta che riceve una connessione in ingresso lancio un processo "chat" (la chiamo chat anche se magari no lo è, ma rende bene l'idea)... Un altro processo chiamo "connector" ha il compito di creare una nuova connessione verso un "listener"... Il processo "chat" è lo stesso sia per il "listener" che per il "connector" ed ha bisogno solamente del socket creato da uno dei due processi... Su questo socket viaggeranno sia i dati in uscita che quelli in ingresso... Se non hai grossi problemi di prestazioni credo che tu possa usare sia send che receive non bloccanti nello stesso processo... Oppure lanci un altro processo che si occupa di trasmettere e ricevere i dati...con send bloccanti e receive non bloccanti... |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 22:35.