X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=signal.tex;h=4d748d91a05fbf98770ec688e770f39088777666;hp=48d45b3f8dbefdefb3e4631a9b9f0e670dfe7a9d;hb=6483a787322c614bc6282a0bf0ee001f1bf54b44;hpb=c21ecd755b45e99ed8b1524e03444bf189bfcc06 diff --git a/signal.tex b/signal.tex index 48d45b3..4d748d9 100644 --- a/signal.tex +++ b/signal.tex @@ -140,9 +140,9 @@ Si dice che il segnale viene \textsl{consegnato} al processo (dall'inglese \textit{delivered}) quando viene eseguita l'azione per esso prevista, mentre per tutto il tempo che passa fra la generazione del segnale e la sua consegna esso è detto \textsl{pendente} (o \textit{pending}). In genere questa -procedura viene effettuata dallo scheduler quando, riprendendo l'esecuzione -del processo in questione, verifica la presenza del segnale nella -\var{task\_struct} e mette in esecuzione il gestore. +procedura viene effettuata dallo scheduler\index{scheduler} quando, +riprendendo l'esecuzione del processo in questione, verifica la presenza del +segnale nella \var{task\_struct} e mette in esecuzione il gestore. In questa semantica un processo ha la possibilità di bloccare la consegna dei segnali, in questo caso, se l'azione per il suddetto segnale non è quella di @@ -211,11 +211,12 @@ verr ignorarlo). Normalmente l'invio al processo che deve ricevere il segnale è immediato ed -avviene non appena questo viene rimesso in esecuzione dallo scheduler che -esegue l'azione specificata. Questo a meno che il segnale in questione non sia -stato bloccato prima della notifica, nel qual caso l'invio non avviene ed il -segnale resta \textsl{pendente} indefinitamente. Quando lo si sblocca il -segnale \textsl{pendente} sarà subito notificato. +avviene non appena questo viene rimesso in esecuzione dallo +scheduler\index{scheduler} che esegue l'azione specificata. Questo a meno che +il segnale in questione non sia stato bloccato prima della notifica, nel qual +caso l'invio non avviene ed il segnale resta \textsl{pendente} +indefinitamente. Quando lo si sblocca il segnale \textsl{pendente} sarà subito +notificato. Si ricordi però che se l'azione specificata per un segnale è quella di essere ignorato questo sarà scartato immediatamente al momento della sua generazione, @@ -1347,11 +1348,11 @@ Chiaramente, anche se il tempo pu nanosecondo, la precisione di \func{nanosleep} è determinata dalla risoluzione temporale del timer di sistema. Perciò la funzione attenderà comunque il tempo specificato, ma prima che il processo possa tornare ad essere eseguito -occorrerà almeno attendere il successivo giro di scheduler e cioè un tempo che -a seconda dei casi può arrivare fino a 1/\macro{HZ}, (sempre che il sistema -sia scarico ed il processa venga immediatamente rimesso in esecuzione); per -questo motivo il valore restituito in \param{rem} è sempre arrotondato al -multiplo successivo di 1/\macro{HZ}. +occorrerà almeno attendere il successivo giro di scheduler\index{scheduler} e +cioè un tempo che a seconda dei casi può arrivare fino a 1/\macro{HZ}, (sempre +che il sistema sia scarico ed il processa venga immediatamente rimesso in +esecuzione); per questo motivo il valore restituito in \param{rem} è sempre +arrotondato al multiplo successivo di 1/\macro{HZ}. In realtà è possibile ottenere anche pause più precise del centesimo di secondo usando politiche di scheduling real time come \macro{SCHED\_FIFO} o @@ -1983,25 +1984,24 @@ inline SigFunc * Signal(int signo, SigFunc *func) Per questo motivo si è provveduto, per mantenere un'interfaccia semplificata che abbia le stesse caratteristiche di \func{signal}, a definire una funzione equivalente attraverso \func{sigaction}; la funzione è \code{Signal}, e si -trova definita come \code{inline} nel file \file{wrapper.h} (nei sorgenti -allegati), riportata in \figref{fig:sig_Signal_code}. La riutilizzeremo spesso -in seguito. +trova definita nel file \file{SigHand.c} (nei sorgenti allegati), e riportata +in \figref{fig:sig_Signal_code}. La riutilizzeremo spesso in seguito. \subsection{La gestione della \textsl{maschera dei segnali} o \textit{signal mask}} \label{sec:sig_sigmask} Come spiegato in \secref{sec:sig_semantics} tutti i moderni sistemi unix-like -permettono si bloccare temporaneamente (o di eliminare completamente, impostando -\macro{SIG\_IGN} come azione) la consegna dei segnali ad un processo. Questo è -fatto specificando la cosiddetta \textsl{maschera dei segnali} (o -\textit{signal mask}) del processo\footnote{nel caso di Linux essa è mantenuta - dal campo \var{blocked} della \var{task\_struct} del processo.} cioè -l'insieme dei segnali la cui consegna è bloccata. Abbiamo accennato in -\secref{sec:proc_fork} che la \textit{signal mask} viene ereditata dal padre -alla creazione di un processo figlio, e abbiamo visto al paragrafo precedente -che essa può essere modificata, durante l'esecuzione di un gestore, -attraverso l'uso dal campo \var{sa\_mask} di \var{sigaction}. +permettono si bloccare temporaneamente (o di eliminare completamente, +impostando \macro{SIG\_IGN} come azione) la consegna dei segnali ad un +processo. Questo è fatto specificando la cosiddetta \textsl{maschera dei + segnali} (o \textit{signal mask}) del processo\footnote{nel caso di Linux + essa è mantenuta dal campo \var{blocked} della \var{task\_struct} del + processo.} cioè l'insieme dei segnali la cui consegna è bloccata. Abbiamo +accennato in \secref{sec:proc_fork} che la \textit{signal mask} viene +ereditata dal padre alla creazione di un processo figlio, e abbiamo visto al +paragrafo precedente che essa può essere modificata, durante l'esecuzione di +un gestore, attraverso l'uso dal campo \var{sa\_mask} di \var{sigaction}. Uno dei problemi evidenziatisi con l'esempio di \secref{fig:sig_event_wrong} è che in molti casi è necessario proteggere delle sezioni di codice (nel caso in