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

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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 vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
La capsula SpaceX Dragon CRS-33 ha acces...
La NASA è sempre più vicin...
Crisi delle memorie: ASUS torna al passa...
Le console next-generation potrebbero es...
Gemini cresce ancora: la quota di mercat...
Samsung sfida TSMC: la capacità produtti...
Iliad alza il prezzo della fibra ottica ...
Il prossimo low cost di POCO sarà il più...
The Elder Scrolls VI: ecco le ultime sul...
Ecco i saldi di fine anno Amazon, 34 off...
iPhone Fold: scorte limitate al lancio m...
OpenAI porterà la pubblicità in ChatGPT ...
TSMC aumenterà ancora i prezzi: nel 2026...
Marvel pubblica anche il secondo teaser ...
Nuovo accordo tra xAI e il Pentagono: l'...
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: 13:46.


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