This shows you the differences between two versions of the page.
|
patr:laboratoare:10 [2022/01/13 13:54] alexandru.ionita99 [Introducere] |
patr:laboratoare:10 [2022/01/13 14:00] (current) alexandru.ionita99 |
||
|---|---|---|---|
| Line 7: | Line 7: | ||
| FreeRTOS utilizează următoarele tipuri de semafoare, pe care le vom detalia în continuare: | FreeRTOS utilizează următoarele tipuri de semafoare, pe care le vom detalia în continuare: | ||
| * Semafoare binare | * Semafoare binare | ||
| - | * Mutexuri | ||
| * Semafoare generalizate | * Semafoare generalizate | ||
| + | * Mutexuri | ||
| În cadrul acestui laborator, vom discuta despre semafoarele binare și cele generalizate, urmând ca în următorul să fie prezentate mutexurile. | În cadrul acestui laborator, vom discuta despre semafoarele binare și cele generalizate, urmând ca în următorul să fie prezentate mutexurile. | ||
| Line 31: | Line 31: | ||
| === Semafoare binare === | === Semafoare binare === | ||
| - | După cum am specificat anterior, există câteva diferențe între semafoarele binare și mutexuri. Întrucât pot fi deblocate de orice task, semafoarele binare sunt mai potrivite atunci când avem nevoie de o sincronizare a două taskuri. De exemplu, un task mai rapid poate fi blocat la un semafor până când un task mai lent ajunge într-un punct în care îl deblochează. \\ | + | O situație în care semafoarele binare se pretează este sincronizarea a două task-uri. De exemplu, un task mai rapid poate fi blocat la un semafor până când un task mai lent ajunge într-un punct în care îl deblochează. \\ |
| + | Diferențele dintre mutexuri și semafoarele binare vor fi prezentate în cadrul laboratorului viitor. Momentan, ne vom orienta atenția către crearea semafoarelor binare. | ||
| Pentru a crea un semafor binar, este utilizată funcția ** xSemaphoreCreateBinary() **. Aceasta alocă spațiu în heap pentru semaforul binar și îl creează, cu starea inițială este "blocat". Dacă valoarea întoarsă este NULL, nu există suficientă memorie disponibilă. \\ | Pentru a crea un semafor binar, este utilizată funcția ** xSemaphoreCreateBinary() **. Aceasta alocă spațiu în heap pentru semaforul binar și îl creează, cu starea inițială este "blocat". Dacă valoarea întoarsă este NULL, nu există suficientă memorie disponibilă. \\ | ||
| Line 72: | Line 73: | ||
| În exemplul de mai sus, handle-ul a fost declarat în interiorul unui task și nu sub formă de variabilă globală. | În exemplul de mai sus, handle-ul a fost declarat în interiorul unui task și nu sub formă de variabilă globală. | ||
| - | === Mutexuri === | ||
| - | Utilizate în principal pentru gestionarea accesului la o resursă partajată, mutexurile sunt create cu ajutorul funcției ** xSemaphoreCreateMutex()**. | ||
| - | |||
| - | **Exemplu:** | ||
| - | <code c> | ||
| - | SemaphoreHandle_t xSemaphore; | ||
| - | void vATask( void * pvParameters ) | ||
| - | { | ||
| - | xSemaphore = xSemaphoreCreateMutex(); // Apelare funcție creare mutex | ||
| - | if( xSemaphore == NULL ) | ||
| - | { | ||
| - | /* Spațiu de memorie insuficient */ | ||
| - | } | ||
| - | else | ||
| - | { | ||
| - | /* Mutexul poate fi utilizat */ | ||
| - | } | ||
| - | } | ||
| - | |||
| - | </code> | ||