Riordinamento completo degli indici. Create della macro ad hoc per la
[gapil.git] / session.tex
1 %% session.tex
2 %%
3 %% Copyright (C) 2000-2005 Simone Piccardi.  Permission is granted to
4 %% copy, distribute and/or modify this document under the terms of the GNU Free
5 %% Documentation License, Version 1.1 or any later version published by the
6 %% Free Software Foundation; with the Invariant Sections being "Un preambolo",
7 %% with no Front-Cover Texts, and with no Back-Cover Texts.  A copy of the
8 %% license is included in the section entitled "GNU Free Documentation
9 %% License".
10 %%
11 \chapter{Terminali e sessioni di lavoro}
12 \label{cha:session}
13
14 I terminali per lungo tempo sono stati l'unico modo per accedere al sistema,
15 per questo anche oggi che esistono molte altre interfacce, essi continuano a
16 coprire un ruolo particolare, restando strettamente legati al funzionamento
17 dell'interfaccia a linea di comando.
18
19 Nella prima parte del capitolo esamineremo i concetti base del sistema delle
20 sessioni di lavoro, vale a dire il metodo con cui il kernel permette ad un
21 utente di gestire le capacità multitasking del sistema, permettendo di
22 eseguire più programmi in contemporanea.  Nella seconda parte del capitolo
23 tratteremo poi il funzionamento dell'I/O su terminale, e delle varie
24 peculiarità che esso viene ad assumere a causa del suo stretto legame con il
25 suo uso come interfaccia di accesso al sistema da parte degli utenti.
26
27
28 \section{Il \textit{job control}}
29 \label{sec:sess_job_control}
30
31 Viene comunemente chiamato \textit{job control} quell'insieme di funzionalità
32 il cui scopo è quello di permettere ad un utente di poter sfruttare le
33 capacità multitasking di un sistema Unix per eseguire in contemporanea più
34 processi, pur potendo accedere, di solito, ad un solo terminale,\footnote{con
35   X e con i terminali virtuali tutto questo non è più vero, dato che si può
36   accedere a molti terminali in contemporanea da una singola postazione di
37   lavoro, ma il sistema è nato prima dell'esistenza di tutto ciò.} avendo cioè
38 un solo punto in cui si può avere accesso all'input ed all'output degli
39 stessi.
40
41
42 \subsection{Una panoramica introduttiva}
43 \label{sec:sess_job_control_overview}
44
45 Il \textit{job control} è una caratteristica opzionale, introdotta in BSD
46 negli anni '80, e successivamente standardizzata da POSIX.1; la sua
47 disponibilità nel sistema è verificabile attraverso il controllo della macro
48 \macro{\_POSIX\_JOB\_CONTROL}. In generale il \textit{job control} richiede il
49 supporto sia da parte della shell (quasi tutte ormai lo fanno), che da parte
50 del kernel; in particolare il kernel deve assicurare sia la presenza di un
51 driver per i terminali abilitato al \textit{job control} che quella dei
52 relativi segnali illustrati in sez.~\ref{sec:sig_job_control}. 
53
54 In un sistema che supporta il \textit{job control}, una volta completato il
55 login, l'utente avrà a disposizione una shell dalla quale eseguire i comandi e
56 potrà iniziare quella che viene chiamata una \textsl{sessione}, che riunisce
57 (vedi sez.~\ref{sec:sess_proc_group}) tutti i processi eseguiti all'interno
58 dello stesso login (esamineremo tutto il processo in dettaglio in
59 sez.~\ref{sec:sess_login}).
60
61 Siccome la shell è collegata ad un solo terminale, che viene usualmente
62 chiamato \textsl{terminale di controllo}, (vedi sez.~\ref{sec:sess_ctrl_term})
63 un solo comando alla volta (quello che viene detto in \textit{foreground} o in
64 \textsl{primo piano}), potrà scrivere e leggere dal terminale. La shell però
65 può eseguire, aggiungendo una \cmd{\&} alla fine del comando, più programmi in
66 contemporanea, mandandoli in \textit{background} (o \textsl{sullo sfondo}),
67 nel qual caso essi saranno eseguiti senza essere collegati al terminale.
68
69 Si noti come si sia parlato di comandi e non di programmi o processi; fra le
70 funzionalità della shell infatti c'è anche quella di consentire di concatenare
71 più programmi in una sola riga di comando con le pipe, ed in tal caso verranno
72 eseguiti più programmi, inoltre, anche quando si invoca un singolo programma,
73 questo potrà sempre lanciare sottoprocessi per eseguire dei compiti specifici.
74
75 Per questo l'esecuzione di un comando può originare più di un processo; quindi
76 nella gestione del job control non si può far riferimento ai singoli processi.
77 Per questo il kernel prevede la possibilità di raggruppare più processi in un
78 \textit{process group} (detto anche \textsl{raggruppamento di processi}, vedi
79 sez.~\ref{sec:sess_proc_group}) e la shell farà sì che tutti i processi che
80 originano da una riga di comando appartengano allo stesso raggruppamento, in
81 modo che le varie funzioni di controllo, ed i segnali inviati dal terminale,
82 possano fare riferimento ad esso.
83
84 In generale allora all'interno di una sessione avremo un eventuale (può non
85 esserci) \textit{process group} in \textit{foreground}, che riunisce i
86 processi che possono accedere al terminale, e più \textit{process group} in
87 \textit{background}, che non possono accedervi. Il job control prevede che
88 quando un processo appartenente ad un raggruppamento in \textit{background}
89 cerca di accedere al terminale, venga inviato un segnale a tutti i processi
90 del raggruppamento, in modo da bloccarli (vedi sez.~\ref{sec:sess_ctrl_term}).
91
92 Un comportamento analogo si ha anche per i segnali generati dai comandi di
93 tastiera inviati dal terminale che vengono inviati a tutti i processi del
94 raggruppamento in \textit{foreground}. In particolare \cmd{C-z} interrompe
95 l'esecuzione del comando, che può poi essere mandato in \textit{background}
96 con il comando \cmd{bg}.\footnote{si tenga presente che \cmd{bg} e \cmd{fg}
97   sono parole chiave che indicano comandi interni alla shell, e nel caso non
98   comportano l'esecuzione di un programma esterno.} Il comando \cmd{fg}
99 consente invece di mettere in \textit{foreground} un comando precedentemente
100 lanciato in \textit{background}.
101
102 Di norma la shell si cura anche di notificare all'utente (di solito prima
103 della stampa a video del prompt) lo stato dei vari processi; essa infatti sarà
104 in grado, grazie all'uso di \func{waitpid}, di rilevare sia i processi che
105 sono terminati, sia i raggruppamenti che sono bloccati (in questo caso usando
106 l'opzione \const{WUNTRACED}, secondo quanto illustrato in
107 sez.~\ref{sec:proc_wait}).
108
109
110 \subsection{I \textit{process group} e le \textsl{sessioni}}
111 \label{sec:sess_proc_group}
112
113 Come accennato in sez.~\ref{sec:sess_job_control_overview} nel job control i
114 processi vengono raggruppati in \textit{process group} e \textit{sessioni};
115 per far questo vengono utilizzati due ulteriori identificatori (oltre quelli
116 visti in sez.~\ref{sec:proc_pid}) che il kernel associa a ciascun
117 processo:\footnote{in Linux questi identificatori sono mantenuti nei campi
118   \var{pgrp} e \var{session} della struttura \struct{task\_struct} definita in
119   \file{sched.h}.}  l'identificatore del \textit{process group} e
120 l'identificatore della \textsl{sessione}, che vengono indicati rispettivamente
121 con le sigle \acr{pgid} e \acr{sid}, e sono mantenuti in variabili di tipo
122 \type{pid\_t}. I valori di questi identificatori possono essere visualizzati
123 dal comando \cmd{ps} usando l'opzione \cmd{-j}.
124
125 Un \textit{process group} è pertanto definito da tutti i processi che hanno lo
126 stesso \acr{pgid}; è possibile leggere il valore di questo identificatore con
127 le funzioni \funcd{getpgid} e \funcd{getpgrp},\footnote{\func{getpgrp} è
128   definita nello standard POSIX.1, mentre \func{getpgid} è richiesta da SVr4.}
129 i cui prototipi sono:
130 \begin{functions}
131   \headdecl{unistd.h}
132
133   \funcdecl{pid\_t getpgid(pid\_t pid)} 
134   Legge il \acr{pgid} del processo \param{pid}.
135
136   \funcdecl{pid\_t getpgrp(void)}
137   Legge il \acr{pgid} del processo corrente.
138   
139   \bodydesc{Le funzioni restituiscono il \acr{pgid} del processo,
140     \func{getpgrp} ha sempre successo, mentre \func{getpgid} restituisce -1
141     ponendo \var{errno} a \errval{ESRCH} se il processo selezionato non
142     esiste.}
143 \end{functions}
144
145 La funzione \func{getpgid} permette di specificare il \acr{pid} del processo
146 di cui si vuole sapere il \acr{pgid}; un valore nullo per \param{pid}
147 restituisce il \acr{pgid} del processo corrente; \func{getpgrp} è di norma
148 equivalente a \code{getpgid(0)}.
149
150 In maniera analoga l'identificatore della sessione può essere letto dalla
151 funzione \funcd{getsid}, che però nelle \acr{glibc}\footnote{la system call è
152   stata introdotta in Linux a partire dalla versione 1.3.44, il supporto nelle
153   librerie del C è iniziato dalla versione 5.2.19. La funzione non è prevista
154   da POSIX.1, che parla solo di processi leader di sessione, e non di
155   identificatori di sessione.} è accessibile solo definendo
156 \macro{\_XOPEN\_SOURCE} e \macro{\_XOPEN\_SOURCE\_EXTENDED}; il suo prototipo
157 è:
158 \begin{prototype}{unistd.h}{pid\_t getsid(pid\_t pid)}
159   Legge l'identificatore di sessione del processo \param{pid}.
160   
161   \bodydesc{La funzione restituisce l'identificatore (un numero positivo) in
162   caso di successo, e -1 in caso di errore, nel qual caso \var{errno} assumerà
163   i valori:
164     \begin{errlist}
165     \item[\errcode{ESRCH}] Il processo selezionato non esiste.
166     \item[\errcode{EPERM}] In alcune implementazioni viene restituito quando il
167       processo selezionato non fa parte della stessa sessione del processo
168       corrente.
169     \end{errlist}
170   }
171 \end{prototype}
172
173 Entrambi gli identificatori vengono inizializzati alla creazione di ciascun
174 processo con lo stesso valore che hanno nel processo padre, per cui un
175 processo appena creato appartiene sempre allo stesso raggruppamento e alla
176 stessa sessione del padre. Vedremo poi come sia possibile creare più
177 \textit{process group} all'interno della stessa sessione, e spostare i
178 processi dall'uno all'altro, ma sempre all'interno di una stessa sessione.
179
180 Ciascun raggruppamento di processi ha sempre un processo principale, il
181 cosiddetto \textit{process group leader}, che è identificato dall'avere un
182 \acr{pgid} uguale al suo \acr{pid}, in genere questo è il primo processo del
183 raggruppamento, che si incarica di lanciare tutti gli altri. Un nuovo
184 raggruppamento si crea con la funzione \funcd{setpgrp},\footnote{questa è la
185   definizione di POSIX.1, BSD definisce una funzione con lo stesso nome, che
186   però è identica a \func{setpgid}; nelle \acr{glibc} viene sempre usata
187   sempre questa definizione, a meno di non richiedere esplicitamente la
188   compatibilità all'indietro con BSD, definendo la macro
189   \macro{\_BSD\_SOURCE}.} il cui prototipo è:
190 \begin{prototype}{unistd.h}{int setpgrp(void)}
191   Modifica il \acr{pgid} al valore del \acr{pid} del processo corrente.
192   
193   \bodydesc{La funzione restituisce il valore del nuovo \textit{process
194       group}.}
195 \end{prototype}
196
197 La funzione, assegnando al \acr{pgid} il valore del \acr{pid} processo
198 corrente, rende questo \textit{group leader} di un nuovo raggruppamento, tutti
199 i successivi processi da esso creati apparterranno (a meno di non cambiare di
200 nuovo il \acr{pgid}) al nuovo raggruppamento. È possibile invece spostare un
201 processo da un raggruppamento ad un altro con la funzione \funcd{setpgid}, il
202 cui prototipo è:
203 \begin{prototype}{unistd.h}{int setpgid(pid\_t pid, pid\_t pgid)}
204   Assegna al \acr{pgid} del processo \param{pid} il valore \param{pgid}.
205   
206   \bodydesc{La funzione ritorna il valore del nuovo \textit{process group}, e
207   -1 in caso di errore, nel qual caso \var{errno} assumerà i valori:
208     \begin{errlist}
209     \item[\errcode{ESRCH}] Il processo selezionato non esiste.
210     \item[\errcode{EPERM}] Il cambiamento non è consentito.
211     \item[\errcode{EACCES}] Il processo ha già eseguito una \func{exec}.
212     \item[\errcode{EINVAL}] Il valore di \param{pgid} è negativo.
213     \end{errlist}
214  }
215 \end{prototype}
216
217 La funzione permette di cambiare il \acr{pgid} del processo \param{pid}, ma il
218 cambiamento può essere effettuato solo se \param{pgid} indica un
219 \textit{process group} che è nella stessa sessione del processo chiamante.
220 Inoltre la funzione può essere usata soltanto sul processo corrente o su uno
221 dei suoi figli, ed in quest'ultimo caso ha successo soltanto se questo non ha
222 ancora eseguito una \func{exec}.\footnote{questa caratteristica è implementata
223   dal kernel che mantiene allo scopo un altro campo, \var{did\_exec}, in
224   \struct{task\_struct}.}  Specificando un valore nullo per \param{pid} si
225 indica il processo corrente, mentre specificando un valore nullo per
226 \param{pgid} si imposta il \textit{process group} al valore del \acr{pid} del
227 processo selezionato; pertanto \func{setpgrp} è equivalente a \code{setpgid(0,
228   0)}.
229
230 Di norma questa funzione viene usata dalla shell quando si usano delle
231 pipeline, per mettere nello stesso process group tutti i programmi lanciati su
232 ogni linea di comando; essa viene chiamata dopo una \func{fork} sia dal
233 processo padre, per impostare il valore nel figlio, che da quest'ultimo, per
234 sé stesso, in modo che il cambiamento di \textit{process group} sia immediato
235 per entrambi; una delle due chiamate sarà ridondante, ma non potendo
236 determinare quale dei due processi viene eseguito per primo, occorre eseguirle
237 comunque entrambe per evitare di esporsi ad una \textit{race
238   condition}\itindex{race~condition}.
239
240 Si noti come nessuna delle funzioni esaminate finora permetta di spostare un
241 processo da una sessione ad un altra; infatti l'unico modo di far cambiare
242 sessione ad un processo è quello di crearne una nuova con l'uso di
243 \funcd{setsid}; il suo prototipo è:
244 \begin{prototype}{unistd.h}{pid\_t setsid(void)}
245   Crea una nuova sessione sul processo corrente impostandone \acr{sid} e
246   \acr{pgid}.
247   
248   \bodydesc{La funzione ritorna il valore del nuovo \acr{sid}, e -1 in caso di
249     errore, il solo errore possibile è \errval{EPERM}, che si ha quando il
250     \acr{pgid} e \acr{pid} del processo coincidono.}
251 \end{prototype}
252
253 La funzione imposta il \acr{pgid} ed il \acr{sid} del processo corrente al
254 valore del suo \acr{pid}, creando così una nuova sessione ed un nuovo
255 \textit{process group} di cui esso diventa leader (come per i \textit{process
256   group} un processo si dice leader di sessione\footnote{in Linux la proprietà
257   è mantenuta in maniera indipendente con un apposito campo \var{leader} in
258   \struct{task\_struct}.} se il suo \acr{sid} è uguale al suo \acr{pid}) ed
259 unico componente.  Inoltre la funzione distacca il processo da ogni terminale
260 di controllo (torneremo sull'argomento in sez.~\ref{sec:sess_ctrl_term}) cui
261 fosse in precedenza associato.
262
263 La funzione ha successo soltanto se il processo non è già leader di un
264 \textit{process group}, per cui per usarla di norma si esegue una \func{fork}
265 e si esce, per poi chiamare \func{setsid} nel processo figlio, in modo che,
266 avendo questo lo stesso \acr{pgid} del padre ma un \acr{pid} diverso, non ci
267 siano possibilità di errore.\footnote{potrebbe sorgere il dubbio che, per il
268   riutilizzo dei valori dei \acr{pid} fatto nella creazione dei nuovi processi
269   (vedi sez.~\ref{sec:proc_pid}), il figlio venga ad assumere un valore
270   corrispondente ad un process group esistente; questo viene evitato dal
271   kernel che considera come disponibili per un nuovo \acr{pid} solo valori che
272   non corrispondono ad altri \acr{pid}, \acr{pgid} o \acr{sid} in uso nel
273   sistema.} Questa funzione viene usata di solito nel processo di login (per i
274 dettagli vedi sez.~\ref{sec:sess_login}) per raggruppare in una sessione tutti
275 i comandi eseguiti da un utente dalla sua shell.
276
277
278
279 \subsection{Il terminale di controllo e il controllo di sessione}
280 \label{sec:sess_ctrl_term}
281
282 Come accennato in sez.~\ref{sec:sess_job_control_overview}, nel sistema del
283 \textit{job control} i processi all'interno di una sessione fanno riferimento
284 ad un terminale di controllo (ad esempio quello su cui si è effettuato il
285 login), sul quale effettuano le operazioni di lettura e
286 scrittura,\footnote{nel caso di login grafico la cosa può essere più
287   complessa, e di norma l'I/O è effettuato tramite il server X, ma ad esempio
288   per i programmi, anche grafici, lanciati da un qualunque emulatore di
289   terminale, sarà quest'ultimo a fare da terminale (virtuale) di controllo.} e
290 dal quale ricevono gli eventuali segnali da tastiera.
291
292 A tale scopo lo standard POSIX.1 prevede che ad ogni sessione possa essere
293 associato un terminale di controllo; in Linux questo viene realizzato
294 mantenendo fra gli attributi di ciascun processo anche qual'è il suo terminale
295 di controllo.\footnote{Lo standard POSIX.1 non specifica nulla riguardo
296   l'implementazione; in Linux anch'esso viene mantenuto nella solita struttura
297   \struct{task\_struct}, nel campo \var{tty}.}  In generale ogni processo
298 eredita dal padre, insieme al \acr{pgid} e al \acr{sid} anche il terminale di
299 controllo (vedi sez.~\ref{sec:proc_fork}). In questo modo tutti processi
300 originati dallo stesso leader di sessione mantengono lo stesso terminale di
301 controllo.
302
303 Alla creazione di una nuova sessione con \func{setsid} ogni associazione con
304 il precedente terminale di controllo viene cancellata, ed il processo che è
305 divenuto un nuovo leader di sessione dovrà riottenere\footnote{solo quando ciò
306   è necessario, cosa che, come vedremo in sez.~\ref{sec:sess_daemon}, non è
307   sempre vera.}, un terminale di controllo. In generale questo viene fatto
308 automaticamente dal sistema\footnote{a meno di non avere richiesto
309   esplicitamente che questo non diventi un terminale di controllo con il flag
310   \const{O\_NOCTTY} (vedi sez.~\ref{sec:file_open}). In questo Linux segue la
311   semantica di SVr4; BSD invece richiede che il terminale venga allocato
312   esplicitamente con una \func{ioctl} con il comando \const{TIOCSCTTY}.}
313 quando viene aperto il primo terminale (cioè uno dei vari file di dispositivo
314 \file{/dev/tty*}) che diventa automaticamente il terminale di controllo,
315 mentre il processo diventa il \textsl{processo di controllo} di quella
316 sessione.
317
318 In genere (a meno di redirezioni) nelle sessioni di lavoro questo terminale è
319 associato ai file standard (di input, output ed error) dei processi nella
320 sessione, ma solo quelli che fanno parte del cosiddetto raggruppamento di
321 \textit{foreground}, possono leggere e scrivere in certo istante. Per
322 impostare il raggruppamento di \textit{foreground} di un terminale si usa la
323 funzione \funcd{tcsetpgrp}, il cui prototipo è:
324 \begin{functions}
325   \headdecl{unistd.h}
326   \headdecl{termios.h}
327   
328   \funcdecl{int tcsetpgrp(int fd, pid\_t pgrpid)} Imposta a \param{pgrpid} il
329   \textit{process group} di \textit{foreground} del terminale associato al
330   file descriptor \param{fd}.
331    
332   \bodydesc{La funzione restituisce 0 in caso di successo, e -1 in caso di
333     errore, nel qual caso \var{errno} assumerà i valori:
334     \begin{errlist}
335     \item[\errcode{ENOTTY}] Il file \param{fd} non corrisponde al terminale di
336       controllo del processo chiamante.
337     \item[\errcode{ENOSYS}] Il sistema non supporta il job control.
338     \item[\errcode{EPERM}] Il \textit{process group} specificato non è nella
339     stessa sessione del processo chiamante.
340     \end{errlist}
341     ed inoltre \errval{EBADF} ed \errval{EINVAL}. 
342   }
343 \end{functions}
344 \noindent la funzione può essere eseguita con successo solo da
345 un processo nella stessa sessione e con lo stesso terminale di controllo. 
346
347 Come accennato in sez.~\ref{sec:sess_job_control_overview}, tutti i processi (e
348 relativi raggruppamenti) che non fanno parte del gruppo di \textit{foreground}
349 sono detti in \textit{background}; se uno si essi cerca di accedere al
350 terminale di controllo provocherà l'invio da parte del kernel di uno dei due
351 segnali \const{SIGTTIN} o \const{SIGTTOU} (a seconda che l'accesso sia stato
352 in lettura o scrittura) a tutto il suo \textit{process group}; dato che il
353 comportamento di default di questi segnali (si riveda quanto esposto in
354 sez.~\ref{sec:sig_job_control}) è di fermare il processo, di norma questo
355 comporta che tutti i membri del gruppo verranno fermati, ma non si avranno
356 condizioni di errore.\footnote{la shell in genere notifica comunque un
357   avvertimento, avvertendo la presenza di processi bloccati grazie all'uso di
358   \func{waitpid}.} Se però si bloccano o ignorano i due segnali citati, le
359 funzioni di lettura e scrittura falliranno con un errore di \errcode{EIO}.
360
361 Un processo può controllare qual è il gruppo di \textit{foreground} associato
362 ad un terminale con la funzione \funcd{tcgetpgrp}, il cui prototipo è:
363 \begin{functions}
364   \headdecl{unistd.h} \headdecl{termios.h}
365   
366   \funcdecl{pid\_t tcgetpgrp(int fd)} Legge il \textit{process group} di
367   \textit{foreground} del terminale associato al file descriptor \param{fd}.
368   \bodydesc{La funzione restituisce in caso di successo il \acr{pgid} del
369     gruppo di \textit{foreground}, e -1 in caso di errore, nel qual caso
370     \var{errno} assumerà i valori:
371     \begin{errlist}
372     \item[\errcode{ENOTTY}] Non c'è un terminale di controllo o \param{fd} non
373       corrisponde al terminale di controllo del processo chiamante.
374     \end{errlist}
375     ed inoltre \errval{EBADF} ed \errval{ENOSYS}. 
376   }
377 \end{functions}
378
379 Si noti come entrambe le funzioni usino come argomento il valore di un file
380 descriptor, il risultato comunque non dipende dal file descriptor che si usa
381 ma solo dal terminale cui fa riferimento; il kernel inoltre permette a ciascun
382 processo di accedere direttamente al suo terminale di controllo attraverso il
383 file speciale \file{/dev/tty}, che per ogni processo è un sinonimo per il
384 proprio terminale di controllo.  Questo consente anche a processi che possono
385 aver rediretto l'output di accedere al terminale di controllo, pur non
386 disponendo più del file descriptor originario; un caso tipico è il programma
387 \cmd{crypt} che accetta la redirezione sullo standard input di un file da
388 decifrare, ma deve poi leggere la password dal terminale.
389
390 Un'altra caratteristica del terminale di controllo usata nel job control è che
391 utilizzando su di esso le combinazioni di tasti speciali (\cmd{C-z},
392 \cmd{C-c}, \cmd{C-y} e \verb|C-\|) si farà sì che il kernel invii i
393 corrispondenti segnali (rispettivamente \const{SIGTSTP}, \const{SIGINT},
394 \const{SIGQUIT} e \const{SIGTERM}, trattati in sez.~\ref{sec:sig_job_control})
395 a tutti i processi del raggruppamento di \textit{foreground}; in questo modo
396 la shell può gestire il blocco e l'interruzione dei vari comandi.
397
398 % \|
399
400 Per completare la trattazione delle caratteristiche del job control legate al
401 terminale di controllo, occorre prendere in considerazione i vari casi legati
402 alla terminazione anomala dei processi, che sono di norma gestite attraverso
403 il segnale \const{SIGHUP}. Il nome del segnale deriva da \textit{hungup},
404 termine che viene usato per indicare la condizione in cui il terminale diventa
405 inutilizzabile, (letteralmente sarebbe \textsl{impiccagione}).
406
407 Quando si verifica questa condizione, ad esempio se si interrompe la linea, o
408 va giù la rete o più semplicemente si chiude forzatamente la finestra di
409 terminale su cui si stava lavorando, il kernel provvederà ad inviare il
410 segnale di \const{SIGHUP} al processo di controllo. L'azione preimpostata in
411 questo caso è la terminazione del processo, il problema che si pone è cosa
412 accade agli altri processi nella sessione, che non han più un processo di
413 controllo che possa gestire l'accesso al terminale, che potrebbe essere
414 riutilizzato per qualche altra sessione.
415
416 Lo standard POSIX.1 prevede che quando il processo di controllo termina, che
417 ciò avvenga o meno per un \textit{hungup} del terminale (ad esempio si
418 potrebbe terminare direttamente la shell con \cmd{kill}) venga inviato un
419 segnale di \const{SIGHUP} ai processi del raggruppamento di foreground. In
420 questo modo essi potranno essere avvisati che non esiste più un processo in
421 grado di gestire il terminale (di norma tutto ciò comporta la terminazione
422 anche di questi ultimi).
423
424 Restano però gli eventuali processi in background, che non ricevono il
425 segnale; in effetti se il terminale non dovesse più servire essi potrebbero
426 proseguire fino al completamento della loro esecuzione; ma si pone il problema
427 di come gestire quelli che sono bloccati, o che si bloccano nell'accesso al
428 terminale, in assenza di un processo che sia in grado di effettuare il
429 controllo dello stesso.
430
431 Questa è la situazione in cui si ha quello che viene chiamato un
432 \textit{orphaned process group}. Lo standard POSIX.1 lo definisce come un
433 \textit{process group} i cui processi hanno come padri esclusivamente o altri
434 processi nel raggruppamento, o processi fuori della sessione.  Lo standard
435 prevede inoltre che se la terminazione di un processo fa sì che un
436 raggruppamento di processi diventi orfano e se i suoi membri sono bloccati, ad
437 essi vengano inviati in sequenza i segnali di \const{SIGHUP} e
438 \const{SIGCONT}.
439
440 La definizione può sembrare complicata, e a prima vista non è chiaro cosa
441 tutto ciò abbia a che fare con il problema della terminazione del processo di
442 controllo.  Consideriamo allora cosa avviene di norma nel \textit{job
443   control}: una sessione viene creata con \func{setsid} che crea anche un
444 nuovo process group: per definizione quest'ultimo è sempre \textsl{orfano},
445 dato che il padre del leader di sessione è fuori dalla stessa e il nuovo
446 process group contiene solo il leader di sessione. Questo è un caso limite, e
447 non viene emesso nessun segnale perché quanto previsto dallo standard riguarda
448 solo i raggruppamenti che diventano orfani in seguito alla terminazione di un
449 processo.\footnote{l'emissione dei segnali infatti avviene solo nella fase di
450   uscita del processo, come una delle operazioni legate all'esecuzione di
451   \func{\_exit}, secondo quanto illustrato in sez.~\ref{sec:proc_termination}.}
452
453 Il leader di sessione provvederà a creare nuovi raggruppamenti che a questo
454 punto non sono orfani in quanto esso resta padre per almeno uno dei processi
455 del gruppo (gli altri possono derivare dal primo). Alla terminazione del
456 leader di sessione però avremo che, come visto in
457 sez.~\ref{sec:proc_termination}, tutti i suoi figli vengono adottati da
458 \cmd{init}, che è fuori dalla sessione. Questo renderà orfani tutti i process
459 group creati direttamente dal leader di sessione (a meno di non aver spostato
460 con \func{setpgid} un processo da un gruppo ad un altro, cosa che di norma non
461 viene fatta) i quali riceveranno, nel caso siano bloccati, i due segnali;
462 \const{SIGCONT} ne farà proseguire l'esecuzione, ed essendo stato nel
463 frattempo inviato anche \const{SIGHUP}, se non c'è un gestore per
464 quest'ultimo, i processi bloccati verranno automaticamente terminati.
465
466
467
468 \subsection{Dal login alla shell}
469 \label{sec:sess_login}
470
471 L'organizzazione del sistema del job control è strettamente connessa alle
472 modalità con cui un utente accede al sistema per dare comandi, collegandosi ad
473 esso con un terminale, che sia questo realmente tale, come un VT100 collegato
474 ad una seriale o virtuale, come quelli associati a schermo e tastiera o ad una
475 connessione di rete. Dato che i concetti base sono gli stessi, e dato che alla
476 fine le differenze sono\footnote{in generale nel caso di login via rete o di
477   terminali lanciati dall'interfaccia grafica cambia anche il processo da cui
478   ha origine l'esecuzione della shell.} nel dispositivo cui il kernel associa
479 i file standard (vedi sez.~\ref{sec:file_std_descr}) per l'I/O, tratteremo
480 solo il caso classico del terminale.
481
482 Abbiamo già brevemente illustrato in sez.~\ref{sec:intro_kern_and_sys} le
483 modalità con cui il sistema si avvia, e di come, a partire da \cmd{init},
484 vengano lanciati tutti gli altri processi. Adesso vedremo in maniera più
485 dettagliata le modalità con cui il sistema arriva a fornire ad un utente la
486 shell che gli permette di lanciare i suoi comandi su un terminale.
487
488 Nella maggior parte delle distribuzioni di GNU/Linux\footnote{fa eccezione la
489   distribuzione \textit{Slackware}, come alcune distribuzioni su dischetto, ed
490   altre distribuzioni dedicate a compiti limitati e specifici.}  viene usata
491 la procedura di avvio di System V; questa prevede che \cmd{init} legga dal
492 file di configurazione \file{/etc/inittab} quali programmi devono essere
493 lanciati, ed in quali modalità, a seconda del cosiddetto \textit{run level},
494 anch'esso definito nello stesso file.
495
496 Tralasciando la descrizione del sistema dei run level, (per il quale si
497 rimanda alla lettura delle pagine di manuale di \cmd{init} e di
498 \file{inittab}) quello che comunque viene sempre fatto è di eseguire almeno
499 una istanza di un programma che permetta l'accesso ad un terminale. Uno schema
500 di massima della procedura è riportato in fig.~\ref{fig:sess_term_login}.
501
502 \begin{figure}[htb]
503   \centering
504   \includegraphics[width=15cm]{img/tty_login}
505   \caption{Schema della procedura di login su un terminale.}
506   \label{fig:sess_term_login}
507 \end{figure}
508
509 Un terminale, che esso sia un terminale effettivo, attaccato ad una seriale o
510 ad un altro tipo di porta di comunicazione, o una delle console virtuali
511 associate allo schermo, viene sempre visto attraverso un device driver che ne
512 presenta un'interfaccia comune su un apposito file di dispositivo.
513
514 Per controllare un terminale si usa di solito il programma \cmd{getty} (od una
515 delle sue varianti), che permette di mettersi in ascolto su uno di questi
516 dispositivi. Alla radice della catena che porta ad una shell per i comandi
517 perciò c'è sempre \cmd{init} che esegue prima una \func{fork} e poi una
518 \func{exec} per lanciare una istanza di questo programma su un terminale, il
519 tutto ripetuto per ciascuno dei terminali che si hanno a disposizione (o per
520 un certo numero di essi, nel caso delle console virtuali), secondo quanto
521 indicato dall'amministratore nel file di configurazione del programma,
522 \file{/etc/inittab}.
523
524 Quando viene lanciato da \cmd{init} il programma parte con i privilegi di
525 amministratore e con un ambiente vuoto; \cmd{getty} si cura di chiamare
526 \func{setsid} per creare una nuova sessione ed un nuovo process group, e di
527 aprire il terminale (che così diventa il terminale di controllo della
528 sessione) in lettura sullo standard input ed in scrittura sullo standard
529 output e sullo standard error; inoltre effettuerà, qualora servano, ulteriori
530 settaggi.\footnote{ad esempio, come qualcuno si sarà accorto scrivendo un nome
531   di login in maiuscolo, può effettuare la conversione automatica dell'input
532   in minuscolo, ponendosi in una modalità speciale che non distingue fra i due
533   tipi di caratteri (a beneficio di alcuni vecchi terminali che non
534   supportavano le minuscole).} Alla fine il programma stamperà un messaggio di
535 benvenuto per poi porsi in attesa dell'immissione del nome di un utente.
536
537 Una volta che si sia immesso il nome di login \cmd{getty} esegue direttamente
538 il programma \cmd{login} con una \func{exevle}, passando come argomento la
539 stringa con il nome, ed un ambiente opportunamente costruito che contenga
540 quanto necessario (ad esempio di solito viene opportunamente inizializzata la
541 variabile di ambiente \texttt{TERM}) ad identificare il terminale su cui si
542 sta operando, a beneficio dei programmi che verranno lanciati in seguito.
543
544 A sua volta \cmd{login}, che mantiene i privilegi di amministratore, usa il
545 nome dell'utente per effettuare una ricerca nel database degli
546 utenti,\footnote{in genere viene chiamata \func{getpwnam}, che abbiamo visto
547   in sez.~\ref{sec:sys_user_group}, per leggere la password e gli altri dati
548   dal database degli utenti.} e richiede una password. Se l'utente non esiste
549 o se la password non corrisponde\footnote{il confronto non viene effettuato
550   con un valore in chiaro; quanto immesso da terminale viene invece a sua
551   volta criptato, ed è il risultato che viene confrontato con il valore che
552   viene mantenuto nel database degli utenti.} la richiesta viene ripetuta un
553 certo numero di volte dopo di che \cmd{login} esce ed \cmd{init} provvede a
554 rilanciare un'altra istanza di \cmd{getty}.
555
556 Se invece la password corrisponde \cmd{login} esegue \func{chdir} per settare
557 la \textit{home directory} dell'utente, cambia i diritti di accesso al
558 terminale (con \func{chown} e \func{chmod}) per assegnarne la titolarità
559 all'utente ed al suo gruppo principale, assegnandogli al contempo i diritti di
560 lettura e scrittura. Inoltre il programma provvede a costruire gli opportuni
561 valori per le variabili di ambiente, come \texttt{HOME}, \texttt{SHELL}, ecc.
562 Infine attraverso l'uso di \func{setuid}, \func{setgid} e \func{initgroups}
563 verrà cambiata l'identità del proprietario del processo, infatti, come
564 spiegato in sez.~\ref{sec:proc_setuid}, avendo invocato tali funzioni con i
565 privilegi di amministratore, tutti gli user-ID ed i group-ID (reali, effettivi
566 e salvati) saranno settati a quelli dell'utente.
567
568 A questo punto \cmd{login} provvederà (fatte salve eventuali altre azioni
569 iniziali, come la stampa di messaggi di benvenuto o il controllo della posta)
570 ad eseguire con un'altra \func{exec} la shell, che si troverà con un ambiente
571 già pronto con i file standard di sez.~\ref{sec:file_std_descr} impostati sul
572 terminale, e pronta, nel ruolo di leader di sessione e di processo di
573 controllo per il terminale, a gestire l'esecuzione dei comandi come illustrato
574 in sez.~\ref{sec:sess_job_control_overview}. 
575
576 Dato che il processo padre resta sempre \cmd{init} quest'ultimo potrà
577 provvedere, ricevendo un \const{SIGCHLD} all'uscita della shell quando la
578 sessione di lavoro è terminata, a rilanciare \cmd{getty} sul terminale per
579 ripetere da capo tutto il procedimento. 
580
581
582
583 \subsection{Prescrizioni per un programma \textit{daemon}}
584 \label{sec:sess_daemon}
585
586 Come sottolineato fin da sez.~\ref{sec:intro_base_concept}, in un sistema
587 unix-like tutte le operazioni sono eseguite tramite processi, comprese quelle
588 operazioni di sistema (come l'esecuzione dei comandi periodici, o la consegna
589 della posta, ed in generale tutti i programmi di servizio) che non hanno
590 niente a che fare con la gestione diretta dei comandi dell'utente.
591
592 Questi programmi, che devono essere eseguiti in modalità non interattiva e
593 senza nessun intervento dell'utente, sono normalmente chiamati
594 \textsl{demoni}, (o \textit{daemons}), nome ispirato dagli omonimi spiritelli
595 che svolgevano compiti vari, di cui parlava Socrate (che sosteneva di averne
596 uno al suo servizio).\footnote{NdT. ricontrollare, i miei ricordi di filosofia
597   sono piuttosto datati.}
598
599 Se però si lancia un programma demone dalla riga di comando in un sistema che
600 supporta, come Linux, il \textit{job control} esso verrà comunque associato ad
601 un terminale di controllo e mantenuto all'interno di una sessione, e anche se
602 può essere mandato in background e non eseguire più nessun I/O su terminale,
603 si avranno comunque tutte le conseguenze che abbiamo appena visto in
604 sez.~\ref{sec:sess_ctrl_term} (in particolare l'invio dei segnali in
605 corrispondenza dell'uscita del leader di sessione).
606
607 Per questo motivo un programma che deve funzionare come demone deve sempre
608 prendere autonomamente i provvedimenti opportuni (come distaccarsi dal
609 terminale e dalla sessione) ad impedire eventuali interferenze da parte del
610 sistema del \textit{job control}; questi sono riassunti in una lista di
611 prescrizioni\footnote{ad esempio sia Stevens in \cite{APUE}, che la
612   \textit{Unix Programming FAQ} \cite{UnixFAQ} ne riportano di sostanzialmente
613   identiche.} da seguire quando si scrive un demone.
614
615 Pertanto, quando si lancia un programma che deve essere eseguito come demone
616 occorrerà predisporlo in modo che esso compia le seguenti azioni:
617 \begin{enumerate}
618 \item Eseguire una \func{fork} e terminare immediatamente il processo padre
619   proseguendo l'esecuzione nel figlio.  In questo modo si ha la certezza che
620   il figlio non è un \textit{process group leader}, (avrà il \acr{pgid} del
621   padre, ma un \acr{pid} diverso) e si può chiamare \func{setsid} con
622   successo. Inoltre la shell considererà terminato il comando all'uscita del
623   padre.
624 \item Eseguire \func{setsid} per creare una nuova sessione ed un nuovo
625   raggruppamento di cui il processo diventa automaticamente il leader, che
626   però non ha associato nessun terminale di controllo.
627 \item Assicurarsi che al processo non venga associato in seguito nessun nuovo
628   terminale di controllo; questo può essere fatto sia avendo cura di usare
629   sempre l'opzione \const{O\_NOCTTY} nell'aprire i file di terminale, che
630   eseguendo una ulteriore \func{fork} uscendo nel padre e proseguendo nel
631   figlio. In questo caso, non essendo più quest'ultimo un leader di sessione
632   non potrà ottenere automaticamente un terminale di controllo.
633 \item Eseguire una \func{chdir} per impostare la directory di lavoro del
634   processo (su \file{/} o su una directory che contenga dei file necessari per
635   il programma), per evitare che la directory da cui si è lanciato il processo
636   resti in uso e non sia possibile rimuoverla o smontare il filesystem che la
637   contiene.
638 \item Impostare la maschera dei permessi (di solito con \code{umask(0)}) in
639   modo da non essere dipendenti dal valore ereditato da chi ha lanciato
640   originariamente il processo. 
641 \item Chiudere tutti i file aperti che non servono più (in generale tutti); in
642   particolare vanno chiusi i file standard che di norma sono ancora associati
643   al terminale (un'altra opzione è quella di redirigerli verso
644   \file{/dev/null}).
645 \end{enumerate}
646
647
648 In Linux buona parte di queste azioni possono venire eseguite invocando la
649 funzione \funcd{daemon}, introdotta per la prima volta in BSD4.4; il suo
650 prototipo è:
651 \begin{prototype}{unistd.h}{int daemon(int nochdir, int noclose)}
652   Esegue le operazioni che distaccano il processo dal terminale di controllo e
653   lo fanno girare come demone.
654   
655   \bodydesc{La funzione restituisce (nel nuovo processo) 0 in caso di
656     successo, e -1 in caso di errore, nel qual caso \var{errno} assumerà i
657     valori impostati dalle sottostanti \func{fork} e \func{setsid}.}
658 \end{prototype}
659
660 La funzione esegue una \func{fork}, per uscire subito, con \func{\_exit}, nel
661 padre, mentre l'esecuzione prosegue nel figlio che esegue subito una
662 \func{setsid}. In questo modo si compiono automaticamente i passi 1 e 2 della
663 precedente lista. Se \param{nochdir} è nullo la funzione imposta anche la
664 directory di lavoro su \file{/}, se \param{noclose} è nullo i file standard
665 vengono rediretti su \file{/dev/null} (corrispondenti ai passi 4 e 6); in caso
666 di valori non nulli non viene eseguita nessuna altra azione.
667
668 Dato che un programma demone non può più accedere al terminale, si pone il
669 problema di come fare per la notifica di eventuali errori, non potendosi più
670 utilizzare lo standard error; per il normale I/O infatti ciascun demone avrà
671 le sue modalità di interazione col sistema e gli utenti a seconda dei compiti
672 e delle funzionalità che sono previste; ma gli errori devono normalmente
673 essere notificati all'amministratore del sistema.
674
675 Una soluzione può essere quella di scrivere gli eventuali messaggi su uno
676 specifico file (cosa che a volte viene fatta comunque) ma questo comporta il
677 grande svantaggio che l'amministratore dovrà tenere sotto controllo un file
678 diverso per ciascun demone, e che possono anche generarsi conflitti di nomi.
679 Per questo in BSD4.2 venne introdotto un servizio di sistema, il
680 \textit{syslog}, che oggi si trova su tutti i sistemi Unix, e che permettesse
681 ai demoni di inviare messaggi all'amministratore in una maniera
682 standardizzata.
683
684 Il servizio prevede vari meccanismi di notifica, e, come ogni altro servizio
685 in un sistema unix-like, viene gestito attraverso un apposito programma,
686 \cmd{syslogd}, che è anch'esso un \textsl{demone}. In generale i messaggi di
687 errore vengono raccolti dal file speciale \file{/dev/log}, un
688 \textit{socket}\index{socket} locale (vedi sez.~\ref{sec:sock_sa_local})
689 dedicato a questo scopo, o via rete, con un \textit{socket} UDP, o da un
690 apposito demone, \cmd{klogd}, che estrae i messaggi del kernel.\footnote{i
691   messaggi del kernel sono tenuti in un buffer circolare e scritti tramite la
692   funzione \func{printk}, analoga alla \func{printf} usata in user space; una
693   trattazione eccellente dell'argomento si trova in \cite{LinDevDri}, nel
694   quarto capitolo.}
695
696 Il servizio permette poi di trattare i vari messaggi classificandoli
697 attraverso due indici; il primo, chiamato \textit{facility}, suddivide in
698 diverse categorie i vari demoni in modo di raggruppare i messaggi provenienti
699 da operazioni che hanno attinenza fra loro, ed è organizzato in sottosistemi
700 (kernel, posta elettronica, demoni di stampa, ecc.). Il secondo, chiamato
701 \textit{priority}, identifica l'importanza dei vari messaggi, e permette di
702 classificarli e differenziare le modalità di notifica degli stessi.
703
704 Il sistema di \textit{syslog} attraverso \cmd{syslogd} provvede poi a
705 riportare i messaggi all'amministratore attraverso una serie differenti
706 meccanismi come:
707 \begin{itemize*}
708 \item scrivere sulla console.
709 \item inviare via mail ad uno specifico utente.
710 \item scrivere su un file (comunemente detto \textit{log file}).
711 \item inviare ad un altro demone (anche via rete).
712 \item scartare.
713 \end{itemize*}
714 secondo le modalità che questo preferisce e che possono essere impostate
715 attraverso il file di configurazione \file{/etc/syslog.conf} (maggiori
716 dettagli si possono trovare sulle pagine di manuale per questo file e per
717 \cmd{syslogd}).
718
719 Le \acr{glibc} definiscono una serie di funzioni standard con cui un processo
720 può accedere in maniera generica al servizio di \textit{syslog}, che però
721 funzionano solo localmente; se si vogliono inviare i messaggi ad un'altro
722 sistema occorre farlo esplicitamente con un socket\index{socket} UDP, o
723 utilizzare le capacità di reinvio del servizio.
724
725 La prima funzione definita dall'interfaccia è \funcd{openlog}, che apre una
726 connessione al servizio di \textit{syslog}; essa in generale non è necessaria
727 per l'uso del servizio, ma permette di impostare alcuni valori che controllano
728 gli effetti delle chiamate successive; il suo prototipo è:
729 \begin{prototype}{syslog.h}{void openlog(const char *ident, int option, 
730 int facility)}
731
732 Apre una connessione al sistema di \textit{syslog}.
733   
734 \bodydesc{La funzione non restituisce nulla.}
735 \end{prototype}
736
737 La funzione permette di specificare, tramite \param{ident}, l'identità di chi
738 ha inviato il messaggio (di norma si passa il nome del programma, come
739 specificato da \code{argv[0]}); la stringa verrà preposta all'inizio di ogni
740 messaggio. Si tenga presente che il valore di \param{ident} che si passa alla
741 funzione è un puntatore, se la stringa cui punta viene cambiata lo sarà pure
742 nei successivi messaggi, e se viene cancellata i risultati potranno essere
743 impredicibili, per questo è sempre opportuno usare una stringa costante. 
744
745 L'argomento \param{facility} permette invece di preimpostare per le successive
746 chiamate l'omonimo indice che classifica la categoria del messaggio.
747 L'argomento è interpretato come una maschera binaria, e pertanto è possibile
748 inviare i messaggi su più categorie alla volta; i valori delle costanti che
749 identificano ciascuna categoria sono riportati in
750 tab.~\ref{tab:sess_syslog_facility}, il valore di \param{facility} deve essere
751 specificato con un OR aritmetico.
752
753 \begin{table}[htb]
754   \footnotesize
755   \centering
756   \begin{tabular}[c]{|l|p{8cm}|}
757     \hline
758     \textbf{Valore}& \textbf{Significato}\\
759     \hline
760     \hline
761     \const{LOG\_AUTH}     & Messaggi relativi ad autenticazione e sicurezza,
762                             obsoleto, è sostituito da \const{LOG\_AUTHPRIV}. \\
763     \const{LOG\_AUTHPRIV} & Sostituisce \const{LOG\_AUTH}.\\
764     \const{LOG\_CRON}     & Messaggi dei demoni di gestione dei comandi
765                             programmati (\cmd{cron} e \cmd{at}).\\
766     \const{LOG\_DAEMON}   & Demoni di sistema.\\
767     \const{LOG\_FTP}      & Server FTP.\\
768     \const{LOG\_KERN}     & Messaggi del kernel\\
769     \const{LOG\_LOCAL0}   & Riservato all'amministratore per uso locale\\
770     --- & \\
771     \const{LOG\_LOCAL7}   & Riservato all'amministratore per uso locale\\
772     \const{LOG\_LPR}      & Messaggi del sistema di gestione delle stampanti \\
773     \const{LOG\_MAIL}     & Messaggi del sistema di posta elettronica\\
774     \const{LOG\_NEWS}     & Messaggi del sistema di gestione delle news 
775                             (USENET) \\
776     \const{LOG\_SYSLOG}   & Messaggi generati dallo stesso \cmd{syslogd}\\
777     \const{LOG\_USER}     & Messaggi generici a livello utente\\
778     \const{LOG\_UUCP}     & Messaggi del sistema UUCP\\
779 \hline
780 \end{tabular}
781 \caption{Valori possibili per l'argomento \param{facility} di \func{openlog}.}
782 \label{tab:sess_syslog_facility}
783 \end{table}
784
785 L'argomento \param{option} serve invece per controllare il comportamento della
786 funzione \func{openlog} e delle modalità con cui le successive chiamate
787 scriveranno i messaggi, esso viene specificato come maschera binaria composta
788 con un OR aritmetico di una qualunque delle costanti riportate in
789 tab.~\ref{tab:sess_openlog_option}.
790
791 \begin{table}[htb]
792   \footnotesize
793 \centering
794 \begin{tabular}[c]{|l|p{8cm}|}
795 \hline
796 \textbf{Valore}& \textbf{Significato}\\
797 \hline
798 \hline
799 \const{LOG\_CONS}   & Scrive sulla console quando. \\
800 \const{LOG\_NDELAY} & Sostituisce \const{LOG\_AUTH}.\\
801 \const{LOG\_NOWAIT} & Messaggi dei demoni di gestione dei comandi
802                       programmati (\cmd{cron} e \cmd{at}).\\
803 \const{LOG\_ODELAY} & .\\
804 \const{LOG\_PERROR} & Stampa anche su \file{stderr}.\\
805 \const{LOG\_PID}    & Inserisce nei messaggi il \acr{pid} del processo
806                       chiamante. \\
807 \hline
808 \end{tabular}
809 \caption{Valori possibili per l'argomento \param{option} di \func{openlog}.}
810 \label{tab:sess_openlog_option}
811 \end{table}
812
813 La funzione che si usa per generare un messaggio è \funcd{syslog}, dato che
814 l'uso di \func{openlog} è opzionale, sarà quest'ultima a provvede a chiamare la
815 prima qualora ciò non sia stato fatto (nel qual caso il valore di
816 \param{ident} è nullo). Il suo prototipo è:
817 \begin{prototype}{syslog.h}
818 {void syslog(int priority, const char *format, ...)}
819
820 Genera un messaggio di priorità \param{priority}.
821
822 \bodydesc{La funzione non restituisce nulla.}
823 \end{prototype}
824
825 Il comportamento della funzione è analogo quello di \func{printf}, e il valore
826 dell'argomento \param{format} è identico a quello descritto nella pagina di
827 manuale di quest'ultima (per i valori principali si può vedere la trattazione
828 sommaria che se ne è fatto in sez.~\ref{sec:file_formatted_io}); l'unica
829 differenza è che la sequenza \val{\%m} viene rimpiazzata dalla stringa
830 restituita da \code{strerror(errno)}. Gli argomenti seguenti i primi due
831 devono essere forniti secondo quanto richiesto da \param{format}.
832
833 L'argomento \param{priority} permette di impostare sia la \textit{facility}
834 che la \textit{priority} del messaggio. In realtà viene prevalentemente usato
835 per specificare solo quest'ultima in quanto la prima viene di norma
836 preimpostata con \func{openlog}. La priorità è indicata con un valore
837 numerico\footnote{le \acr{glibc}, seguendo POSIX.1-2001, prevedono otto
838   diverse priorità ordinate da 0 a 7, in ordine di importanza decrescente;
839   questo comporta che i tre bit meno significativi dell'argomento
840   \param{priority} sono occupati da questo valore, mentre i restanti bit più
841   significativi vengono usati per specificare la \textit{facility}.}
842 specificabile attraverso le costanti riportate in
843 tab.~\ref{tab:sess_syslog_priority}.  Nel caso si voglia specificare anche la
844 \textit{facility} basta eseguire un OR aritmetico del valore della priorità
845 con la maschera binaria delle costanti di tab.~\ref{tab:sess_syslog_facility}.
846
847 \begin{table}[htb]
848   \footnotesize
849   \centering
850   \begin{tabular}[c]{|l|p{8cm}|}
851     \hline
852     \textbf{Valore}& \textbf{Significato}\\
853     \hline
854     \hline
855     \const{LOG\_EMERG}   & Il sistema è inutilizzabile. \\
856     \const{LOG\_ALERT}   & C'è una emergenza che richiede intervento
857                            immediato.\\
858     \const{LOG\_CRIT}    & Si è in una condizione critica.\\
859     \const{LOG\_ERR}     & Si è in una condizione di errore.\\
860     \const{LOG\_WARNING} & Messaggio di avvertimento.\\
861     \const{LOG\_NOTICE}  & Notizia significativa relativa al comportamento.\\
862     \const{LOG\_INFO}    & Messaggio informativo. \\
863     \const{LOG\_DEBUG}   & Messaggio di debug.\\
864     \hline
865   \end{tabular}
866   \caption{Valori possibili per l'indice di importanza del messaggio da
867     specificare nell'argomento \param{priority} di \func{syslog}.}
868   \label{tab:sess_syslog_priority}
869 \end{table}
870
871 Una ulteriore funzione, \funcd{setlogmask}, permette di filtrare
872 preliminarmente i messaggi in base alla loro priorità; il suo prototipo è:
873 \begin{prototype}{syslog.h}{int setlogmask(int mask)}
874
875 Imposta la maschera dei log al valore specificato.
876
877 \bodydesc{La funzione restituisce il precedente valore.}
878 \end{prototype}
879
880 Le routine di gestione mantengono per ogni processo una maschera che determina
881 quale delle chiamate effettuate a \func{syslog} verrà effettivamente
882 registrata. La registrazione viene disabilitata per tutte quelle priorità che
883 non rientrano nella maschera; questa viene settata usando la macro
884 \macro{LOG\_MASK(p)} dove \code{p} è una delle costanti di
885 tab.~\ref{tab:sess_syslog_priority}. É inoltre disponibile anche la macro
886 \macro{LOG\_UPTO(p)} che permette di specificare automaticamente tutte le
887 priorità fino ad un certo valore.
888
889
890
891 \section{L'I/O su terminale}
892 \label{sec:sess_terminal_io}
893
894 Benché come ogni altro dispositivo i terminali siano accessibili come file,
895 essi hanno assunto storicamente (essendo stati a lungo l'unico modo di
896 accedere al sistema) una loro rilevanza specifica, che abbiamo già avuto modo
897 di incontrare nella precedente sezione.
898
899 Esamineremo qui le peculiarità dell'I/O eseguito sui terminali, che per la
900 loro particolare natura presenta delle differenze rispetto ai normali file su
901 disco e agli altri dispositivi.
902
903
904
905 \subsection{L'architettura}
906 \label{sec:term_design}
907
908 I terminali sono una classe speciale di dispositivi a caratteri (si ricordi la
909 classificazione di sez.~\ref{sec:file_file_types}); un terminale ha infatti una
910 caratteristica che lo contraddistingue da un qualunque altro dispositivo, e
911 cioè che è destinato a gestire l'interazione con un utente (deve essere cioè
912 in grado di fare da terminale di controllo per una sessione), che comporta la
913 presenza di ulteriori capacità.
914
915 L'interfaccia per i terminali è una delle più oscure e complesse, essendosi
916 stratificata dagli inizi dei sistemi Unix fino ad oggi. Questo comporta una
917 grande quantità di opzioni e controlli relativi ad un insieme di
918 caratteristiche (come ad esempio la velocità della linea) necessarie per
919 dispositivi, come i terminali seriali, che al giorno d'oggi sono praticamente
920 in disuso.
921
922 Storicamente i primi terminali erano appunto terminali di telescriventi
923 (\textit{teletype}), da cui deriva sia il nome dell'interfaccia, \textit{TTY},
924 che quello dei relativi file di dispositivo, che sono sempre della forma
925 \texttt{/dev/tty*}.\footnote{ciò vale solo in parte per i terminali virtuali,
926   essi infatti hanno due lati, un \textit{master}, che può assumere i nomi
927   \file{/dev/pty[p-za-e][0-9a-f]} ed un corrispondente \textit{slave} con nome
928   \file{/dev/tty[p-za-e][0-9a-f]}.}  Oggi essi includono le porte seriali, le
929 console virtuali dello schermo, i terminali virtuali che vengono creati come
930 canali di comunicazione dal kernel e che di solito vengono associati alle
931 connessioni di rete (ad esempio per trattare i dati inviati con \cmd{telnet} o
932 \cmd{ssh}).
933
934 L'I/O sui terminali si effettua con le stesse modalità dei file normali: si
935 apre il relativo file di dispositivo, e si leggono e scrivono i dati con le
936 usuali funzioni di lettura e scrittura, così se apriamo una console virtuale
937 avremo che \func{read} leggerà quanto immesso dalla tastiera, mentre
938 \func{write} scriverà sullo schermo.  In realtà questo è vero solo a grandi
939 linee, perché non tiene conto delle caratteristiche specifiche dei terminali;
940 una delle principali infatti è che essi prevedono due modalità di operazione,
941 dette rispettivamente \textsl{modo canonico} e \textsl{modo non canonico}, che
942 comportano dei comportamenti nettamente diversi.
943
944 La modalità preimpostata all'apertura del terminale è quella canonica, in cui
945 le operazioni di lettura vengono sempre effettuate assemblando i dati in una
946 linea;\footnote{per cui eseguendo una \func{read} su un terminale in modo
947   canonico la funzione si bloccherà, anche se si sono scritti dei caratteri,
948   fintanto che non si preme il tasto di ritorno a capo: a questo punto la
949   linea sarà completa e la funzione ritornerà.} ed in cui alcuni caratteri
950 vengono interpretati per compiere operazioni (come la generazione dei segnali
951 illustrati in sez.~\ref{sec:sig_job_control}), questa di norma è la modalità in
952 cui funziona la shell.
953
954 Un terminale in modo non canonico invece non effettua nessun accorpamento dei
955 dati in linee né li interpreta; esso viene di solito usato dai programmi (gli
956 editor ad esempio) che necessitano di poter leggere un carattere alla volta e
957 che gestiscono al loro interno i vari comandi.
958
959 Per capire le caratteristiche dell'I/O sui terminali, occorre esaminare le
960 modalità con cui esso viene effettuato; l'accesso, come per tutti i
961 dispositivi, viene gestito da un driver apposito, la cui struttura generica è
962 mostrata in fig.~\ref{fig:term_struct}. Ad un terminale sono sempre associate
963 due code per gestire l'input e l'output, che ne implementano una
964 bufferizzazione\footnote{completamente indipendente dalla eventuale ulteriore
965   bufferizzazione fornita dall'interfaccia standard dei file.} all'interno del
966 kernel.
967
968 \begin{figure}[htb]
969   \centering \includegraphics[width=14.5cm]{img/term_struct}
970   \caption{Struttura interna generica di un driver per un terminale.}
971   \label{fig:term_struct}
972 \end{figure}
973
974 La coda di ingresso mantiene i caratteri che sono stati letti dal terminale ma
975 non ancora letti da un processo, la sua dimensione è definita dal parametro di
976 sistema \const{MAX\_INPUT} (si veda sez.~\ref{sec:sys_file_limits}), che ne
977 specifica il limite minimo, in realtà la coda può essere più grande e cambiare
978 dimensione dinamicamente. Se è stato abilitato il controllo di flusso in
979 ingresso il driver emette i caratteri di STOP e START per bloccare e sbloccare
980 l'ingresso dei dati; altrimenti i caratteri immessi oltre le dimensioni
981 massime vengono persi; in alcuni casi il driver provvede ad inviare
982 automaticamente un avviso (un carattere di BELL, che provoca un beep)
983 sull'output quando si eccedono le dimensioni della coda.  Se è abilitato il
984 modo canonico i caratteri in ingresso restano nella coda fintanto che non
985 viene ricevuto un a capo; un'altro parametro del sistema, \const{MAX\_CANON},
986 specifica la dimensione massima di una riga in modo canonico.
987
988 La coda di uscita è analoga a quella di ingresso e contiene i caratteri
989 scritti dai processi ma non ancora inviati al terminale. Se è abilitato il
990 controllo di flusso in uscita il driver risponde ai caratteri di START e STOP
991 inviati dal terminale. Le dimensioni della coda non sono specificate, ma non
992 hanno molta importanza, in quanto qualora esse vengano eccedute il driver
993 provvede automaticamente a bloccare la funzione chiamante.
994
995
996
997 \subsection{La gestione delle caratteristiche di un terminale}
998 \label{sec:term_attr}
999
1000 Data le loro peculiarità, fin dall'inizio si è posto il problema di come
1001 gestire le caratteristiche specifiche dei terminali; storicamente i vari
1002 dialetti di Unix hanno utilizzato diverse funzioni, alla fine con POSIX.1, è
1003 stata effettuata una standardizzazione, unificando le differenze fra BSD e
1004 System V in una unica interfaccia, che è quella usata dal Linux.
1005
1006 Alcune di queste funzioni prendono come argomento un file descriptor (in
1007 origine molte operazioni venivano effettuate con \func{ioctl}), ma ovviamente
1008 possono essere usate solo con file che corrispondano effettivamente ad un
1009 terminale (altrimenti si otterrà un errore di \errcode{ENOTTY}); questo può
1010 essere evitato utilizzando la funzione \funcd{isatty}, il cui prototipo è:
1011 \begin{prototype}{unistd.h}{int isatty(int desc)}
1012   
1013   Controlla se il file descriptor \param{desc} è un terminale.
1014   
1015 \bodydesc{La funzione restituisce 1 se \param{desc} è connesso ad un
1016   terminale, 0 altrimenti.}
1017 \end{prototype}
1018
1019 Un'altra funzione che fornisce informazioni su un terminale è \funcd{ttyname},
1020 che permette di ottenere il nome del terminale associato ad un file
1021 descriptor; il suo prototipo è:
1022 \begin{prototype}{unistd.h}{char *ttyname(int desc)}
1023   
1024   Restituisce il nome del terminale associato al file \param{desc}.
1025   
1026    \bodydesc{La funzione restituisce il puntatore alla stringa contenente il
1027     nome del terminale associato \param{desc} e \val{NULL} in caso di
1028     errore.}
1029 \end{prototype}
1030
1031 Si tenga presente che la funzione restituisce un indirizzo di dati statici,
1032 che pertanto possono essere sovrascritti da successive chiamate. Una funzione
1033 funzione analoga, anch'essa prevista da POSIX.1, è \funcd{ctermid}, il cui
1034 prototipo è:
1035 \begin{prototype}{stdio.h}{char *ctermid(char *s)}
1036   
1037   Restituisce il nome del terminale di controllo del processo.
1038   
1039   \bodydesc{La funzione restituisce il puntatore alla stringa contenente il
1040     \textit{pathname} del terminale.}
1041 \end{prototype}
1042
1043 La funzione scrive il \itindex{pathname}\textit{pathname} del terminale di
1044 controllo del processo chiamante nella stringa posta all'indirizzo specificato
1045 dall'argomento \param{s}.  La memoria per contenere la stringa deve essere
1046 stata allocata in precedenza ed essere lunga almeno
1047 \const{L\_ctermid}\footnote{\const{L\_ctermid} è una delle varie costanti del
1048   sistema, non trattata esplicitamente in sez.~\ref{sec:sys_characteristics}
1049   che indica la dimensione che deve avere una stringa per poter contenere il
1050   nome di un terminale.} caratteri.
1051
1052 Esiste infine una versione rientrante \funcd{ttyname\_r} della funzione
1053 \func{ttyname}, che non presenta il problema dell'uso di una zona di memoria
1054 statica; il suo prototipo è:
1055 \begin{prototype}{unistd.h}{int ttyname\_r(int desc, char *buff, size\_t len)}
1056   
1057   Restituisce il nome del terminale associato al file \param{desc}.
1058   
1059   \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di
1060     errore, nel qual caso \var{errno} assumerà i valori:
1061     \begin{errlist}
1062     \item[\errcode{ERANGE}] la lunghezza del buffer, \param{len}, non è
1063       sufficiente per contenere la stringa restituita.
1064     \end{errlist}
1065     ed inoltre \errval{EBADF} ed \errval{ENOSYS}.
1066 }
1067 \end{prototype}
1068
1069 La funzione prende due argomenti, il puntatore alla zona di memoria
1070 \param{buff}, in cui l'utente vuole che il risultato venga scritto (dovrà
1071 ovviamente essere stata allocata in precedenza), e la relativa dimensione,
1072 \param{len}; se la stringa che deve essere restituita eccede questa dimensione
1073 si avrà una condizione di errore.
1074
1075 Se si passa come argomento \val{NULL} la funzione restituisce il puntatore ad
1076 una stringa statica che può essere sovrascritta da chiamate successive. Si
1077 tenga presente che il \itindex{pathname}\textit{pathname} restituito
1078 potrebbe non identificare univocamente il terminale (ad esempio potrebbe
1079 essere \file{/dev/tty}), inoltre non è detto che il processo possa
1080 effettivamente aprire il terminale.
1081
1082 I vari attributi vengono mantenuti per ciascun terminale in una struttura
1083 \struct{termios}, (la cui definizione è riportata in
1084 fig.~\ref{fig:term_termios}), usata dalle varie funzioni dell'interfaccia. In
1085 fig.~\ref{fig:term_termios} si sono riportati tutti i campi della definizione
1086 usata in Linux; di questi solo i primi cinque sono previsti dallo standard
1087 POSIX.1, ma le varie implementazioni ne aggiungono degli altri per mantenere
1088 ulteriori informazioni.\footnote{la definizione della struttura si trova in
1089   \file{bits/termios.h}, da non includere mai direttamente, Linux, seguendo
1090   l'esempio di BSD, aggiunge i due campi \var{c\_ispeed} e \var{c\_ospeed} per
1091   mantenere le velocità delle linee seriali, ed un campo ulteriore,
1092   \var{c\_line} per ... (NdT, trovare a che serve).}
1093
1094 \begin{figure}[!htb] 
1095   \footnotesize \centering
1096   \begin{minipage}[c]{15cm}
1097     \includestruct{listati/termios.h}
1098   \end{minipage} 
1099   \normalsize 
1100   \caption{La struttura \structd{termios}, che identifica le proprietà di un
1101     terminale.}
1102   \label{fig:term_termios}
1103 \end{figure}
1104
1105 I primi quattro campi sono quattro flag che controllano il comportamento del
1106 terminale; essi sono realizzati come maschera binaria, pertanto il tipo
1107 \type{tcflag\_t} è di norma realizzato con un intero senza segno di lunghezza
1108 opportuna. I valori devono essere specificati bit per bit, avendo cura di non
1109 modificare i bit su cui non si interviene.
1110
1111 \begin{table}[b!ht]
1112   \footnotesize
1113   \centering
1114   \begin{tabular}[c]{|l|p{11cm}|}
1115     \hline
1116     \textbf{Valore}& \textbf{Significato}\\
1117     \hline
1118     \hline
1119     \const{INPCK}  & Abilita il controllo di parità in ingresso. Se non viene
1120                      impostato non viene fatto nessun controllo ed i caratteri
1121                      vengono passati in input direttamente.\\
1122     \const{IGNPAR} & Ignora gli errori di parità, il carattere viene passato
1123                      come ricevuto. Ha senso solo se si è impostato 
1124                      \const{INPCK}.\\
1125     \const{PARMRK} & Controlla come vengono riportati gli errori di parità. Ha 
1126                      senso solo se \const{INPCK} è impostato e \const{IGNPAR}
1127                      no. Se impostato inserisce una sequenza \texttt{0xFF
1128                        0x00} prima di ogni carattere che presenta errori di
1129                      parità, se non impostato un carattere con errori di
1130                      parità viene letto come uno \texttt{0x00}. Se un
1131                      carattere ha il valore \texttt{0xFF} e \const{ISTRIP} 
1132                      non è settato, per evitare ambiguità esso viene sempre
1133                      riportato come \texttt{0xFF 0xFF}.\\
1134     \const{ISTRIP} & Se impostato i caratteri in input sono tagliati a sette
1135                      bit mettendo a zero il bit più significativo, altrimenti 
1136                      vengono passati tutti gli otto bit.\\
1137     \const{IGNBRK} & Ignora le condizioni di BREAK sull'input. Una
1138                      \textit{condizione di BREAK} è definita nel contesto di
1139                      una trasmissione seriale asincrona come una sequenza di
1140                      bit nulli più lunga di un byte. \\
1141     \const{BRKINT} & Controlla la reazione ad un BREAK quando
1142                      \const{IGNBRK} non è impostato. Se \const{BRKINT} è
1143                      impostato il BREAK causa lo scarico delle code, 
1144                      e se il terminale è il terminale di controllo per un 
1145                      gruppo in foreground anche l'invio di \const{SIGINT} ai
1146                      processi di quest'ultimo. Se invece \const{BRKINT} non è
1147                      impostato un BREAK viene letto come un carattere
1148                      NUL, a meno che non sia settato \const{PARMRK}
1149                      nel qual caso viene letto come la sequenza di caratteri
1150                      \texttt{0xFF 0x00 0x00}.\\
1151     \const{IGNCR}  & Se impostato il carattere di ritorno carrello 
1152                      (\textit{carriage return}, \verb|'\r'|) viene scartato 
1153                      dall'input. Può essere utile per i terminali che inviano 
1154                      entrambi i caratteri di ritorno carrello e a capo 
1155                      (\textit{newline}, \verb|'\n'|).  \\
1156     \const{ICRNL}  & Se impostato un carattere di ritorno carrello  
1157                      (\verb|'\r'|) sul terminale viene automaticamente 
1158                      trasformato in un a capo (\verb|'\n'|) sulla coda di
1159                      input. \\
1160     \const{INLCR}  & Se impostato il carattere di a capo
1161                      (\verb|'\n'|) viene automaticamente trasformato in un
1162                      ritorno carrello (\verb|'\r'|).\\
1163     \const{IUCLC}  & Se impostato trasforma i caratteri maiuscoli dal
1164                      terminale in minuscoli sull'ingresso (opzione non 
1165                      POSIX).\\
1166     \const{IXON}   & Se impostato attiva il controllo di flusso in uscita con i
1167                      caratteri di START e STOP. se si riceve
1168                      uno STOP l'output viene bloccato, e viene fatto
1169                      ripartire solo da uno START, e questi due
1170                      caratteri non vengono passati alla coda di input. Se non
1171                      impostato i due caratteri sono passati alla coda di input
1172                      insieme agli altri.\\
1173     \const{IXANY}  & Se impostato con il controllo di flusso permette a
1174                      qualunque carattere di far ripartire l'output bloccato da
1175                      un carattere di STOP.\\
1176     \const{IXOFF}  & Se impostato abilita il controllo di flusso in
1177                      ingresso. Il computer emette un carattere di STOP per
1178                      bloccare l'input dal terminale e lo sblocca con il
1179                      carattere START. \\
1180     \const{IMAXBEL}& Se impostato fa suonare il cicalino se si riempie la cosa
1181                      di ingresso; in Linux non è implementato e il kernel si
1182                      comporta cose se fosse sempre settato (è una estensione
1183                      BSD). \\
1184     \hline
1185   \end{tabular}
1186   \caption{Costanti identificative dei vari bit del flag di controllo
1187     \var{c\_iflag} delle modalità di input di un terminale.}
1188   \label{tab:sess_termios_iflag}
1189 \end{table}
1190
1191 Il primo flag, mantenuto nel campo \var{c\_iflag}, è detto \textsl{flag di
1192   input} e controlla le modalità di funzionamento dell'input dei caratteri sul
1193 terminale, come il controllo di parità, il controllo di flusso, la gestione
1194 dei caratteri speciali; un elenco dei vari bit, del loro significato e delle
1195 costanti utilizzate per identificarli è riportato in
1196 tab.~\ref{tab:sess_termios_iflag}.
1197
1198 Si noti come alcuni di questi flag (come quelli per la gestione del flusso)
1199 fanno riferimento a delle caratteristiche che ormai sono completamente
1200 obsolete; la maggior parte inoltre è tipica di terminali seriali, e non ha
1201 alcun effetto su dispositivi diversi come le console virtuali o gli
1202 pseudo-terminali usati nelle connessioni di rete.
1203
1204 \begin{table}[htb]
1205   \footnotesize
1206   \centering
1207   \begin{tabular}[c]{|l|p{11cm}|}
1208     \hline
1209     \textbf{Valore}& \textbf{Significato}\\
1210     \hline
1211     \hline
1212     \const{OPOST} & Se impostato i caratteri vengono convertiti opportunamente
1213                     (in maniera dipendente dall'implementazione) per la 
1214                     visualizzazione sul terminale, ad esempio al
1215                     carattere di a capo (NL) può venire aggiunto un ritorno
1216                     carrello (CR).\\
1217     \const{OCRNL} & Se impostato converte automaticamente il carattere di a
1218                     capo (NL) nella coppia di caratteri ritorno carrello, a 
1219                     capo (CR-NL).\\
1220     \const{OLCUC} & Se impostato trasforma i caratteri minuscoli in ingresso 
1221                     in caratteri maiuscoli sull'uscita (non previsto da
1222                     POSIX.1).\\
1223     \const{ONLCR} & Se impostato converte automaticamente il carattere di a 
1224                     capo (NL) in un carattere di ritorno carrello (CR).\\
1225     \const{ONOCR} & Se impostato converte il carattere di ritorno carrello
1226                     (CR) nella coppia di caratteri CR-NL.\\
1227     \const{ONLRET}& Se impostato rimuove dall'output il carattere di ritorno
1228                     carrello (CR).\\
1229     \const{OFILL} & Se impostato in caso di ritardo sulla linea invia dei
1230                     caratteri di riempimento invece di attendere.\\
1231     \const{OFDEL} & Se impostato il carattere di riempimento è DEL
1232                     (\texttt{0x3F}), invece che NUL (\texttt{0x00}).\\
1233     \const{NLDLY} & Maschera per i bit che indicano il ritardo per il
1234                     carattere di a capo (NL), i valori possibili sono 
1235                     \val{NL0} o \val{NL1}.\\
1236     \const{CRDLY} & Maschera per i bit che indicano il ritardo per il
1237                     carattere ritorno carrello (CR), i valori possibili sono
1238                     \val{CR0}, \val{CR1}, \val{CR2} o \val{CR3}.\\
1239     \const{TABDLY}& Maschera per i bit che indicano il ritardo per il
1240                     carattere di tabulazione, i valori possibili sono
1241                     \val{TAB0}, \val{TAB1}, \val{TAB2} o \val{TAB3}.\\
1242     \const{BSDLY} & Maschera per i bit che indicano il ritardo per il
1243                     carattere di ritorno indietro (\textit{backspace}), i
1244                     valori possibili sono \val{BS0} o \val{BS1}.\\
1245     \const{VTDLY} & Maschera per i bit che indicano il ritardo per il
1246                     carattere di tabulazione verticale, i valori possibili sono
1247                     \val{VT0} o \val{VT1}.\\
1248     \const{FFDLY} & Maschera per i bit che indicano il ritardo per il
1249                     carattere di pagina nuova (\textit{form feed}), i valori
1250                     possibili sono \val{FF0} o \val{FF1}.\\
1251     \hline
1252   \end{tabular}
1253   \caption{Costanti identificative dei vari bit del flag di controllo
1254     \var{c\_oflag} delle modalità di output di un terminale.}
1255   \label{tab:sess_termios_oflag}
1256 \end{table}
1257
1258 Il secondo flag, mantenuto nel campo \var{c\_oflag}, è detto \textsl{flag di
1259   output} e controlla le modalità di funzionamento dell'output dei caratteri,
1260 come l'impacchettamento dei caratteri sullo schermo, la traslazione degli a
1261 capo, la conversione dei caratteri speciali; un elenco dei vari bit, del loro
1262 significato e delle costanti utilizzate per identificarli è riportato in
1263 tab.~\ref{tab:sess_termios_oflag}.
1264
1265 Si noti come alcuni dei valori riportati in tab.~\ref{tab:sess_termios_oflag}
1266 fanno riferimento a delle maschere di bit; essi infatti vengono utilizzati per
1267 impostare alcuni valori numerici relativi ai ritardi nell'output di alcuni
1268 caratteri: una caratteristica originaria dei primi terminali su telescrivente,
1269 che avevano bisogno di tempistiche diverse per spostare il carrello in
1270 risposta ai caratteri speciali, e che oggi sono completamente in disuso.
1271
1272 Si tenga presente inoltre che nel caso delle maschere il valore da inserire in
1273 \var{c\_oflag} deve essere fornito avendo cura di cancellare prima tutti i bit
1274 della maschera, i valori da immettere infatti (quelli riportati nella
1275 spiegazione corrispondente) sono numerici e non per bit, per cui possono
1276 sovrapporsi fra di loro. Occorrerà perciò utilizzare un codice del tipo:
1277
1278 \includecodesnip{listati/oflag.c}
1279
1280 \noindent che prima cancella i bit della maschera in questione e poi setta il
1281 valore.
1282
1283
1284 \begin{table}[htb]
1285   \footnotesize
1286   \centering
1287   \begin{tabular}[c]{|l|p{11cm}|}
1288     \hline
1289     \textbf{Valore}& \textbf{Significato}\\
1290     \hline
1291     \hline
1292     \const{CLOCAL} & Se impostato indica che il terminale è connesso in locale
1293                      e che le linee di controllo del modem devono essere
1294                      ignorate. Se non impostato effettuando una chiamata ad
1295                      \func{open} senza aver specificato il flag di
1296                      \const{O\_NOBLOCK} si bloccherà il processo finché 
1297                      non si è stabilita una connessione con il modem; inoltre 
1298                      se viene rilevata una disconessione viene inviato un
1299                      \const{SIGHUP} al processo di controllo del terminale. La
1300                      lettura su un terminale sconnesso comporta una condizione
1301                      di \textit{end of file} e la scrittura un errore di
1302                      \errcode{EIO}. \\
1303     \const{HUPCL}  & Se è impostato viene distaccata la connessione del
1304                      modem quando l'ultimo dei processi che ha ancora un file
1305                      aperto sul terminale lo chiude o esce.\\
1306     \const{CREAD}  & Se è impostato si può leggere l'input del terminale,
1307                      altrimenti i caratteri in ingresso vengono scartati
1308                      quando arrivano.\\
1309     \const{CSTOPB} & Se impostato vengono usati due bit di stop sulla linea
1310                      seriale, se non impostato ne viene usato soltanto uno.\\
1311     \const{PARENB} & Se impostato abilita la generazione il controllo di
1312                      parità. La reazione in caso di errori dipende dai
1313                      relativi valori per \var{c\_iflag}, riportati in 
1314                      tab.~\ref{tab:sess_termios_iflag}. Se non è impostato i
1315                      bit di parità non vengono
1316                      generati e i caratteri non vengono controllati.\\
1317     \const{PARODD} & Ha senso solo se è attivo anche \const{PARENB}. Se 
1318                      impostato viene usata una parità è dispari, altrimenti 
1319                      viene usata una parità pari.\\
1320     \const{CSIZE}  & Maschera per i bit usati per specificare la dimensione 
1321                      del carattere inviato lungo la linea di trasmissione, i
1322                      valore ne indica la lunghezza (in bit), ed i valori   
1323                      possibili sono \val{CS5}, \val{CS6}, 
1324                      \val{CS7} e \val{CS8}
1325                      corrispondenti ad un analogo numero di bit.\\
1326     \const{CBAUD}  & Maschera dei bit (4+1) usati per impostare della velocità
1327                      della linea (il \textit{baud rate}) in ingresso. 
1328                      In Linux non è implementato in quanto viene 
1329                      usato un apposito campo di \struct{termios}.\\
1330     \const{CBAUDEX}& Bit aggiuntivo per l'impostazione della velocità della
1331                      linea, per le stesse motivazioni del precedente non è
1332                      implementato in Linux.\\
1333     \const{CIBAUD} & Maschera dei bit della velocità della linea in
1334                      ingresso. Analogo a \const{CBAUD}, anch'esso in Linux è
1335                      mantenuto in un apposito campo di \struct{termios}. \\
1336     \const{CRTSCTS}& Abilita il controllo di flusso hardware sulla seriale,
1337                      attraverso l'utilizzo delle dei due fili di RTS e CTS.\\
1338     \hline
1339   \end{tabular}
1340   \caption{Costanti identificative dei vari bit del flag di controllo
1341     \var{c\_cflag} delle modalità di controllo di un terminale.}
1342   \label{tab:sess_termios_cflag}
1343 \end{table}
1344
1345 Il terzo flag, mantenuto nel campo \var{c\_cflag}, è detto \textsl{flag di
1346   controllo} ed è legato al funzionamento delle linee seriali, permettendo di
1347 impostarne varie caratteristiche, come il numero di bit di stop, i settaggi
1348 della parità, il funzionamento del controllo di flusso; esso ha senso solo per
1349 i terminali connessi a linee seriali. Un elenco dei vari bit, del loro
1350 significato e delle costanti utilizzate per identificarli è riportato in
1351 tab.~\ref{tab:sess_termios_cflag}.
1352
1353 I valori di questo flag sono molto specifici, e completamente indirizzati al
1354 controllo di un terminale mantenuto su una linea seriale; essi pertanto non
1355 hanno nessuna rilevanza per i terminali che usano un'altra interfaccia, come
1356 le console virtuali e gli pseudo-terminali usati dalle connessioni di rete.
1357
1358 Inoltre alcuni valori sono previsti solo per quelle implementazioni (lo
1359 standard POSIX non specifica nulla riguardo l'implementazione, ma solo delle
1360 funzioni di lettura e scrittura) che mantengono le velocità delle linee
1361 seriali all'interno dei flag; come accennato in Linux questo viene fatto
1362 (seguendo l'esempio di BSD) attraverso due campi aggiuntivi, \var{c\_ispeed} e
1363 \var{c\_ospeed}, nella struttura \struct{termios} (mostrati in
1364 fig.~\ref{fig:term_termios}).
1365
1366 \begin{table}[b!ht]
1367   \footnotesize
1368   \centering
1369   \begin{tabular}[c]{|l|p{11cm}|}
1370     \hline
1371     \textbf{Valore}& \textbf{Significato}\\
1372     \hline
1373     \hline
1374     \const{ICANON} & Se impostato il terminale opera in modo canonico,
1375                      altrimenti opera in modo non canonico.\\
1376     \const{ECHO}   & Se è impostato viene attivato l'eco dei caratteri in
1377                      input sull'output del terminale.\\
1378     \const{ECHOE}  & Se è impostato l'eco mostra la cancellazione di un
1379                      carattere in input (in reazione al carattere ERASE)
1380                      cancellando l'ultimo carattere della riga corrente dallo
1381                      schermo; altrimenti il carattere è rimandato in eco per
1382                      mostrare quanto accaduto (usato per i terminali con
1383                      l'uscita su una stampante). \\
1384     \const{ECHOPRT}& Se impostato abilita la visualizzazione del carattere di
1385                      cancellazione in una modalità adatta ai terminali con
1386                      l'uscita su stampante; l'invio del carattere di ERASE
1387                      comporta la stampa di un \verb|\| seguito dal carattere
1388                      cancellato, e così via in caso di successive
1389                      cancellazioni, quando si riprende ad immettere carattere 
1390                      normali prima verrà stampata una \texttt{/}.\\
1391     \const{ECHOK}  & Se impostato abilita il trattamento della visualizzazione
1392                      del carattere KILL, andando a capo dopo aver visualizzato
1393                      lo stesso, altrimenti viene solo mostrato il carattere e
1394                      sta all'utente ricordare che l'input precedente è stato
1395                      cancellato. \\
1396     \const{ECHOKE} & Se impostato abilita il trattamento della visualizzazione
1397                      del carattere KILL cancellando i caratteri precedenti
1398                      nella linea secondo le modalità specificate dai valori di
1399                      \const{ECHOE} e \const{ECHOPRT}.\\
1400     \const{ECHONL} & Se impostato viene effettuato l'eco di un a
1401                      capo (\verb|\n|) anche se non è stato impostato
1402                      \const{ECHO}. \\
1403     \const{ECHOCTL}& Se impostato insieme ad \const{ECHO} i caratteri di
1404                      controllo ASCII (tranne TAB, NL, START, e STOP) sono
1405                      mostrati nella forma che prepende un \verb|^| alla
1406                      lettera ottenuta sommando \texttt{0x40} al valore del
1407                      carattere (di solito questi si possono ottenere anche
1408                      direttamente premendo il tasto \texttt{ctrl} più la
1409                      relativa lettera).\\
1410     \const{ISIG}   & Se impostato abilita il riconoscimento dei caratteri
1411                      INTR, QUIT, e SUSP generando il relativo segnale.\\
1412     \const{IEXTEN} & Abilita alcune estensioni previste dalla
1413                      implementazione. Deve essere impostato perché caratteri
1414                      speciali come EOL2, LNEXT, REPRINT e WERASE possano
1415                      essere interpretati. \\
1416     \const{NOFLSH} & Se impostato disabilita lo scarico delle code di ingresso
1417                      e uscita quando vengono emessi i segnali \const{SIGINT}, 
1418                      \const{SIGQUIT} and \const{SIGSUSP}.\\
1419     \const{TOSTOP} & Se abilitato, con il supporto per il job control presente,
1420                      genera il segnale \const{SIGTTOU} per un processo in
1421                      background che cerca di scrivere sul terminale.\\
1422     \const{XCASE}  & Se impostato il terminale funziona solo con le
1423                      maiuscole. L'input è convertito in minuscole tranne per i
1424                      caratteri preceduti da una \verb|\|. In output le
1425                      maiuscole sono precedute da una \verb|\| e le minuscole
1426                      convertite in maiuscole.\\
1427     \const{DEFECHO}& Se impostato effettua l'eco solo se c'è un processo in
1428                      lettura.\\
1429     \const{FLUSHO} & Effettua la cancellazione della coda di uscita. Viene
1430                      attivato dal carattere DISCARD. Non è supportato in
1431                      Linux.\\
1432     \const{PENDIN} & Indica che la linea deve essere ristampata, viene
1433                      attivato dal carattere REPRINT e resta attivo fino alla
1434                      fine della ristampa. Non è supportato in Linux.\\
1435     \hline
1436   \end{tabular}
1437   \caption{Costanti identificative dei vari bit del flag di controllo
1438     \var{c\_lflag} delle modalità locali di un terminale.}
1439   \label{tab:sess_termios_lflag}
1440 \end{table}
1441
1442 Il quarto flag, mantenuto nel campo \var{c\_lflag}, è detto \textsl{flag
1443   locale}, e serve per controllare il funzionamento dell'interfaccia fra il
1444 driver e l'utente, come abilitare l'eco, gestire i caratteri di controllo e
1445 l'emissione dei segnali, impostare modo canonico o non canonico; un elenco dei
1446 vari bit, del loro significato e delle costanti utilizzate per identificarli è
1447 riportato in tab.~\ref{tab:sess_termios_lflag}. Con i terminali odierni l'unico
1448 flag con cui probabilmente si può avere a che fare è questo, in quanto è con
1449 questo che si impostano le caratteristiche generiche comuni a tutti i
1450 terminali.
1451
1452 Si tenga presente che i flag che riguardano le modalità di eco dei caratteri
1453 (\const{ECHOE}, \const{ECHOPRT}, \const{ECHOK}, \const{ECHOKE},
1454 \const{ECHONL}) controllano solo il comportamento della visualizzazione, il
1455 riconoscimento dei vari caratteri dipende dalla modalità di operazione, ed
1456 avviene solo in modo canonico, pertanto questi flag non hanno significato se
1457 non è impostato \const{ICANON}.
1458
1459 Oltre ai vari flag per gestire le varie caratteristiche dei terminali,
1460 \struct{termios} contiene pure il campo \var{c\_cc} che viene usato per
1461 impostare i caratteri speciali associati alle varie funzioni di controllo. Il
1462 numero di questi caratteri speciali è indicato dalla costante \const{NCCS},
1463 POSIX ne specifica almeno 11, ma molte implementazioni ne definiscono molti
1464 altri.\footnote{in Linux il valore della costante è 32, anche se i caratteri
1465   effettivamente definiti sono solo 17.}
1466
1467 \begin{table}[htb]
1468   \footnotesize
1469   \centering
1470   \begin{tabular}[c]{|l|c|c|p{8cm}|}
1471     \hline
1472     \textbf{Indice} & \textbf{Valore}&\textbf{Codice} & \textbf{Funzione}\\
1473     \hline
1474     \hline
1475     \const{VINTR}   &\texttt{0x03}&(\verb|C-c|)& Carattere di interrupt, 
1476                                                  provoca l'emissione di 
1477                                                  \const{SIGINT}. \\
1478     \const{VQUIT}   &\texttt{0x1C}&(\verb|C-\|)& Carattere di uscita provoca 
1479                                                  l'emissione di 
1480                                                  \const{SIGQUIT}.\\
1481     \const{VERASE}  &\texttt{0x7f}& DEL &  Carattere di ERASE, cancella
1482                                            l'ultimo carattere precedente 
1483                                            nella linea.\\
1484     \const{VKILL}   &\texttt{0x15}&(\verb|C-u|)& Carattere di KILL, cancella
1485                                                  l'intera riga.\\
1486     \const{VEOF}    &\texttt{0x04}&(\verb|C-d|)& Carattere di
1487                                                  \textit{end-of-file}. Causa
1488                                                  l'invio del contenuto del
1489                                                  buffer di ingresso al
1490                                                  processo in lettura anche se
1491                                                  non è ancora stato ricevuto
1492                                                  un a capo. Se è il primo
1493                                                  carattere immesso comporta il
1494                                                  ritorno di \func{read} con
1495                                                  zero caratteri, cioè la
1496                                                  condizione di
1497                                                  \textit{end-of-file}.\\
1498     \const{VTIME}   &   ---       & --- & Timeout, in decimi di secondo, per
1499                                           una lettura in modo non canonico. \\
1500     \const{VMIN}    &   ---       & --- & Numero minimo di caratteri per una 
1501                                           lettura in modo non canonico.\\
1502     \const{VSWTC}   &\texttt{0x00}& NUL & Carattere di switch. Non supportato
1503                                           in Linux.\\
1504     \const{VSTART}  &\texttt{0x21}&(\verb|C-q|)& Carattere di START. Riavvia un
1505                                                  output bloccato da uno STOP.\\
1506     \const{VSTOP}   &\texttt{0x23}&(\verb|C-s|)& Carattere di STOP. Blocca
1507                                                  l'output fintanto che non
1508                                                  viene premuto un carattere di
1509                                                  START.\\
1510     \const{VSUSP}   &\texttt{0x1A}&(\verb|C-z|)& Carattere di
1511                                                  sospensione. Invia il segnale
1512                                                  \const{SIGTSTP}.\\
1513     \const{VEOL}    &\texttt{0x00}& NUL & Carattere di fine riga. Agisce come
1514                                           un a capo, ma non viene scartato ed
1515                                           è letto come l'ultimo carattere
1516                                           nella riga.  \\
1517     \const{VREPRINT}&\texttt{0x12}&(\verb|C-r|)& Ristampa i caratteri non
1518                                                  ancora letti.  \\
1519     \const{VDISCARD}&\texttt{0x07}&(\verb|C-o|)& Non riconosciuto in Linux. \\
1520     \const{VWERASE} &\texttt{0x17}&(\verb|C-w|)& Cancellazione di una parola.\\
1521     \const{VLNEXT}  &\texttt{0x16}&(\verb|C-v|)& Carattere di escape, serve a
1522                                                  quotare il carattere
1523                                                  successivo che non viene
1524                                                  interpretato ma passato
1525                                                  direttamente all'output. \\
1526     \const{VEOL2}   &\texttt{0x00}& NUL & Ulteriore carattere di fine
1527                                           riga. Ha lo stesso effetto di
1528                                           \const{VEOL} ma può essere un
1529                                           carattere diverso. \\
1530     \hline
1531   \end{tabular}
1532   \caption{Valori dei caratteri di controllo mantenuti nel campo \var{c\_cc}
1533     della struttura \struct{termios}.} 
1534   \label{tab:sess_termios_cc}
1535 \end{table}
1536
1537
1538 A ciascuna di queste funzioni di controllo corrisponde un elemento del vettore
1539 \var{c\_cc} che specifica quale è il carattere speciale associato; per
1540 portabilità invece di essere indicati con la loro posizione numerica nel
1541 vettore, i vari elementi vengono indicizzati attraverso delle opportune
1542 costanti, il cui nome corrisponde all'azione ad essi associata. Un elenco
1543 completo dei caratteri di controllo, con le costanti e delle funzionalità
1544 associate è riportato in tab.~\ref{tab:sess_termios_cc}, usando quelle
1545 definizioni diventa possibile assegnare un nuovo carattere di controllo con un
1546 codice del tipo:
1547 \includecodesnip{listati/value_c_cc.c}
1548
1549 La maggior parte di questi caratteri (tutti tranne \const{VTIME} e
1550 \const{VMIN}) hanno effetto solo quando il terminale viene utilizzato in modo
1551 canonico; per alcuni devono essere soddisfatte ulteriori richieste, ad esempio
1552 \const{VINTR}, \const{VSUSP}, e \const{VQUIT} richiedono sia settato
1553 \const{ISIG}; \const{VSTART} e \const{VSTOP} richiedono sia settato
1554 \const{IXON}; \const{VLNEXT}, \const{VWERASE}, \const{VREPRINT} richiedono sia
1555 settato \const{IEXTEN}.  In ogni caso quando vengono attivati i caratteri
1556 vengono interpretati e non sono passati sulla coda di ingresso.
1557
1558 Per leggere ed scrivere tutte le varie impostazioni dei terminali viste finora
1559 lo standard POSIX prevede due funzioni che utilizzano come argomento un
1560 puntatore ad una struttura \struct{termios} che sarà quella in cui andranno
1561 immagazzinate le impostazioni.  Le funzioni sono \funcd{tcgetattr} e
1562 \funcd{tcsetattr} ed il loro prototipo è:
1563 \begin{functions}
1564   \headdecl{unistd.h} 
1565   \headdecl{termios.h}  
1566   \funcdecl{int tcgetattr(int fd, struct termios *termios\_p)} 
1567   Legge il valore delle impostazioni di un terminale.
1568   
1569   \funcdecl{int tcsetattr(int fd, int optional\_actions, struct termios
1570     *termios\_p)} 
1571   Scrive le impostazioni di un terminale.
1572   
1573   \bodydesc{Entrambe le funzioni restituiscono 0 in caso di successo e -1 in
1574     caso di errore, nel qual caso \var{errno} assumerà i valori:
1575     \begin{errlist}
1576     \item[\errcode{EINTR}] La funzione è stata interrotta. 
1577     \end{errlist}
1578     ed inoltre \errval{EBADF}, \errval{ENOTTY} ed \errval{EINVAL}. 
1579   }
1580 \end{functions}
1581
1582 Le funzioni operano sul terminale cui fa riferimento il file descriptor
1583 \param{fd} utilizzando la struttura indicata dal puntatore \param{termios\_p}
1584 per lo scambio dei dati. Si tenga presente che le impostazioni sono associate
1585 al terminale e non al file descriptor; questo significa che se si è cambiata
1586 una impostazione un qualunque altro processo che apra lo stesso terminale, od
1587 un qualunque altro file descriptor che vi faccia riferimento, vedrà le nuove
1588 impostazioni pur non avendo nulla a che fare con il file descriptor che si è
1589 usato per effettuare i cambiamenti.
1590
1591 Questo significa che non è possibile usare file descriptor diversi per
1592 utilizzare automaticamente il terminale in modalità diverse, se esiste una
1593 necessità di accesso differenziato di questo tipo occorrerà cambiare
1594 esplicitamente la modalità tutte le volte che si passa da un file descriptor
1595 ad un altro.
1596
1597 La funzione \func{tcgetattr} legge i valori correnti delle impostazioni di un
1598 terminale qualunque nella struttura puntata da \param{termios\_p};
1599 \func{tcsetattr} invece effettua la scrittura delle impostazioni e quando
1600 viene invocata sul proprio terminale di controllo può essere eseguita con
1601 successo solo da un processo in foreground.  Se invocata da un processo in
1602 background infatti tutto il gruppo riceverà un segnale di \const{SIGTTOU} come
1603 se si fosse tentata una scrittura, a meno che il processo chiamante non abbia
1604 \const{SIGTTOU} ignorato o bloccato, nel qual caso l'operazione sarà eseguita.
1605
1606 La funzione \func{tcsetattr} prevede tre diverse modalità di funzionamento,
1607 specificabili attraverso l'argomento \param{optional\_actions}, che permette
1608 di stabilire come viene eseguito il cambiamento delle impostazioni del
1609 terminale, i valori possibili sono riportati in
1610 tab.~\ref{tab:sess_tcsetattr_option}; di norma (come fatto per le due funzioni
1611 di esempio) si usa sempre \const{TCSANOW}, le altre opzioni possono essere
1612 utili qualora si cambino i parametri di output.
1613
1614 \begin{table}[htb]
1615   \footnotesize
1616   \centering
1617   \begin{tabular}[c]{|l|p{8cm}|}
1618     \hline
1619     \textbf{Valore}& \textbf{Significato}\\
1620     \hline
1621     \hline
1622     \const{TCSANOW}  & Esegue i cambiamenti in maniera immediata. \\
1623     \const{TCSADRAIN}& I cambiamenti vengono eseguiti dopo aver atteso che
1624                        tutto l'output presente sulle code è stato scritto. \\
1625     \const{TCSAFLUSH}& È identico a \const{TCSADRAIN}, ma in più scarta
1626                        tutti i dati presenti sulla coda di input.\\
1627     \hline
1628   \end{tabular}
1629   \caption{Possibili valori per l'argomento \param{optional\_actions} della
1630     funzione \func{tcsetattr}.} 
1631   \label{tab:sess_tcsetattr_option}
1632 \end{table}
1633
1634 Occorre infine tenere presente che \func{tcsetattr} ritorna con successo anche
1635 se soltanto uno dei cambiamenti richiesti è stato eseguito. Pertanto se si
1636 effettuano più cambiamenti è buona norma controllare con una ulteriore
1637 chiamata a \func{tcgetattr} che essi siano stati eseguiti tutti quanti.
1638
1639 \begin{figure}[!htb]
1640   \footnotesize \centering
1641   \begin{minipage}[c]{15cm}
1642     \includecodesample{listati/SetTermAttr.c}
1643   \end{minipage} 
1644   \normalsize 
1645   \caption{Codice della funzione \func{SetTermAttr} che permette di
1646     impostare uno dei flag di controllo locale del terminale.}
1647   \label{fig:term_set_attr}
1648 \end{figure}
1649
1650 Come già accennato per i cambiamenti effettuati ai vari flag di controllo
1651 occorre che i valori di ciascun bit siano specificati avendo cura di mantenere
1652 intatti gli altri; per questo motivo in generale si deve prima leggere il
1653 valore corrente delle impostazioni con \func{tcgetattr} per poi modificare i
1654 valori impostati.
1655
1656 In fig.~\ref{fig:term_set_attr} e fig.~\ref{fig:term_unset_attr} si è riportato
1657 rispettivamente il codice delle due funzioni \func{SetTermAttr} e
1658 \func{UnSetTermAttr}, che possono essere usate per impostare o rimuovere, con
1659 le dovute precauzioni, un qualunque bit di \var{c\_lflag}. Il codice di
1660 entrambe le funzioni può essere trovato nel file \file{SetTermAttr.c} dei
1661 sorgenti allegati.
1662
1663 La funzione \func{SetTermAttr} provvede ad impostare il bit specificato
1664 dall'argomento \param{flag}; prima si leggono i valori correnti
1665 (\texttt{\small 10}) con \func{tcgetattr}, uscendo con un messaggio in caso di
1666 errore (\texttt{\small 11--14}), poi si provvede a impostare solo i bit
1667 richiesti (possono essere più di uno) con un OR binario (\texttt{\small 15});
1668 infine si scrive il nuovo valore modificato con \func{tcsetattr}
1669 (\texttt{\small 16}), notificando un eventuale errore (\texttt{\small 11--14})
1670 o uscendo normalmente.
1671
1672 \begin{figure}[!htb]
1673   \footnotesize \centering
1674   \begin{minipage}[c]{15cm}
1675     \includecodesample{listati/UnSetTermAttr.c}
1676   \end{minipage} 
1677   \normalsize 
1678   \caption{Codice della funzione \func{UnSetTermAttr} che permette di
1679     rimuovere uno dei flag di controllo locale del terminale.} 
1680   \label{fig:term_unset_attr}
1681 \end{figure}
1682
1683 La seconda funzione, \func{UnSetTermAttr}, è assolutamente identica alla
1684 prima, solo che in questo caso, in (\texttt{\small 15}), si rimuovono i bit
1685 specificati dall'argomento \param{flag} usando un AND binario del valore
1686 negato.
1687
1688
1689 Al contrario di tutte le altre caratteristiche dei terminali, che possono
1690 essere impostate esplicitamente utilizzando gli opportuni campi di
1691 \struct{termios}, per le velocità della linea (il cosiddetto \textit{baud
1692   rate}) non è prevista una implementazione standardizzata, per cui anche se
1693 in Linux sono mantenute in due campi dedicati nella struttura, questi non
1694 devono essere acceduti direttamente ma solo attraverso le apposite funzioni di
1695 interfaccia provviste da POSIX.1.
1696
1697 Lo standard prevede due funzioni per scrivere la velocità delle linee seriali,
1698 \funcd{cfsetispeed} per la velocità della linea di ingresso e
1699 \funcd{cfsetospeed} per la velocità della linea di uscita; i loro prototipi
1700 sono:
1701 \begin{functions}
1702   \headdecl{unistd.h} 
1703   \headdecl{termios.h}  
1704   \funcdecl{int cfsetispeed(struct termios *termios\_p, speed\_t speed)} 
1705   Imposta la velocità delle linee seriali in ingresso.
1706   
1707   \funcdecl{int cfsetospeed(struct termios *termios\_p, speed\_t speed)} 
1708   Imposta la velocità delle linee seriali in uscita.
1709   
1710   \bodydesc{Entrambe le funzioni restituiscono 0 in caso di successo e -1 in
1711     caso di errore, che avviene solo quando il valore specificato non è
1712     valido.}
1713 \end{functions}
1714  
1715 Si noti che le funzioni si limitano a scrivere opportunamente il valore della
1716 velocità prescelta \param{speed} all'interno della struttura puntata da
1717 \param{termios\_p}; per effettuare l'impostazione effettiva occorrerà poi
1718 chiamare \func{tcsetattr}.
1719
1720 Si tenga presente che per le linee seriali solo alcuni valori di velocità sono
1721 validi; questi possono essere specificati direttamente (le \acr{glibc}
1722 prevedono che i valori siano indicati in bit per secondo), ma in generale
1723 altre versioni di librerie possono utilizzare dei valori diversi; per questo
1724 POSIX.1 prevede una serie di costanti che però servono solo per specificare le
1725 velocità tipiche delle linee seriali:
1726 \begin{verbatim}
1727      B0       B50      B75      
1728      B110     B134     B150
1729      B200     B300     B600
1730      B1200    B1800    B2400
1731      B4800    B9600    B19200
1732      B38400   B57600   B115200   
1733      B230400  B460800
1734 \end{verbatim}
1735
1736 Un terminale può utilizzare solo alcune delle velocità possibili, le funzioni
1737 però non controllano se il valore specificato è valido, dato che non possono
1738 sapere a quale terminale le velocità saranno applicate; sarà l'esecuzione di
1739 \func{tcsetattr} a fallire quando si cercherà di eseguire l'impostazione.
1740
1741 Di norma il valore ha senso solo per i terminali seriali dove indica appunto
1742 la velocità della linea di trasmissione; se questa non corrisponde a quella
1743 del terminale quest'ultimo non potrà funzionare: quando il terminale non è
1744 seriale il valore non influisce sulla velocità di trasmissione dei dati. 
1745
1746 In generale impostare un valore nullo (\val{B0}) sulla linea di output fa si
1747 che il modem non asserisca più le linee di controllo, interrompendo di fatto
1748 la connessione, qualora invece si utilizzi questo valore per la linea di input
1749 l'effetto sarà quello di rendere la sua velocità identica a quella della linea
1750 di output.
1751
1752 Analogamente a quanto avviene per l'impostazione, le velocità possono essere
1753 lette da una struttura \struct{termios} utilizzando altre due funzioni,
1754 \funcd{cfgetispeed} e \funcd{cfgetospeed}, i cui prototipi sono:
1755 \begin{functions}
1756   \headdecl{unistd.h} 
1757   \headdecl{termios.h}  
1758   \funcdecl{speed\_t cfgetispeed(struct termios *termios\_p)} 
1759   Legge la velocità delle linee seriali in ingresso.
1760   
1761   \funcdecl{speed\_t cfgetospeed(struct termios *termios\_p)} 
1762   Legge la velocità delle linee seriali in uscita.
1763   
1764   \bodydesc{Entrambe le funzioni restituiscono la velocità della linea, non
1765   sono previste condizioni di errore.}
1766 \end{functions}
1767
1768 Anche in questo caso le due funzioni estraggono i valori della velocità della
1769 linea da una struttura, il cui indirizzo è specificato dall'argomento
1770 \param{termios\_p} che deve essere stata letta in precedenza con
1771 \func{tcgetattr}.
1772
1773
1774
1775 \subsection{La gestione della disciplina di linea.}
1776 \label{sec:term_line_discipline}
1777
1778 Come illustrato dalla struttura riportata in fig.~\ref{fig:term_struct} tutti
1779 i terminali hanno un insieme di funzionalità comuni, che prevedono la presenza
1780 di code di ingresso ed uscita; in generale si fa riferimento ad esse con il
1781 nome di \textsl{discipline di linea}.
1782
1783
1784 Lo standard POSIX prevede alcune funzioni che permettono di intervenire
1785 direttamente sulla gestione di quest'ultime e sull'interazione fra i dati in
1786 ingresso ed uscita e le relative code. In generale tutte queste funzioni
1787 vengono considerate, dal punto di vista dell'accesso al terminale, come delle
1788 funzioni di scrittura, pertanto se usate da processi in background sul loro
1789 terminale di controllo provocano l'emissione di \const{SIGTTOU} come
1790 illustrato in sez.~\ref{sec:sess_ctrl_term}.\footnote{con la stessa eccezione,
1791   già vista per \func{tcsetattr}, che quest'ultimo sia bloccato o ignorato dal
1792   processo chiamante.}
1793
1794 Una prima funzione, che è efficace solo in caso di terminali seriali asincroni
1795 (non fa niente per tutti gli altri terminali), è \funcd{tcsendbreak}; il suo
1796 prototipo è:
1797 \begin{functions}
1798   \headdecl{unistd.h} 
1799   \headdecl{termios.h}  
1800   
1801   \funcdecl{int tcsendbreak(int fd, int duration)} Genera una condizione di
1802   break inviando un flusso di bit nulli.
1803   
1804   \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di
1805     errore, nel qual caso \var{errno} assumerà i valori \errval{EBADF} o
1806     \errval{ENOTTY}.}
1807 \end{functions}
1808
1809 La funzione invia un flusso di bit nulli (che genera una condizione di break)
1810 sul terminale associato a \param{fd}; un valore nullo di \param{duration}
1811 implica una durata del flusso fra 0.25 e 0.5 secondi, un valore diverso da
1812 zero implica una durata pari a \code{duration*T} dove \code{T} è un valore
1813 compreso fra 0.25 e 0.5.\footnote{POSIX specifica il comportamento solo nel
1814   caso si sia impostato un valore nullo per \param{duration}; il comportamento
1815   negli altri casi può dipendere dalla implementazione.}
1816
1817 Le altre funzioni previste da POSIX servono a controllare il comportamento
1818 dell'interazione fra le code associate al terminale e l'utente; la prima è
1819 \funcd{tcdrain}, il cui prototipo è:
1820 \begin{functions}
1821   \headdecl{unistd.h} 
1822   \headdecl{termios.h}  
1823   
1824   \funcdecl{int tcdrain(int fd)} Attende lo svuotamento della coda di output.
1825   
1826   \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di
1827     errore, nel qual caso \var{errno} assumerà i valori \errval{EBADF} o
1828     \errval{ENOTTY}.}
1829 \end{functions}
1830
1831 La funzione blocca il processo fino a che tutto l'output presente sulla coda
1832 di uscita non è stato trasmesso al terminale associato ad \param{fd}. % La
1833                                 % funzione è  un punto di cancellazione per i
1834                                 % programmi multi-thread, in tal caso le
1835                                 % chiamate devono essere protette con dei
1836                                 % gestori di cancellazione. 
1837
1838 Una seconda funzione, \funcd{tcflush}, permette svuotare immediatamente le code
1839 di cancellando tutti i dati presenti al loro interno; il suo prototipo è:
1840 \begin{functions}
1841   \headdecl{unistd.h} \headdecl{termios.h}
1842   
1843   \funcdecl{int tcflush(int fd, int queue)} Cancella i dati presenti
1844   nelle code di ingresso o di uscita.
1845   
1846   \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di
1847     errore, nel qual caso \var{errno} assumerà i valori \errval{EBADF} o
1848     \errval{ENOTTY}.}
1849 \end{functions}
1850
1851 La funzione agisce sul terminale associato a \param{fd}, l'argomento
1852 \param{queue} permette di specificare su quale coda (ingresso, uscita o
1853 entrambe), operare. Esso può prendere i valori riportati in
1854 tab.~\ref{tab:sess_tcflush_queue}, nel caso si specifichi la coda di ingresso
1855 cancellerà i dati ricevuti ma non ancora letti, nel caso si specifichi la coda
1856 di uscita cancellerà i dati scritti ma non ancora trasmessi.
1857
1858 \begin{table}[htb]
1859   \footnotesize
1860   \centering
1861   \begin{tabular}[c]{|l|p{8cm}|}
1862     \hline
1863     \textbf{Valore}& \textbf{Significato}\\
1864     \hline
1865     \hline
1866     \const{TCIFLUSH} & Cancella i dati sulla coda di ingresso. \\
1867     \const{TCOFLUSH} & Cancella i dati sulla coda di uscita. \\
1868     \const{TCIOFLUSH}& Cancella i dati su entrambe le code.\\
1869     \hline
1870   \end{tabular}
1871   \caption{Possibili valori per l'argomento \param{queue} della
1872     funzione \func{tcflush}.} 
1873   \label{tab:sess_tcflush_queue}
1874 \end{table}
1875
1876
1877 L'ultima funzione dell'interfaccia che interviene sulla disciplina di linea è
1878 \funcd{tcflow}, che viene usata per sospendere la trasmissione e la ricezione
1879 dei dati sul terminale; il suo prototipo è:
1880 \begin{functions}
1881   \headdecl{unistd.h} 
1882   \headdecl{termios.h}  
1883   
1884   \funcdecl{int tcflow(int fd, int action)} 
1885   
1886   Sospende e riavvia il flusso dei dati sul terminale.
1887
1888   \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di
1889     errore, nel qual caso \var{errno} assumerà i valori \errval{EBADF} o
1890     \errval{ENOTTY}.}
1891 \end{functions}
1892
1893 La funzione permette di controllare (interrompendo e facendo riprendere) il
1894 flusso dei dati fra il terminale ed il sistema sia in ingresso che in uscita.
1895 Il comportamento della funzione è regolato dall'argomento \param{action}, i
1896 cui possibili valori, e relativa azione eseguita dalla funzione, sono
1897 riportati in tab.~\ref{tab:sess_tcflow_action}.
1898
1899 \begin{table}[htb]
1900    \footnotesize
1901   \centering
1902   \begin{tabular}[c]{|l|p{8cm}|}
1903     \hline
1904     \textbf{Valore}& \textbf{Azione}\\
1905     \hline
1906     \hline
1907     \const{TCOOFF}& Sospende l'output.\\
1908     \const{TCOON} & Riprende un output precedentemente sospeso.\\
1909     \const{TCIOFF}& Il sistema trasmette un carattere di STOP, che 
1910                     fa interrompere la trasmissione dei dati dal terminale.  \\
1911     \const{TCION} & Il sistema trasmette un carattere di START, che 
1912                     fa riprendere la trasmissione dei dati dal terminale.\\
1913     \hline
1914   \end{tabular}
1915   \caption{Possibili valori per l'argomento \param{action} della
1916     funzione \func{tcflow}.} 
1917   \label{tab:sess_tcflow_action}
1918 \end{table}
1919
1920
1921 \subsection{Operare in \textsl{modo non canonico}}
1922 \label{sec:term_non_canonical}
1923
1924 Operare con un terminale in modo canonico è relativamente semplice; basta
1925 eseguire una lettura e la funzione ritornerà quando una il driver del
1926 terminale avrà completato una linea di input. Non è detto che la linea sia
1927 letta interamente (si può aver richiesto un numero inferiore di byte) ma in
1928 ogni caso nessun dato verrà perso, e il resto della linea sarà letto alla
1929 chiamata successiva.
1930
1931 Inoltre in modo canonico la gestione dell'input è di norma eseguita
1932 direttamente dal driver del terminale, che si incarica (a seconda di quanto
1933 impostato con le funzioni viste nei paragrafi precedenti) di cancellare i
1934 caratteri, bloccare e riavviare il flusso dei dati, terminare la linea quando
1935 viene ricevuti uno dei vari caratteri di terminazione (NL, EOL, EOL2, EOF).
1936
1937 In modo non canonico tocca invece al programma gestire tutto quanto, i
1938 caratteri NL, EOL, EOL2, EOF, ERASE, KILL, CR, REPRINT non vengono
1939 interpretati automaticamente ed inoltre, non dividendo più l'input in linee,
1940 il sistema non ha più un limite definito per quando ritornare i dati ad un
1941 processo. Per questo motivo abbiamo visto che in \var{c\_cc} sono previsti due
1942 caratteri speciali, MIN e TIME (specificati dagli indici \const{VMIN} e
1943 \const{VTIME} in \var{c\_cc}) che dicono al sistema di ritornare da una
1944 \func{read} quando è stata letta una determinata quantità di dati o è passato
1945 un certo tempo.
1946
1947 Come accennato nella relativa spiegazione in tab.~\ref{tab:sess_termios_cc},
1948 TIME e MIN non sono in realtà caratteri ma valori numerici. Il comportamento
1949 del sistema per un terminale in modalità non canonica prevede quattro casi
1950 distinti:
1951 \begin{description}
1952 \item[MIN$>0$, TIME$>0$] In questo caso MIN stabilisce il numero minimo di
1953   caratteri desiderati e TIME un tempo di attesa, in decimi di secondo, fra un
1954   carattere e l'altro. Una \func{read} ritorna se vengono ricevuti almeno MIN
1955   caratteri prima della scadenza di TIME (MIN è solo un limite inferiore, se
1956   la funzione ha richiesto un numero maggiore di caratteri ne possono essere
1957   restituiti di più); se invece TIME scade vengono restituiti i byte ricevuti
1958   fino ad allora (un carattere viene sempre letto, dato che il timer inizia a
1959   scorrere solo dopo la ricezione del primo carattere).
1960 \item[MIN$>0$, TIME$=0$] Una \func{read} ritorna solo dopo che sono stati
1961   ricevuti almeno MIN caratteri. Questo significa che una \func{read} può
1962   bloccarsi indefinitamente. 
1963 \item[MIN$=0$, TIME$>0$] In questo caso TIME indica un tempo di attesa dalla
1964   chiamata di \func{read}, la funzione ritorna non appena viene ricevuto un
1965   carattere o scade il tempo. Si noti che è possibile che \func{read} ritorni
1966   con un valore nullo.
1967 \item[MIN$=0$, TIME$=0$] In questo caso una \func{read} ritorna immediatamente
1968   restituendo tutti i caratteri ricevuti. Anche in questo caso può ritornare
1969   con un valore nullo.
1970 \end{description}
1971
1972
1973 %
1974 % Qui c'è da mettere tutta la parte sui terminali virtuali, e la gestione
1975 % degli stessi
1976 %
1977
1978 \section{La gestione dei terminali virtuali}
1979 \label{sec:sess_virtual_terminal}
1980
1981 Da fare.
1982
1983 \subsection{I terminali virtuali}
1984 \label{sec:sess_pty}
1985
1986 Qui vanno spiegati i terminali virtuali, \file{/dev/pty} e compagnia.
1987
1988 \subsection{La funzione \func{openpty}}
1989 \label{sec:sess_openpty}
1990
1991 Qui vanno le cose su \func{openpty} e compagnia.
1992
1993 %%% Local Variables: 
1994 %%% mode: latex
1995 %%% TeX-master: "gapil"
1996 %%% End: