Torna indietro   Hardware Upgrade Forum > Software > Linux, Unix, OS alternativi

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-01-2006, 23:05   #1
shodan
Senior Member
 
L'Avatar di shodan
 
Iscritto dal: Sep 2001
Città: Pescara
Messaggi: 3695
Domande sullo switch dei processi

Ciao a tutti,
apro questo post per togliermi alcuni dubbi su come funziona a livello hardware il contex switch nel kernel linux e sulle macchine x86.

Perdonatemi se le domande risulteranno banali, ma su google non riesco a trovare la risposta ai miei dubbi (nonostante abbia trovato molto materiale che spiega cos'è il contex switch e come funziona lo scheduler non ho trovato quello che cercavo).

Dato per scontato che ho presente abbastanza bene com'è implementato lo scheduler di linux, vorrei capire come fa quest'ultimo a far eseguire un processo solo per un certo tempo e come può, di conseguenza, accorgersi che questo tempo (quanto) è terminato.
E' una funzionalità integrata direttamente nell'hardware 386 e superiori, cioè lo scheduler dice al processore di eseguire un certo task solo per un certo quanto di tempo direttamente quando sta per lanciare il task in questione? Oppure lo scheduler si limita a controllare periodicamente il tempo di esecuzione di un certo task e confrontarlo con il quanto di tempo teoricamente assegnatoli?
Se fosse vera quest'ultima ipotesi, come potrebbe lo scheduler svolgere i suoi compiti? Per far questo dovrebbe essere eseguito, ma la CPU allo stesso tempo sta eseguendo il task assegnatole; come potrebbe eseguire contemporaneamente anche lo scheduler? Inoltre, in quest'ultimo caso nessuno ci assicurerebbe che il processo non sia in realtà eseguito per un tempo superiore al quanto originariamente assegnatogli.

In sintesi vorrei sapere se c'è un supporto hardware per il multitasking nelle CPU 386 e superiori, oppure se questo (compreso lo scheduler necessario a gestire i vari task) sia implementato solo nel software.

Ciao grazie!
shodan è offline   Rispondi citando il messaggio o parte di esso
Old 18-01-2006, 00:58   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Quote:
Originariamente inviato da shodan
Ciao a tutti,
apro questo post per togliermi alcuni dubbi su come funziona a livello hardware il contex switch nel kernel linux e sulle macchine x86.

Perdonatemi se le domande risulteranno banali, ma su google non riesco a trovare la risposta ai miei dubbi (nonostante abbia trovato molto materiale che spiega cos'è il contex switch e come funziona lo scheduler non ho trovato quello che cercavo).

Dato per scontato che ho presente abbastanza bene com'è implementato lo scheduler di linux, vorrei capire come fa quest'ultimo a far eseguire un processo solo per un certo tempo e come può, di conseguenza, accorgersi che questo tempo (quanto) è terminato.
E' una funzionalità integrata direttamente nell'hardware 386 e superiori, cioè lo scheduler dice al processore di eseguire un certo task solo per un certo quanto di tempo direttamente quando sta per lanciare il task in questione? Oppure lo scheduler si limita a controllare periodicamente il tempo di esecuzione di un certo task e confrontarlo con il quanto di tempo teoricamente assegnatoli?
Se fosse vera quest'ultima ipotesi, come potrebbe lo scheduler svolgere i suoi compiti? Per far questo dovrebbe essere eseguito, ma la CPU allo stesso tempo sta eseguendo il task assegnatole; come potrebbe eseguire contemporaneamente anche lo scheduler? Inoltre, in quest'ultimo caso nessuno ci assicurerebbe che il processo non sia in realtà eseguito per un tempo superiore al quanto originariamente assegnatogli.

In sintesi vorrei sapere se c'è un supporto hardware per il multitasking nelle CPU 386 e superiori, oppure se questo (compreso lo scheduler necessario a gestire i vari task) sia implementato solo nel software.

Ciao grazie!
Questa è più una domanda per la sezione Programmazione. Provo comunque a rispondere.
Un supporto anche se minimo è dato dagli interrupt che permettono l'esecuzione asincrona di certe routine. Sono usati ad esempio dalle periferiche per avvertire la CPU quando succede qualcosa. Se la CPU sente la presenza di un interrupt questa smette di fare quello che sta facendo e lancia in esecuzione il codice assegnato.

Oltre alle normali periferiche all'interno di ogni PC c'è anche un orologio piuttosto preciso che può essere programmato a lanciare un interrupt ogni X millisecondi.

Un sistema come linux non deve fare altro che impostare l'intervallo dell'orologio allo stesso valore del timeslice a disposizione di ogni processo ed associare al interrupt il codice dello scheduler. Quando verrà eseguito questo deciderà se cedere il controllo nuovamente al processo corrente oppure ad uno nuovo.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 18-01-2006, 08:31   #3
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da shodan
Dato per scontato che ho presente abbastanza bene com'è implementato lo scheduler di linux, vorrei capire come fa quest'ultimo a far eseguire un processo solo per un certo tempo e come può, di conseguenza, accorgersi che questo tempo (quanto) è terminato.
Tramite un timer di sistema

Quote:
E' una funzionalità integrata direttamente nell'hardware 386 e superiori, cioè lo scheduler dice al processore di eseguire un certo task solo per un certo quanto di tempo direttamente quando sta per lanciare il task in questione? Oppure lo scheduler si limita a controllare periodicamente il tempo di esecuzione di un certo task e confrontarlo con il quanto di tempo teoricamente assegnatoli?
Se fosse vera quest'ultima ipotesi, come potrebbe lo scheduler svolgere i suoi compiti? Per far questo dovrebbe essere eseguito, ma la CPU allo stesso tempo sta eseguendo il task assegnatole; come potrebbe eseguire contemporaneamente anche lo scheduler?
Il timer genera un irq, durante la gestione del quale il kernel controlla lo stato del quanto temporale del processo. Se necessario, il task viene spostato sulla runqueue dei processi "expired" e un nuovo task viene preparato per il ripristino dell'esecuzione. Molti processori, come gli x86, hanno uno specifico supporto hw per aiutare questa fase. Se chiedi in Programmazione possono fornirti i dettagli, se ti interessa.
__________________
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 18-01-2006, 16:30   #4
shodan
Senior Member
 
L'Avatar di shodan
 
Iscritto dal: Sep 2001
Città: Pescara
Messaggi: 3695
Grazie mille per le risposte!

Quindi, se ho ben capito:

-) il kernel imposta l'orologio di sistema per "emettere" un IRQ ogni x, dove x è il quanto di tempo impostato nel kernel stesso;
-) l'IRQ emesso dall'orologio viene associato al codice del kernel stesso (in questo caso dello scheduler);
-) lo scheduler sceglie un task da eseguire;
-) il task viene eseguito; in questa fase lo scheduler risulta interrotto (in che stato è? Sleeping?);
-) il timer avvisa tramite l'IRQ che il quanto è finito;
-) il task viene interrotto e la CPU riesegue nuovamente lo scheduler;
-) lo scheduler sceglie il prossimo task da eseguire.

Giusto?

Ciao.

PS: grazie a entrambi per le vostre risposte; spesso leggo con grande interesse i vostri interventi!
shodan è offline   Rispondi citando il messaggio o parte di esso
Old 18-01-2006, 21:08   #5
LimiT-MaTz
Senior Member
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 673
bello!
un post interessante proprio ora che sto studiando calcolatori-elettronici!
__________________
MaTz!
LimiT-MaTz è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2006, 07:58   #6
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da shodan
Grazie mille per le risposte!

Quindi, se ho ben capito:

-) il kernel imposta l'orologio di sistema per "emettere" un IRQ ogni x, dove x è il quanto di tempo impostato nel kernel stesso;
-) l'IRQ emesso dall'orologio viene associato al codice del kernel stesso (in questo caso dello scheduler);
-) lo scheduler sceglie un task da eseguire;
-) il task viene eseguito; in questa fase lo scheduler risulta interrotto (in che stato è? Sleeping?);
-) il timer avvisa tramite l'IRQ che il quanto è finito;
-) il task viene interrotto e la CPU riesegue nuovamente lo scheduler;
-) lo scheduler sceglie il prossimo task da eseguire.

Giusto?
Più o meno. Non ha senso dire che "lo scheduler risulta interrorro". Lo scheduler non è un programma, è una piccola libreria che viene invocata quando è necessario sospendere il processo corrente per attivarne un altro. Può essere invocato dall'irq handler del timer per emulare un multitask non cooperativo, ma può essere invocato anche in molte altre situazioni.
__________________
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 19-01-2006, 14:55   #7
shodan
Senior Member
 
L'Avatar di shodan
 
Iscritto dal: Sep 2001
Città: Pescara
Messaggi: 3695
Quote:
Originariamente inviato da ilsensine
Più o meno. Non ha senso dire che "lo scheduler risulta interrorro". Lo scheduler non è un programma, è una piccola libreria che viene invocata quando è necessario sospendere il processo corrente per attivarne un altro. Può essere invocato dall'irq handler del timer per emulare un multitask non cooperativo, ma può essere invocato anche in molte altre situazioni.
Perfetto... dovrei aver capito!

Grazie mille!
shodan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Larry Ellison guadagna 101 miliardi in u...
Johnson Controls amplia la gamma di solu...
NASA Perseverance: il rover potrebbe ave...
Quelli di Immuni si 'pappano' Vimeo: Ben...
Changan lancia la Deepal S05 in Europa, ...
Substrati in vetro, Intel smentisce le v...
ECOVACS DEEBOT T50 PRO OMNI Gen2 fa piaz...
Windelo 62: catamarano a vela che unisce...
Francia, in arrivo un incentivo di 1.000...
Haier, la sorpresa a IFA: la lavatrice C...
GeForce RTX 5000 SUPER in arrivo? Sembra...
Ionity prova una soluzione contro i ladr...
Pirateria, svolta clamorosa: Dazn e Lega...
Maxi richiamo Toyota e Lexus: oltre 900....
Blackwell Ultra: fino al 45% di prestazi...
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: 19:10.


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