+In questa sezione sono raccolti i codici restituiti dalle \textit{system call}
+attinenti ad errori che riguardano operazioni specifiche relative alla
+gestione dei processi.
+
+\begin{basedescript}{\desclabelwidth{1.5cm}\desclabelstyle{\nextlinelabel}}
+\item[\errcode{E2BIG} \textit{Argument list too long}.] La lista degli
+ argomenti passati è troppo lunga: è una condizione prevista da POSIX quando
+ la lista degli argomenti passata ad una delle funzioni \func{exec} occupa
+ troppa memoria.
+\item[\errcode{ECHILD} \textit{There are no child processes}.] Non esistono
+ processi figli di cui attendere la terminazione. Viene rilevato dalle
+ funzioni \func{wait} e \func{waitpid} (vedi sez.~\ref{sec:proc_wait}).
+\item[\errcode{EPROCLIM} \textit{Too many processes}.] Il limite dell'utente
+ per nuovi processi (vedi sez.~\ref{sec:sys_resource_limit}) sarà ecceduto
+ alla prossima \func{fork}; è un codice di errore di BSD, che non viene
+ utilizzato al momento su Linux.
+\item[\errcode{ESRCH} \textit{No process matches the specified process ID}.]
+ Non esiste un processo o un \textit{process group} corrispondenti al valore
+ dell'identificativo specificato.
+\end{basedescript}
+
+
+\section{Gli errori di rete}
+\label{sec:err_network}
+
+In questa sezione sono raccolti i codici restituiti dalle \textit{system call}
+attinenti ad errori che riguardano operazioni specifiche relative alla
+gestione dei socket e delle connessioni di rete.
+
+\begin{basedescript}{\desclabelwidth{1.5cm}\desclabelstyle{\nextlinelabel}}
+\item[\errcode{EADDRINUSE} \textit{Address already in use}.] L'indirizzo del
+ socket richiesto è già utilizzato (ad esempio si è eseguita \func{bind}
+ su una porta già in uso).
+\item[\errcode{EADDRNOTAVAIL} \textit{Cannot assign requested
+ address}.] L'indirizzo richiesto non è disponibile (ad esempio si
+ è cercato di dare al socket un nome che non corrisponde al nome
+ della stazione locale), o l'interfaccia richiesta non esiste.
+\item[\errcode{EAFNOSUPPORT} \textit{Address family not supported by
+ protocol}.] Famiglia di indirizzi non supportata. La famiglia di
+ indirizzi richiesta non è supportata, o è inconsistente con il protocollo
+ usato dal socket.
+\item[\errcode{ECONNABORTED} \textit{Software caused connection abort}.] Una
+ connessione è stata abortita localmente.
+\item[\errcode{ECONNREFUSED} \textit{Connection refused}.] Un host remoto ha
+ rifiutato la connessione (in genere dipende dal fatto che non c'è un server
+ per soddisfare il servizio richiesto).
+\item[\errcode{ECONNRESET} \textit{Connection reset by peer}.] Una connessione
+ è stata chiusa per ragioni fuori dal controllo dell'host locale, come il
+ riavvio di una macchina remota o un qualche errore non recuperabile sul
+ protocollo.
+\item[\errcode{EDESTADDRREQ} \textit{Destination address required}.] Non c'è
+ un indirizzo di destinazione predefinito per il socket. Si ottiene questo
+ errore mandando dato su un socket senza connessione senza averne prima
+ specificato una destinazione.
+\item[\errcode{EISCONN} \textit{Transport endpoint is already connected}.] Si
+ è tentato di connettere un socket che è già connesso.
+\item[\errcode{EMSGSIZE} \textit{Message too long}.] Le dimensioni di un
+ messaggio inviato su un socket sono eccedono la massima lunghezza supportata.
+\item[\errcode{ENETDOWN} \textit{Network is down}.] L'operazione sul socket è
+ fallita perché la rete è sconnessa.
+\item[\errcode{ENETRESET} \textit{Network dropped connection because of
+ reset}.] Una connessione è stata cancellata perché l'host remoto è
+ caduto.
+\item[\errcode{ENETUNREACH} \textit{Network is unreachable}.] L'operazione è
+ fallita perché l'indirizzo richiesto è irraggiungibile (ad esempio la
+ sottorete della stazione remota è irraggiungibile).
+\item[\errcode{ENOBUFS} \textit{No buffer space available}.] Tutti i buffer per
+ le operazioni di I/O del kernel sono occupati. In generale questo errore è
+ sinonimo di \errcode{ENOMEM}, ma attiene alle funzioni di input/output. In
+ caso di operazioni sulla rete si può ottenere questo errore invece
+ dell'altro.
+\item[\errcode{ENOPROTOOPT} \textit{Protocol not available}.] Protocollo non
+ disponibile. Si è richiesta un'opzione per il socket non disponibile con il
+ protocollo usato.
+\item[\errcode{ENOTCONN} \textit{Transport endpoint is not connected}.] Il
+ socket non è connesso a niente. Si ottiene questo errore quando si cerca di
+ trasmettere dati su un socket senza avere specificato in precedenza la loro
+ destinazione. Nel caso di socket senza connessione (ad esempio socket UDP)
+ l'errore che si ottiene è \errcode{EDESTADDRREQ}.
+\item[\errcode{ENOTSOCK} \textit{Socket operation on non-socket}.] Si è
+ tentata un'operazione su un file descriptor che non è un socket quando
+ invece era richiesto un socket.
+\item[\errcode{EOPNOTSUPP} \textit{Operation not supported on transport
+ endpoint}.] L'operazione richiesta non è supportata. Alcune funzioni non
+ hanno senso per tutti i tipi di socket, ed altre non sono implementate per
+ tutti i protocolli di trasmissione. Questo errore quando un socket non
+ supporta una particolare operazione, e costituisce una indicazione generica
+ che il server non sa cosa fare per la chiamata effettuata.
+\item[\errcode{EPFNOSUPPORT} \textit{Protocol family not supported}.] Famiglia
+ di protocolli non supportata. La famiglia di protocolli richiesta non è
+ supportata.
+\item[\errcode{EPROTONOSUPPORT} \textit{Protocol not supported}.] Protocollo
+ non supportato. Il tipo di socket non supporta il protocollo richiesto (un
+ probabile errore nella specificazione del protocollo).
+\item[\errcode{EPROTOTYPE} \textit{Protocol wrong type for socket}.]
+ Protocollo sbagliato per il socket. Il socket usato non supporta il
+ protocollo di comunicazione richiesto.
+\item[\errcode{ESHUTDOWN} \textit{Cannot send after transport endpoint
+ shutdown}.] Il socket su cui si cerca di inviare dei dati ha avuto uno
+ shutdown.
+\item[\errcode{ESOCKTNOSUPPORT} \textit{Socket type not supported}.] Socket
+ non supportato. Il tipo di socket scelto non è supportato.
+\item[\errcode{ETIMEDOUT} \textit{Connection timed out}.] Un'operazione sul
+ socket non ha avuto risposta entro il periodo di timeout.
+\item[\errcode{ETOOMANYREFS} \textit{Too many references: cannot splice}.] La
+ \acr{glibc} dice ???
+\end{basedescript}
+
+
+\section{Errori generici}
+
+In questa sezione sono raccolti i codici restituiti dalle \textit{system call}
+attinenti ad errori generici, si trovano qui tutti i codici di errore non
+specificati nelle sezioni precedenti.
+
+\begin{basedescript}{\desclabelwidth{1.5cm}\desclabelstyle{\nextlinelabel}}
+\item[\errcode{EAGAIN} \textit{Resource temporarily unavailable}.] La funzione è
+ fallita ma potrebbe funzionare se la chiamata fosse ripetuta. Questo errore
+ accade in due tipologie di situazioni:
+ \begin{itemize}
+ \item Si è effettuata un'operazione che si sarebbe bloccata su un oggetto
+ che è stato posto in modalità non bloccante. Nei vecchi sistemi questo era
+ un codice diverso, \errcode{EWOULDBLOCK}. In genere questo ha a che fare
+ con file o socket, per i quali si può usare la funzione \func{select} per
+ vedere quando l'operazione richiesta (lettura, scrittura o connessione)
+ diventa possibile.
+ \item Indica la carenza di una risorsa di sistema che non è al momento
+ disponibile (ad esempio \func{fork} può fallire con questo errore se si è
+ esaurito il numero di processi contemporanei disponibili). La ripetizione
+ della chiamata in un periodo successivo, in cui la carenza della risorsa
+ richiesta può essersi attenuata, può avere successo. Questo tipo di
+ carenza è spesso indice di qualcosa che non va nel sistema, è pertanto
+ opportuno segnalare esplicitamente questo tipo di errori.
+ \end{itemize}
+\item[\errcode{EALREADY} \textit{Operation already in progress}.] L'operazione è
+ già in corso. Si è tentata un'operazione già in corso su un oggetto posto in
+ modalità non-bloccante.
+\item[\errcode{EDEADLK} \textit{Deadlock avoided}.] L'allocazione di una
+ risorsa avrebbe causato un \textit{deadlock}. Non sempre il sistema è in
+ grado di riconoscere queste situazioni, nel qual caso si avrebbe il blocco.
+\item[\errcode{EFAULT} \textit{Bad address}.] Una stringa passata come
+ argomento è fuori dello spazio di indirizzi del processo, in genere questa
+ situazione provoca direttamente l'emissione di un segnale di \textit{segment
+ violation} (\signal{SIGSEGV}).
+\item[\errcode{EDOM} \textit{Domain error}.] È usato dalle funzioni matematiche
+ quando il valore di un argomento è al di fuori dell'intervallo in cui esse
+ sono definite.
+\item[\errcode{EILSEQ} \textit{Illegal byte sequence}.] Nella decodifica di un
+ carattere esteso si è avuta una sequenza errata o incompleta o si è
+ specificato un valore non valido.
+\item[\errcode{EINPROGRESS} \textit{Operation now in progress}.] Operazione in
+ corso. Un'operazione che non può essere completata immediatamente è stata
+ avviata su un oggetto posto in modalità non-bloccante. Questo errore viene
+ riportato per operazioni che si dovrebbero sempre bloccare (come per una
+ \func{connect}) e che pertanto non possono riportare \errcode{EAGAIN},
+ l'errore indica che l'operazione è stata avviata correttamente e occorrerà
+ del tempo perché si possa completare. La ripetizione della chiamata darebbe
+ luogo ad un errore \errcode{EALREADY}.
+\item[\errcode{EINTR} \textit{Interrupted function call}.] Una funzione di
+ libreria è stata interrotta. In genere questo avviene causa di un segnale
+ asincrono al processo che impedisce la conclusione della chiamata, la
+ funzione ritorna con questo errore una volta che si sia correttamente
+ eseguito il gestore del segnale. In questo caso è necessario ripetere la
+ chiamata alla funzione.
+\item[\errcode{EINVAL} \textit{Invalid argument}.] Errore utilizzato per
+ segnalare vari tipi di problemi dovuti all'aver passato un argomento
+ sbagliato ad una funzione di libreria.
+\item[\errcode{ENOMEM} \textit{No memory available}.] Il kernel non è in grado
+ di allocare ulteriore memoria per completare l'operazione richiesta.
+\item[\errcode{ENOSYS} \textit{Function not implemented}.] Indica che la
+ funzione non è supportata o nelle librerie del C o nel kernel. Può dipendere
+ sia dalla mancanza di una implementazione, che dal fatto che non si è
+ abilitato l'opportuno supporto nel kernel; nel caso di Linux questo può
+ voler dire anche che un modulo necessario non è stato caricato nel sistema.
+\item[\errcode{ENOTSUP} \textit{Not supported}.] Una funzione ritorna questo
+ errore quando gli argomenti sono validi ma l'operazione richiesta non è
+ supportata. Questo significa che la funzione non implementa quel particolare
+ comando o opzione o che, in caso di oggetti specifici (file descriptor o
+ altro) non è in grado di supportare i parametri richiesti.
+\item[\errcode{ERANGE} \textit{Range error}.] È usato dalle funzioni
+ matematiche quando il risultato dell'operazione non è rappresentabile nel
+ valore di ritorno a causa di un overflow o di un underflow.
+\item[\errcode{EWOULDBLOCK} \textit{Operation would block}.] Indica che
+ l'operazione richiesta si bloccherebbe, ad esempio se si apre un file in
+ modalità non bloccante, una \func{read} restituirebbe questo errore per
+ indicare che non ci sono dati; in Linux è identico a \errcode{EAGAIN}, ma in
+ altri sistemi può essere specificato un valore diverso.
+\end{basedescript}
+
+
+\begin{basedescript}{\desclabelwidth{1.5cm}\desclabelstyle{\nextlinelabel}}
+% definiti nel manuale delle glibc ma inesistenti in linux/errno.h
+%\item[\errcode{EBADRPC} \textit{}.]
+%\item[\errcode{ERPCMISMATCH} \textit{}.]
+%\item[\errcode{EPROGUNAVAIL} \textit{}.]
+%\item[\errcode{EPROGMISMATCH} \textit{}.]
+%\item[\errcode{EPROCUNAVAIL} \textit{}.]
+%\item[\errcode{EAUTH} \textit{}.]
+%\item[\errcode{ENEEDAUTH} \textit{}.]
+%\item[\errcode{EBACKGROUND} \textit{}.]
+%\item[\errcode{EDIED} \textit{}.]
+% questi sembrano scherzi, sempre dal manuale delle glibc...
+%\item[\errcode{ED} \textit{}.]
+%\item[\errcode{EGREGIOUS} \textit{}.]
+%\item[\errcode{EIEIO} \textit{}.]
+%\item[\errcode{EGRATUITOUS} \textit{} roba di Hurd, pare.
+
+
+\item[\errcode{EBADMSG} \textit{Not a data message}.] Definito da POSIX come
+errore che arriva ad una funzione di lettura che opera su uno stream. Non
+essendo gli stream definiti su Linux il kernel non genera mai questo tipo di
+messaggio.
+
+\item[\errcode{EIDRM} \textit{Identifier removed}.] Indica che l'oggetto del
+ \textit{SysV IPC} a cui si fa riferimento è stato cancellato.
+
+\item[\errcode{EMULTIHOP} \textit{Multihop attempted}.] Definito da POSIX come
+ errore dovuto all'accesso a file remoti attraverso più macchine, quando ciò
+ non è consentito. Non viene mai generato su Linux.
+
+\item[\errcode{ENOATTR} \textit{No such attribute}.] È un codice di errore
+ specifico di Linux utilizzato dalle funzioni per la gestione degli attributi
+ estesi dei file (vedi sez.~\ref{sec:file_xattr}) quando il nome
+ dell'attributo richiesto non viene trovato.
+
+\item[\errcode{ENODATA} \textit{No data available}.] Viene indicato da POSIX
+ come restituito da una \func{read} eseguita su un file descriptor in
+ modalità non bloccante quando non ci sono dati. In realtà in questo caso su
+ Linux viene utilizzato \errcode{EAGAIN}. Lo stesso valore però viene usato
+ come sinonimo di \errcode{ENOATTR}.
+
+\item[\errcode{ENOLINK} \textit{Link has been severed}.] È un errore il cui
+ valore è indicato come \textsl{riservato} nelle \textit{Single Unix
+ Specification}. Dovrebbe indicare l'impossibilità di accedere ad un file a
+ causa di un errore sul collegamento di rete, ma non ci sono indicazioni
+ precise del suo utilizzo. Per quanto riguarda Linux viene riportato nei
+ sorgenti del kernel in alcune operazioni relative ad operazioni di rete.
+
+\item[\errcode{ENOMSG} \textit{No message of desired type}.] Indica che in una
+ coda di messaggi del \textit{SysV IPC} non è presente nessun messaggio del
+ tipo desiderato.
+
+\item[\errcode{ENOSR} \textit{Out of streams resources}.] Errore relativo agli
+ \textit{STREAMS}, che indica l'assenza di risorse sufficienti a completare
+ l'operazione richiesta. Quella degli \textit{STREAMS}\footnote{che non vanno
+ confusi con gli \textit{stream} di sez.~\ref{sec:files_std_interface}.} è
+ interfaccia di programmazione originaria di System V, che non è implementata
+ da Linux, per cui questo errore non viene utilizzato.
+
+\item[\errcode{ENOSTR} \textit{Device not a stream}.] Altro errore relativo
+ agli \textit{STREAMS}, anch'esso non utilizzato da Linux.
+
+\item[\errcode{EOVERFLOW} \textit{Value too large for defined data type}.] Si è
+ chiesta la lettura di un dato dal \textit{SysV IPC} con \const{IPC\_STAT} ma
+ il valore eccede la dimensione usata nel buffer di lettura.
+
+\item[\errcode{EPROTO} \textit{Protocol error}.] Indica che c'è stato un errore
+ nel protocollo di rete usato dal socket; viene usato come errore generico
+ dall'interfaccia degli \textit{STREAMS} quando non si è in grado di
+ specificare un altro codice di errore che esprima più accuratamente la
+ situazione.
+
+\item[\errcode{ETIME} \textit{Timer expired}.] Indica che è avvenuto un timeout
+ nell'accesso ad una risorsa (ad esempio un semaforo). Compare nei sorgenti
+ del kernel (in particolare per le funzioni relativa al bus USB) come
+ indicazione di una mancata risposta di un dispositivo, con una descrizione
+ alternativa di \textit{Device did not respond}.
+\end{basedescript}
+
+
+
+% \section{Errori del kernel}
+% \label{sec:err_kernel_err}