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

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
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


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Il nuovo Snapdragon 8 Elite Gen 6 sar&ag...
Nintendo Switch 2: risultati sotto le at...
Weekend con tante sorprese su Amazon: to...
HONOR non si ferma più: il 2025 &...
Speciale best seller: EUREKA J15 Evo Ult...
Roborock Q10 X5+ da 10.000 Pa a 199€ &eg...
E-mail reset password di Instagram: la c...
La NASA ha discusso le problematiche del...
Il razzo spaziale NASA SLS e la capsula ...
Stazione Spaziale Internazionale: Crew-1...
Samsung Galaxy S26 Ultra: la ricarica de...
Apple ha un nuovo partner per la sua App...
Trenitalia introduce il prezzo dinamico ...
OnePlus non si ferma più: c'&egra...
DAZN sconta il piano Full per 6 mesi, se...
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: 23:24.


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