Torna indietro   Hardware Upgrade Forum > Software > Programmazione

AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-05-2004, 16:27   #1
cavay
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??
cavay è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 16:34   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
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
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 16:44   #3
cavay
Member
 
Iscritto dal: Sep 2001
Messaggi: 181
ops...ho sbagliato...nn me ne ero accorto
cavay è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 19:10   #4
Wyrdmeister
Member
 
L'Avatar di Wyrdmeister
 
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
Wyrdmeister è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 19:56   #5
Burns
Senior Member
 
L'Avatar di Burns
 
Iscritto dal: Jun 2003
Città: Lund, Sweden
Messaggi: 1248
Quote:
Originariamente inviato da Wyrdmeister
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)
Sei sicuro?
__________________
"Guardami gli occhi; il destro è artificiale.
Con il sinistro registro il presente, col destro ricordo il passato."
See you space cowboy...
Burns è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 19:59   #6
cavay
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!
cavay è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 20:34   #7
Wyrdmeister
Member
 
L'Avatar di Wyrdmeister
 
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
Quote:
Originariamente inviato da Burns
Sei sicuro?
http://news.hwupgrade.it/11393.html
__________________
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
Wyrdmeister è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 21:22   #8
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Wyrdmeister
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)
Stai mischiando due cose diverse: latenza di una syscall e latenza dello scheduler.

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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 21:32   #9
Wyrdmeister
Member
 
L'Avatar di Wyrdmeister
 
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 spiega perchè!
__________________
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.
Wyrdmeister è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 21:38   #10
Wyrdmeister
Member
 
L'Avatar di Wyrdmeister
 
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
Quote:
Originariamente inviato da ilsensine
Stai mischiando due cose diverse: latenza di una syscall e latenza dello scheduler.

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.
hai ragione... ... avevo pensato al fatto che la timeslice era troppo lunga ma non sapevo come fosse nel kernel linux... le mie del resto erano solo un'ipotesi... in effetti in un sistema senza carico la latenza di una syscall non è poi fondamentale! soprattutto perchè non c'è ogni volta che il processo esce dalla sleep, ma è casuale!
__________________
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
Wyrdmeister è offline   Rispondi citando il messaggio o parte di esso
Old 31-05-2004, 23:06   #11
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
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/
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 00:20   #12
cavay
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?
cavay è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 01:39   #13
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
Ma un giocattolino per fare cosa ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 08:38   #14
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cavay
quindi sembrerebbe che nn ci sono soluzioni....il timer inizialmente veniva gestito con una select ma....anch'essa nn si comportava bene...
Per valori di usleep relativamente bassi (decine di ms) la funzione viene implementata con nanosleep. Se dai una occhiata alla manpage di nanosleep, leggerai alcuni dettagli sul suo comportamento. In particolare, puoi ottenere risoluzioni precise utilizzando una strategia di scheduling real-time (sched-fifo oppure sched-roundrobin; v. man sched_setscheduler). Occhio che questo viene ottenuto a scapito degli altri processi e di un'ottimale allocazione del processore, quindi non ne abusare.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 16:09   #15
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Quote:
Originariamente inviato da Wyrdmeister
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!

Come sarebbe che non capisci? Ilsensine ti ha spiegato che molto dipende dallo scheduler della CPU (che sceglie fra i processi in ready queue quale deve essere eseguito). Quindi dal carico e dalla tipologia di lavoro presente nel sistema al momento in cui lanci il tuo processo. Addirittura eseguendolo sulla tua stessa macchina in momenti diversi, con carichi diversi, potresti avere differenze significative.
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2004, 17:48   #16
Wyrdmeister
Member
 
L'Avatar di Wyrdmeister
 
Iscritto dal: Apr 2004
Città: Milano
Messaggi: 225
Quote:
Originariamente inviato da cn73
Come sarebbe che non capisci? Ilsensine ti ha spiegato che molto dipende dallo scheduler della CPU (che sceglie fra i processi in ready queue quale deve essere eseguito). Quindi dal carico e dalla tipologia di lavoro presente nel sistema al momento in cui lanci il tuo processo. Addirittura eseguendolo sulla tua stessa macchina in momenti diversi, con carichi diversi, potresti avere differenze significative.
Quando ho postato non avevo ancora letto il messaggio... infatti poi ho editato!
__________________
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
Wyrdmeister è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Tutti i Kindle Scribe in sconto, ma prop...
Booking.com e OpenAI annunciano SME AI A...
Xiaomi SU7 Ultra: da domani tutti i gioc...
Sharp Inspire Expo 2026: da produttore d...
Razer Synapse Web è realtà...
Concessionarie Audi chiudono improvvisam...
Resident Evil Requiem: 4K, 60 FPS e ray ...
Le batterie LFP sono piccole e pesanti? ...
Motorola inarrestabile: nuova serie moto...
Decima generazione Pokémon: grafi...
Una nuova legge consente di rottamare un...
Google mostra per sbaglio Android per PC...
Tesla non convince più: crolla il...
OpenAI lancia Prism: l'AI ora lavora fia...
Nissan mette i pannelli solari su Ariya:...
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:14.


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