X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=session.tex;h=6fd9027748b84088c909196cb9eaf839571b4ac1;hp=a4dad38f30623bb9a69677cd711474c9080376b3;hb=4e566a40155b75d19f8cf3f3207e4a3df272245d;hpb=dcf2c2df897955ff3503a7c426025457ab456fd7 diff --git a/session.tex b/session.tex index a4dad38..6fd9027 100644 --- a/session.tex +++ b/session.tex @@ -336,13 +336,13 @@ divenuto un nuovo leader di sessione dovrà riottenere\footnote{solo quando ciò sempre vera.}, un terminale di controllo. In generale questo viene fatto automaticamente dal sistema\footnote{a meno di non avere richiesto esplicitamente che questo non diventi un terminale di controllo con il flag - \const{O\_NOCTTY} (vedi sez.~\ref{sec:file_open}). In questo Linux segue la - semantica di SVr4; BSD invece richiede che il terminale venga allocato - esplicitamente con una \func{ioctl} con il comando \const{TIOCSCTTY}.} -quando viene aperto il primo terminale (cioè uno dei vari file di dispositivo -\file{/dev/tty*}) che diventa automaticamente il terminale di controllo, -mentre il processo diventa il \textsl{processo di controllo} di quella -sessione. + \const{O\_NOCTTY} (vedi sez.~\ref{sec:file_open_close}). In questo Linux + segue la semantica di SVr4; BSD invece richiede che il terminale venga + allocato esplicitamente con una \func{ioctl} con il comando + \const{TIOCSCTTY}.} quando viene aperto il primo terminale (cioè uno dei +vari file di dispositivo \file{/dev/tty*}) che diventa automaticamente il +terminale di controllo, mentre il processo diventa il \textsl{processo di + controllo} di quella sessione. In genere (a meno di redirezioni) nelle sessioni di lavoro questo terminale è associato ai file standard (di input, output ed error) dei processi nella @@ -507,7 +507,7 @@ connessione di rete. Dato che i concetti base sono gli stessi, e dato che alla fine le differenze sono\footnote{in generale nel caso di login via rete o di terminali lanciati dall'interfaccia grafica cambia anche il processo da cui ha origine l'esecuzione della shell.} nel dispositivo cui il kernel associa -i file standard (vedi sez.~\ref{sec:file_std_descr}) per l'I/O, tratteremo +i file standard (vedi tab.~\ref{tab:file_std_files}) per l'I/O, tratteremo solo il caso classico del terminale. Abbiamo già brevemente illustrato in sez.~\ref{sec:intro_kern_and_sys} le @@ -608,10 +608,10 @@ funzioni con i privilegi di amministratore, tutti gli \ids{UID} ed i \ids{GID} A questo punto \cmd{login} provvederà (fatte salve eventuali altre azioni iniziali, come la stampa di messaggi di benvenuto o il controllo della posta) ad eseguire con un'altra \func{exec} la shell, che si troverà con un ambiente -già pronto con i file standard di sez.~\ref{sec:file_std_descr} impostati sul +già pronto con i file standard di tab.~\ref{tab:file_std_files} impostati sul terminale, e pronta, nel ruolo di leader di sessione e di processo di controllo per il terminale, a gestire l'esecuzione dei comandi come illustrato -in sez.~\ref{sec:sess_job_control_overview}. +in sez.~\ref{sec:sess_job_control_overview}. Dato che il processo padre resta sempre \cmd{init} quest'ultimo potrà provvedere, ricevendo un \signal{SIGCHLD} all'uscita della shell quando la @@ -1193,8 +1193,8 @@ disco e agli altri dispositivi. -\subsection{L'architettura} -\label{sec:term_design} +\subsection{L'architettura dell'I/O su terminale} +\label{sec:term_io_design} I terminali sono una classe speciale di dispositivi a caratteri (si ricordi la classificazione di sez.~\ref{sec:file_file_types}); un terminale ha infatti una @@ -1232,6 +1232,9 @@ una delle principali infatti è che essi prevedono due modalità di operazione, dette rispettivamente ``\textsl{modo canonico}'' e ``\textsl{modo non canonico}'', che hanno dei comportamenti nettamente diversi. +% TODO: inserire qui il comportamento di read relativo all'errore EIO sulla +% lettura in background??? + La modalità preimpostata all'apertura del terminale è quella canonica, in cui le operazioni di lettura vengono sempre effettuate assemblando i dati in una linea;\footnote{per cui eseguendo una \func{read} su un terminale in modo @@ -1641,7 +1644,7 @@ valore. e che le linee di controllo del modem devono essere ignorate. Se non impostato effettuando una chiamata ad \func{open} senza aver specificato il flag di - \const{O\_NOBLOCK} si bloccherà il processo finché + \const{O\_NONBLOCK} si bloccherà il processo finché non si è stabilita una connessione con il modem; inoltre se viene rilevata una disconnessione viene inviato un segnale di \signal{SIGHUP} al processo di controllo del @@ -2396,7 +2399,7 @@ Qui vanno le cose su \func{openpty} e compagnia. % LocalWords: BRKINT IGNCR carriage return newline ICRNL INLCR IUCLC IXON NL % LocalWords: IXANY IXOFF IMAXBEL iflag OPOST CR OCRNL OLCUC ONLCR ONOCR OFILL % LocalWords: ONLRET OFDEL NLDLY CRDLY TABDLY BSDLY backspace BS VTDLY FFDLY -% LocalWords: form feed FF oflag CLOCAL NOBLOCK of HUPCL CREAD CSTOPB PARENB +% LocalWords: form feed FF oflag CLOCAL of HUPCL CREAD CSTOPB PARENB % LocalWords: PARODD CSIZE CS CBAUD CBAUDEX CIBAUD CRTSCTS RTS CTS cflag ECHO % LocalWords: ICANON ECHOE ERASE ECHOPRT ECHOK ECHOKE ECHONL ECHOCTL ctrl ISIG % LocalWords: INTR QUIT SUSP IEXTEN EOL LNEXT REPRINT WERASE NOFLSH and TOSTOP