+\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{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{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{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.
+\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{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{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{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.
+\end{basedescript}
+
+
+\begin{basedescript}{\desclabelwidth{2.cm}\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{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{EIDRM} \textit{Identifier removed}.] Indica che l'oggetto del
+ \textit{SysV IPC} a cui si fa riferimento è stato cancellato.
+
+\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 valore però viene
+ usato come sinonimo di \errcode{ENOATTR}.
+
+\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{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}