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

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-01-2006, 00: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, 01: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, 09: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, 17: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, 22: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, 08: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, 15: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


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Hyundai: spunta un'elettrica estremament...
Una connessione diretta con AWS European...
La Toyota Yaris avrà una versione...
Minori sessualizzati da Grok: l'UE mette...
NIO stabilisce il nuovo record di scambi...
Dell Private Cloud sempre più ape...
Ennesimo incidente per la guida autonoma...
Dopo le maniglie, è il turno dei ...
Addio incendi incontrollati? Svolt dice ...
WINDTRE si mette in proprio: vender&agra...
The Mandalorian & Grogu: il trailer ...
OpenClaw sotto attacco: i malware infost...
Resident Evil Requiem: pre-load dal 25 f...
Vaticano, la Messa si traduce in 60 ling...
Kia prepara il facelift della Kia EV5: n...
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: 00:32.


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