Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Cos'è la bolla dell'IA e perché se ne parla
Cos'è la bolla dell'IA e perché se ne parla
Si parla molto ultimamente di "bolla dell'intelligenza artificiale", ma non è sempre chiaro perché: l'IA è una tecnologia molto promettente e che ha già cambiato molte cose dentro e fuori le aziende, ma ci sono enormi aspettative che stanno gonfiando a dismisura i valori delle azioni e distorcendo il mercato. Il che, com'è facile intuire, può portare a una ripetizione della "bolla dotcom", e forse anche di quella dei mutui subprime. Vediamo perché
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-03-2017, 16:04   #1
domenico88
Senior Member
 
L'Avatar di domenico88
 
Iscritto dal: Dec 2009
Messaggi: 1056
[C]Sincronizzazione tra processi

Salve
Sto studiando sistemi operativi e sono un po' fermo su questo argomento da alcuni giorni -IPC(inter Comunication Process)-
In sostanza non riesco a capire come viene risolto il problema del deadlock tra i processi produttore e consumatore attraverso i semafori

Il codice del produttore e del consumatore con le chiamate sleep() e wakeup() mette in evidenza la problematica dello stallo tra i processi quando viene schedulato il consumatore un istante prima che esegua la chiamata sleep(), nel caso in cui il buffer sia vuoto con count uguale a zero.
In questo caso il produttore prende l esecuzione ed inserisce un elemento nel buffer, controlla se il buffer era vuoto e chiama wakeup() verso il consumatore

A questo punto se viene ripristanato il consumatore dallo scheduler per l esecuzione, il consumatore ancora non ha chiamto sleep ed il segnale di wakeup() viene perso. Riprendendo l esecuzione chiamerà sleep e andrà in wait
Il produttore eseguendo il codice riempirà il buffer ed eseguirà sleep a sua volta ed entrambi saranno in stato di sleep.

Codice:
#define  N 100
 
   int count = 0;

 void produttore(){

   int item;

while(TRUE){

   item = produceItem();
   
   if(count == N) //se il buffer è pieno va a sleep
     sleep();
   
   insertItem(item);
   count = count +1;
   
   if(count ==1)   //Se il buffer era vuoto risveglia il consumatore
     wakeup(consumatore);
   }
}

 void consumatore(){

   int item;

 while(TRUE){
   
   if(count == 0) //se il buffer è vuoto sleep
     sleep();
   
   item =removeItem();
   count = count -1;
   
   if(count == N -1) //Se il buffer era pieno risveglia il produttore
     wakeup(produttore);

   }
}
Il testo dice che attraverso i semafori viene risolto il problema della perdita dei wakeUp

Un semaforo che vale zero che sta ad indicare che non sono stati salvati dei wakeup o un numero maggiore di zero se uno o più wakeup sono in attesa(qua non ho per niente capito cosa vuole dire)
Le operazioni sui semafori sono down e up(analoghi a sleep e wakeup)
-down verifica se il valore è maggiore di zero, se è così decrementa il valore e continua, se è zero è sospeso
-up aumenta il valore del semaforo indirizzato, se uno o più processi stavano dormendo su quel semaforo, uno di loro è schedulato per completare il suo down

Qua non riesco proprio a capire, e il codice con i semafori altrettanto
Cioè non riesco a capire come i semafori riescono ad evitare le corse critiche e risolvere il problema della perdita di wakeup...

Nel codice dichiara tre semafori, uno mutex per l accesso alla regione critica ,uno empty impostato a N e uno Full impostato a zero
Spero che qualcuno mi possa dare una mano
Vi ringrazio comunque per la gentile attenzione
__________________
Alimentatore corsair RM650W-AMD ryzen 5 5600x - 16GB RAM DDR4 3600mhz- Dissipatore be quite dark rock 4- AMD RX6800XT - SSD Samsung 980PRO 1TB - CASE corsair ICUE 220T
Asus rog strix 35"
domenico88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2017, 15:55   #2
domenico88
Senior Member
 
L'Avatar di domenico88
 
Iscritto dal: Dec 2009
Messaggi: 1056
Grazie mille Antonio

In effetti la questione che non riesco a capire è proprio questa

Quote:
Originariamente inviato da Antonio23 Guarda i messaggi

un semaforo binario rinforza il concetto di sincronizzazione: un thread che fa la wait su un semaforo viene sbloccato da un altro thread che fa una release sullo stesso semaforo.
Per sincronizzazione viene inteso il fatto che solo un processo per volta può eseguire la sua sezione critica andando a lavorare su variabili o risorse condivise da altri processi..(Giusto?)

Quindi un processo o un thread che fa una wait( chiamata down() o sleep() analogamente ) su un semaforo viene sbloccato da un altro thread che farà un up() sullo stesso semaforo(up sarebbe analogo a wakeup).. umm
forse ci sto arrivando...
__________________
Alimentatore corsair RM650W-AMD ryzen 5 5600x - 16GB RAM DDR4 3600mhz- Dissipatore be quite dark rock 4- AMD RX6800XT - SSD Samsung 980PRO 1TB - CASE corsair ICUE 220T
Asus rog strix 35"
domenico88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2017, 19:44   #3
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da domenico88 Guarda i messaggi
Il codice del produttore e del consumatore con le chiamate sleep() e wakeup() mette in evidenza la problematica dello stallo tra i processi quando viene schedulato il consumatore un istante prima che esegua la chiamata sleep(), nel caso in cui il buffer sia vuoto con count uguale a zero.
In questo caso il produttore prende l esecuzione ed inserisce un elemento nel buffer, controlla se il buffer era vuoto e chiama wakeup() verso il consumatore
Esattamente. Il problema e' che tra la valutazione della condizione e la decisione di mettersi in sleep/inviare il segnale all'altra entita', puo' accadere che il processo in esecuzione ( consumatore o produttore ) venga sospeso e il controllo della cpu passi all'altro.

Quote:
Originariamente inviato da domenico88 Guarda i messaggi
In sostanza non riesco a capire come viene risolto il problema del deadlock tra i processi produttore e consumatore attraverso i semafori
Se guardi com'e' fatto un semaforo sotto il cofano, troverai questo

Codice:
wait()
	if sem.val > 0 then
		sem.val = sem.val - 1
	else
		blocca processo
end

signal()
	if processi bloccati su sem then
		attiva i processi
	else
		sem.val = sem.val + 1
end
nota che grosso modo e' simile al codice che hai postato, con una grandissima differenza pero'....i blocchi signal e wait non sono preemptibile, cioe' non e' possibile che l'esecuzione venga sospesa nel bel mezzo di uno di quei blocchi

e questo e' garantito dalla cpu, tramite apposite istruzioni e relativi meccanismi
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 07-03-2017, 00:30   #4
domenico88
Senior Member
 
L'Avatar di domenico88
 
Iscritto dal: Dec 2009
Messaggi: 1056
Grazie mille forse sono riuscito a capire come funziona il codice con i semafori anche se ho ancora dei dubbi su alcune cose.. forse è un argomento particolare che proprio non mi entra bene...
__________________
Alimentatore corsair RM650W-AMD ryzen 5 5600x - 16GB RAM DDR4 3600mhz- Dissipatore be quite dark rock 4- AMD RX6800XT - SSD Samsung 980PRO 1TB - CASE corsair ICUE 220T
Asus rog strix 35"
domenico88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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 ...
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
SpaceX: un satellite ha fotografato il s...
36 idee regalo con offerte Amazon sotto ...
Sony assume il controllo dei Peanuts: Sn...
DJI Neo scende a 149€ su Amazon, in vers...
Scoperto un nuovo esopianeta che orbita ...
Blue Origin NS-37: successo per la missi...
Potrebbe essere stata rilevata una super...
La cometa interstellare 3I/ATLAS è...
Xiaomi 17 Ultra: l'autonomia non sarà un...
Il processo produttivo a 2 nm di TSMC è ...
L'atteso aggiornamento dei driver della ...
The Elder Scrolls VI nel 2029 e Fallout ...
Il Ryzen 7 9850X3D appare nel catalogo d...
Weekend pre natalizio Amazon, ecco tutte...
Prezzi giù su Oral-B iO: spazzolini elet...
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: 02:20.


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