|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Nov 2002
Messaggi: 845
|
Scheduling Real Time Come?
Salve
sto realizzando un'applicazione tempo critica. So che ho diverse opzioni : 1) patch per il kernel 2) installare RTAI (kernel RealTime) 3) lasciare tutto com'e' e provare a giocare con sched.h e pthread.h faccio partire il processo, dal processo partono diversi thread (nessun figlio) ai thread ho dato priorita' alta con pthread_attr_setschedparam se tramite le funzioni della lib sched.h do altissima priorita' al processo ne guadagneranno anke i thread da lui creati? Dato che se non ne guadagnano i thread (che sn il cuore del programma) nn ho ragione di schedulare con prio piu' alta il quasi inutile "main". Grazie Salvo |
![]() |
![]() |
![]() |
#2 | |||
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
Quote:
Potrebbe anche essere consigliabile un mlockall() all'inizio del programma (thread principale). Quote:
Occhio che il RT richiede cooperazione da parte del programmatore: fai un thread RT ad alta priorità rispetto agli altri, che sfora la sua quota temporale, e tutto è inutile. Sposto in programmzione.
__________________
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 Ultima modifica di ilsensine : 06-06-2005 alle 14:10. |
|||
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Nov 2002
Messaggi: 845
|
Bene, onestamente spero che la schedulazione "semplice" funzioni...oggi facevo esperimenti.
Se in un thread faccio getpid, mi torna il pid del main (processo principale) e infatti eredità la sched...pero' se dentro il thread tento di manipolare la schedulazione, il valore cambia, ma il S.O. nn ne risente... mi spiego meglio nel thread faccio uno setsched FIFO + 99, se faccio un getsched mi da 99 pero' li thread nn viene schedulato da 99 (quando schedulo a 99 con un while da un miliardo di cicli mi si blocca pure il mouse) se invece schedulo nel main tutto bene. il mio software ha 4/5thread+main. Uno che "guarda" la scheda sonora per vedere se ci sono impulsi superiore a una certa soglia in dB uno che "guarda" la scheda di rete tramite socket per vedere se ci sn pacchetti in arrivo e che a sua volta lancia un altro thread per vedere di che tipo di pacchetto si tratta. uno che manda i pacchetti ogni tot secondi (10 circa) uno che ogni 30 pacchetti applica un algoritmo per computare dei ritardi. Per nn perdere il vantaggio dovrei schedulare tutti e 5 a 99, giusto? Cosa è un mlockall() ? cosa implica? grazie mille Salvo Ultima modifica di parisisalvo : 06-06-2005 alle 21:56. |
![]() |
![]() |
![]() |
#4 | ||||
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
In soldoni: se devi chiamare delle funzioni che richiedono il pid di processo da dentro un thread (ad es. sched_setscheduler), non usare la getpid ma la gettid (oppure usa le funzioni specifiche per i thread, come pthread_setscheduler). Quote:
Quote:
Quote:
Forza tutta la memoria del processo a risiedere in ram, eliminando i page fault e le attese di swapin/page load che cozzano per ovvi motivi con i requisiti real time.
__________________
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 |
||||
![]() |
![]() |
![]() |
#5 | |
Senior Member
Iscritto dal: Nov 2002
Messaggi: 845
|
Quote:
Ora capisco la storia del PID non PID...quindi devo fare gettid (qual è il comando da consolle per vedere tutti i processi e thread?) cmq usero' le funzioni apposite per i thread. |
|
![]() |
![]() |
![]() |
#6 | ||
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
Le isr (interrupt service routine) hanno la priorità maggiore, in quanto un irq hardware deve essere gestito immediatamente, ma non hanno contesto di processo quindi non le vedi negli elenchi dei task (i normali kernel thread li vedi; sono riconoscibili per l'assenza della VMA). Una isr mal scritta, oppure un blocco che tiene uno spinlock per troppo tempo, sono le principali sorgenti di alte latenze. Quote:
![]()
__________________
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 |
||
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Nov 2002
Messaggi: 845
|
Salve, rileggevo questo mio vechio post...
mi chiedevo una cosa... date due istruzioni istruzione1; istruzione2; si puo' dire allo scheduler in maniera diretta che alla fine dell'istruzione1 deve assolutamente essere eseguita l'istruzione2?? in pratica io assegno priorita' "bestiale" al thread che ha queste due istruzioni quindi mi aspetto che vengano eseguite insieme...nn c'e' un metodo "esplicito" ? |
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Scheduling FIFO o Round Robin, come ho detto. Nota che non c'è modo per impedire a un isr di interrompere il tuo processo, ma puoi evitare lo scheduling verso altri task.
__________________
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 |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 19:54.