|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Sep 2001
Messaggi: 181
|
bachi linux?
Sto provando a fare un timer per linux in c++ ma....qualsiasi primitiva utilizzo mi sembra che portino un ritardo o cmq un nn buon funzionamento.
Testiamo una sleep ad esempio: #include <sys/time.h> #include <stdio.h> #include <unistd.h> void *TimeZone; struct timeval Before; struct timeval After; int main() { while(1) { gettimeofday (&Before, TimeZone); //usleep(1000); //1 ms sleep(1); //1 s gettimeofday (&After, TimeZone); printf("\nIl tempo trascorso è %d(sec) e %d(usec", After.tv_sec-Before.tv_sec, After.tv_usec-Before.tv_usec); fflush(stdout); } } Dall'esecuzione dell'exe prodotto si nota che c'è un ritardo medio di circa 8ms, se lostesso codice lo compilo su piattaforma DIGITAL il ritardo è nullo. Qualcuno mi sa consigliare qualche soluzione o cmq darmi una spiegazione alla cosa? è INTEL o LINUX OS che nn vanno?? |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Oct 2001
Messaggi: 11471
|
forse è meglio che chiedi ad un moderatore di spostare la discussione in Programmazione li trovi di sicuro qualcuno piu adatto a risponderti.
ciao |
|
|
|
|
|
#3 |
|
Member
Iscritto dal: Sep 2001
Messaggi: 181
|
ops...ho sbagliato...nn me ne ero accorto
|
|
|
|
|
|
#4 |
|
Member
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
|
Ipotesi:
1) puoi provare a impostare il nice del processo a realtime (mi pare che sia -20) altrimenti potrebbe succedere che il tuo processo non sia messo in esecuzione immediatamente... inoltre per quel che ne so io, una sleep(t) ti assicura che il tuo processo non tornerà in esecuzione prima di un tempo t, ma non ti assicura che ritorni in esecuzione immediatamente dopo un tempo t... 2) usi un kernel 2.4? il codice di sistema del 2.4 non è preemptive quindi se un altro processo sta eseguendo una chiamata di sistema nel momento in cui esci dalla sleep devi aspettare che la finisca prima di poter tornare in esecuzione (prova un 2.6 con il supporto preemptive per il codice in modalità kernel) 3) Altri motivi che ignoro.. non conosco l'architettura DIGITAL
__________________
Workstation: Epox 8RDA+ con AthlonXP 2400+@3000+ (200x12=2400Mhz @ 1,9V) - 512Mb Corsair 6-3-3-2 - 2 x Maxtor D740X 40Gb RAID0 su Sil0680 - WD Caviar 1200JB 120Gb - Plextor PX-W4824A - NEC ND2500A - WinXP SP1 - Gentoo Linux, kernel 2.6.5 Server: PIII 800 su Asus CUSL2 - 256Mb - IBM Deskstar 30Gb - Linux Slackware 9.1 |
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Jun 2003
Città: Lund, Sweden
Messaggi: 1248
|
Quote:
__________________
"Guardami gli occhi; il destro è artificiale. Con il sinistro registro il presente, col destro ricordo il passato." See you space cowboy... |
|
|
|
|
|
|
#6 |
|
Member
Iscritto dal: Sep 2001
Messaggi: 181
|
Hai raggne circa la sleep, è proprio come dici ma...u ritardo di circa 8-9milli al secondo...è eccessivo.
Se si pensa che sulla macchina nn stava girando "niente" poi... Ho appena provato anche su altre piattaforme(SUN-SOLARIS e LYNX su power pc)...tutto funziona come dovrebbe.. Circa invece il kernel...nn so che sto utilizzando ma è quello di default della RH 9, sai è la piattaforma target(INTEL-LINUX); niente su linux ma...intell....va be lasciamo stare. Faro' delle indagini in +, grazie per l'aiuto! |
|
|
|
|
|
#7 | |
|
Member
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
|
Quote:
__________________
Workstation: Epox 8RDA+ con AthlonXP 2400+@3000+ (200x12=2400Mhz @ 1,9V) - 512Mb Corsair 6-3-3-2 - 2 x Maxtor D740X 40Gb RAID0 su Sil0680 - WD Caviar 1200JB 120Gb - Plextor PX-W4824A - NEC ND2500A - WinXP SP1 - Gentoo Linux, kernel 2.6.5 Server: PIII 800 su Asus CUSL2 - 256Mb - IBM Deskstar 30Gb - Linux Slackware 9.1 |
|
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
La prima è sì ridotta da un kernel preemptive, ma non ha un grande effetto sulla usleep (finché le grandezze in gioco rimangono nell'ordine dei ms). La seconda è ciò che determina il tempo effettivo speso nella usleep: quando un processo va a "dormire", il sistema invoca lo scheduler e passa ad un altro processo. Il tempo assegnato a ciascun processo in ciascuna epoca è rozzamente pari a 1/HZ, dove "HZ" è il "parametro magico" in questione. A meno che il secondo processo non vada anch'esso a dormire con usleep, consuma tutto il timeslice a sua disposizione. E' plausibile quindi che il tempo di attesa _minimo_ (a seconda del carico può salire considerevolmente) è nell'ordine di 1/HZ. Nei kernel 2.4 HZ è di 100 herts (con un ritardo minimo di scheduling di circa 10 ms); nei kernel 2.6 è stato elevato a 1000 (o 1024 non ricordo; il ritardo minimo è di circa 1 ms ma può crescere per altri fattori). Altri sistemi possono presentare comportamenti diversi, in quanto lo scheduler è una delle cose più "variegate" dell'informatica. Non mi sorprenderebbe che uno scheduler che sembra "perfetto" per il tuo programma, all'aumentare del carico degradi considerevolmente le sue prestazioni. Anche il numero di processori del sistema influisce, ovviamente.
__________________
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 |
|
|
|
|
|
|
#9 |
|
Member
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
|
Ho provato il codice su un p3 800 con kernel 2.6.5, compilato con gcc 3.3.3 e ottengo ritardi inferiori ai 2ms...
Il tempo trascorso è 1(sec) e 1701(usec) Il tempo trascorso è 1(sec) e 1627(usec) Il tempo trascorso è 1(sec) e 1805(usec) Il tempo trascorso è 1(sec) e 1782(usec) Il tempo trascorso è 1(sec) e 1797(usec) Il tempo trascorso è 1(sec) e 1786(usec) Il tempo trascorso è 1(sec) e 1806(usec) Il tempo trascorso è 1(sec) e 1781(usec) Il tempo trascorso è 1(sec) e 1807(usec) Il tempo trascorso è 1(sec) e 1780(usec) Il tempo trascorso è 1(sec) e 1794(usec) Il tempo trascorso è 1(sec) e 1784(usec) Il tempo trascorso è 1(sec) e 1810(usec) Il tempo trascorso è 1(sec) e 1783(usec) Il tempo trascorso è 1(sec) e 1809(usec) Il tempo trascorso è 1(sec) e 1786(usec) Inoltre avviando il programma di prova con il comando: nice -n "-30" ./prova il ritardo si riduce fino a 1.4ms e anche meno a volte... non capisco perchè sulla tua macchina abbia latenze maggiori! EDIT: il messaggio di ilsensine che non avevo ancora letto
__________________
Workstation: Epox 8RDA+ con AthlonXP 2400+@3000+ (200x12=2400Mhz @ 1,9V) - 512Mb Corsair 6-3-3-2 - 2 x Maxtor D740X 40Gb RAID0 su Sil0680 - WD Caviar 1200JB 120Gb - Plextor PX-W4824A - NEC ND2500A - WinXP SP1 - Gentoo Linux, kernel 2.6.5 Server: PIII 800 su Asus CUSL2 - 256Mb - IBM Deskstar 30Gb - Linux Slackware 9.1 Ultima modifica di Wyrdmeister : 31-05-2004 alle 21:40. |
|
|
|
|
|
#10 | |
|
Member
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
|
Quote:
__________________
Workstation: Epox 8RDA+ con AthlonXP 2400+@3000+ (200x12=2400Mhz @ 1,9V) - 512Mb Corsair 6-3-3-2 - 2 x Maxtor D740X 40Gb RAID0 su Sil0680 - WD Caviar 1200JB 120Gb - Plextor PX-W4824A - NEC ND2500A - WinXP SP1 - Gentoo Linux, kernel 2.6.5 Server: PIII 800 su Asus CUSL2 - 256Mb - IBM Deskstar 30Gb - Linux Slackware 9.1 |
|
|
|
|
|
|
#11 |
|
Bannato
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
|
Qui puoi trovare un confronto tra i nanosleep di diversi unix (non aggiornatissimo, ma lettura comunque interessante)
http://www.dragonflybsd.org/docs/nanosleep/ |
|
|
|
|
|
#12 |
|
Member
Iscritto dal: Sep 2001
Messaggi: 181
|
quindi sembrerebbe che nn ci sono soluzioni....il timer inizialmente veniva gestito con una select ma....anch'essa nn si comportava bene...
Quindi...possiamo dire che INTEL-LINUX è ancora un giocattolino? |
|
|
|
|
|
#13 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ma un giocattolino per fare cosa ?
|
|
|
|
|
|
#14 | |
|
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 |
|
|
|
|
|
|
#15 | |
|
Senior Member
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
|
Quote:
|
|
|
|
|
|
|
#16 | |
|
Member
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
|
Quote:
__________________
Workstation: Epox 8RDA+ con AthlonXP 2400+@3000+ (200x12=2400Mhz @ 1,9V) - 512Mb Corsair 6-3-3-2 - 2 x Maxtor D740X 40Gb RAID0 su Sil0680 - WD Caviar 1200JB 120Gb - Plextor PX-W4824A - NEC ND2500A - WinXP SP1 - Gentoo Linux, kernel 2.6.5 Server: PIII 800 su Asus CUSL2 - 256Mb - IBM Deskstar 30Gb - Linux Slackware 9.1 |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 08:14.


















