X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=errors.tex;h=b8b6a8fe264c779d153d257b6eca1367ea817d00;hp=adecb8ef65a92f70c95e368485962e1e71742fff;hb=54a3f08494d976cbc6c0fd49926f9cf707ab2a6a;hpb=b38fb9f5c8fb8360f7ac296baa8f4a0bdd692d1c diff --git a/errors.tex b/errors.tex index adecb8e..b8b6a8f 100644 --- a/errors.tex +++ b/errors.tex @@ -1,6 +1,6 @@ %% errors.tex %% -%% Copyright (C) 2000-2005 Simone Piccardi. Permission is granted to +%% Copyright (C) 2000-2019 Simone Piccardi. Permission is granted to %% copy, distribute and/or modify this document under the terms of the GNU Free %% Documentation License, Version 1.1 or any later version published by the %% Free Software Foundation; with the Invariant Sections being "Un preambolo", @@ -8,399 +8,524 @@ %% license is included in the section entitled "GNU Free Documentation %% License". %% + \chapter{I codici di errore} \label{cha:errors} Si riportano in questa appendice tutti i codici di errore. Essi sono -accessibili attraverso l'inclusione del file di header \file{errno.h}, che +accessibili attraverso l'inclusione del file di header \headfile{errno.h}, che definisce anche la variabile globale \var{errno}. Per ogni errore definito riporteremo la stringa stampata da \func{perror} ed una breve spiegazione. Si -tenga presente che spiegazioni più particolareggiate, qualora necessarie per -il caso specifico, possono essere trovate nella descrizione del prototipo -della funzione. +tenga presente che spiegazioni più particolareggiate del significato +dell'errore, qualora necessarie per casi specifici, possono essere trovate +nella descrizione del prototipo della funzione per cui detto errore si è +verificato. I codici di errore sono riportati come costanti di tipo \ctyp{int}, i valori delle costanti sono definiti da macro di preprocessore nel file citato, e -possono variare da architettura a architettura; è pertanto necessario +possono variare da architettura a architettura; è pertanto necessario riferirsi ad essi tramite i nomi simbolici. Le funzioni \func{perror} e \func{strerror} (vedi sez.~\ref{sec:sys_strerror}) possono essere usate per -ottenere dei messaggi di errore più espliciti. +ottenere dei messaggi di errore più espliciti. \section{Gli errori dei file} \label{sec:err_file_errors} -In questa sezione sono raccolti i codici restituiti dalle funzioni di libreria +In questa sezione sono raccolti i codici restituiti dalle \textit{system call} attinenti ad errori che riguardano operazioni specifiche relative alla gestione dei file. -\begin{description} -\item \errcode{EPERM} \textit{Operation not permitted}. L'operazione non è - permessa: solo il proprietario del file o un processo con sufficienti - privilegi può eseguire l'operazione. -\item \errcode{ENOENT} \textit{No such file or directory}. Il file indicato - dal \itindex{pathname}\textit{pathname} non esiste: o una delle - componenti non esiste o il \textit{pathname} contiene un link simbolico - spezzato. Errore tipico di un riferimento ad un file che si suppone - erroneamente essere esistente. -\item \errcode{EIO} \textit{Input/output error}. Errore di input/output: usato - per riportare errori hardware in lettura/scrittura su un dispositivo. -\item \errcode{ENXIO} \textit{No such device or address}. Dispositivo - inesistente: il sistema ha tentato di usare un dispositivo attraverso il - file specificato, ma non lo ha trovato. Può significare che il file di - dispositivo non è corretto, che il modulo relativo non è stato caricato nel - kernel, o che il dispositivo è fisicamente assente o non funzionante. -\item \errcode{ENOEXEC} \textit{Invalid executable file format}. Il file non ha - un formato eseguibile, è un errore riscontrato dalle funzioni \func{exec}. -\item \errcode{EBADF} \textit{Bad file descriptor}. File descriptor non valido: - si è usato un file descriptor inesistente, o aperto in sola lettura per - scrivere, o viceversa, o si è cercato di eseguire un'operazione non +\begin{basedescript}{\desclabelwidth{1.5cm}\desclabelstyle{\nextlinelabel}} +\item[\errcode{EACCES} \textit{Permission denied}.] Permesso negato; l'accesso + al file o alla directory non è consentito: i permessi del file o della + directory o quelli necessari ad attraversare un \textit{pathname} non + consentono l'operazione richiesta. +\item[\errcode{EBADF} \textit{Bad file descriptor}.] File descriptor non + valido: si è usato un file descriptor inesistente, o aperto in sola lettura + per scrivere, o viceversa, o si è cercato di eseguire un'operazione non consentita per quel tipo di file descriptor. -\item \errcode{EACCES} \textit{Permission denied}. Permesso negato; l'accesso - al file non è consentito: i permessi del file o della directory non - consentono l'operazione. -\item \errcode{ELOOP} \textit{Too many symbolic links encountered}. Ci sono - troppi link simbolici nella risoluzione di un - \itindex{pathname}\textit{pathname}. -\item \errcode{ENAMETOOLONG} \textit{File name too long}. Si è indicato un - \itindex{pathname}\textit{pathname} troppo lungo. -\item \errcode{ENOTBLK} \textit{Block device required}. Si è specificato un - file che non è un \textit{block device} in un contesto in cui era necessario - specificare un \textit{block device} (ad esempio si è tentato di montare un - file ordinario). -\item \errcode{EEXIST} \textit{File exists}. Si è specificato un file esistente - in un contesto in cui ha senso solo specificare un nuovo file. -\item \errcode{EBUSY} \textit{Resource busy}. Una risorsa di sistema che non - può essere condivisa è occupata. Ad esempio si è tentato di cancellare la - directory su cui si è montato un filesystem. -\item \errcode{EXDEV} \textit{Cross-device link}. Si è tentato di creare un - link diretto che attraversa due filesystem differenti. -\item \errcode{ENODEV} \textit{No such device}. Si è indicato un tipo di device - sbagliato ad una funzione che ne richiede uno specifico. -\item \errcode{ENOTDIR} \textit{Not a directory}. Si è specificato un file che - non è una directory in una operazione che richiede una directory. -\item \errcode{EISDIR} \textit{Is a directory}. Il file specificato è una - directory, non può essere aperto in scrittura, né si possono creare o +\item[\errcode{EBUSY} \textit{Resource busy}.] Una risorsa di sistema che non + può essere condivisa è occupata. Ad esempio si è tentato di cancellare la + directory su cui si è montato un filesystem. +\item[\errcode{EDQUOT} \textit{Quota exceeded}.] Si è ecceduta la quota di + disco dell'utente, usato sia per lo spazio disco che per il numero di + \textit{inode}. +\item[\errcode{EEXIST} \textit{File exists}.] Si è specificato un file + esistente in un contesto in cui ha senso solo specificare un nuovo file. +\item[\errcode{EFBIG} \textit{File too big}.] Si è ecceduto il limite imposto + dal sistema sulla dimensione massima che un file può avere. +\item[\errcode{EFTYPE} \textit{Inappropriate file type or format}.] Il file è + di tipo sbagliato rispetto all'operazione richiesta o un file di dati ha un + formato sbagliato. Alcuni sistemi restituiscono questo errore quando si + cerca di impostare lo \textit{sticky bit} su un file che non è una + directory. +\item[\errcode{EIO} \textit{Input/output error}.] Errore di input/output: + usato per riportare errori hardware in lettura/scrittura su un dispositivo. +\item[\errcode{EISDIR} \textit{Is a directory}.] Il file specificato è una + directory; non può essere aperto in scrittura, né si possono creare o rimuovere link diretti ad essa. -\item \errcode{EMFILE} \textit{Too many open files}. Il processo corrente ha - troppi file aperti e non può aprirne altri. Anche i descrittori duplicati - vengono tenuti in conto\footnote{Il numero massimo di file aperti è - controllabile dal sistema, in Linux si può usare il comando - \cmd{ulimit}.}. -\item \errcode{ENFILE} \textit{File table overflow}. Ci sono troppi file aperti - nel sistema. -\item \errcode{ENOTTY} \textit{Not a terminal}. Si è tentata una operazione di - controllo relativa ad un terminale su un file che non lo è. -\item \errcode{ETXTBSY} \textit{Text file busy}. Si è cercato di eseguire un - file che è aperto in scrittura, o scrivere un file che è in esecuzione. -\item \errcode{EFBIG} \textit{File too big}. Si è ecceduto il limite imposto - dal sistema sulla dimensione massima che un file può avere. -\item \errcode{ENOSPC} \textit{No space left on device}. la directory in cui si - vuole creare il link non ha spazio per ulteriori voci. -\item \errcode{ESPIPE} \textit{Invalid seek operation}. -\item \errcode{EROFS} \textit{Read-only file system}. il file risiede su un - filesystem read-only. -\item \errcode{EMLINK} \textit{Too many links}. Ci sono troppi link al file (il - numero massimo è specificato dalla variabile \const{LINK\_MAX}, vedi - sez.~\ref{sec:sys_limits}). -\item \errcode{EPIPE} \textit{Broken pipe}. Non c'è un processo che stia - leggendo l'altro capo della pipe. Ogni funzione che restituisce questo - errore genera anche un segnale \const{SIGPIPE}, la cui azione predefinita è - terminare il programma; pertanto non si potrà vedere questo errore fintanto - che \const{SIGPIPE} non viene gestito o bloccato. -\item \errcode{ENOTEMPTY} \textit{Directory not empty}. La directory non è - vuota quando l'operazione richiede che lo sia. È l'errore tipico che si ha +\item[\errcode{ELOOP} \textit{Too many symbolic links encountered}.] Ci sono + troppi link simbolici nella risoluzione di un \textit{pathname}. +\item[\errcode{EMFILE} \textit{Too many open files}.] Il processo corrente ha + troppi file aperti e non può aprirne altri. Anche i descrittori duplicati ed + i socket vengono tenuti in conto.\footnote{il numero massimo di file aperti + è controllabile dal sistema; in Linux si può impostare usando il comando + \cmd{ulimit}, esso è in genere indicato dalla costante \const{OPEN\_MAX}, + vedi sez.~\ref{sec:sys_limits}.} +\item[\errcode{EMLINK} \textit{Too many links}.] Ci sono già troppi link al + file, il numero massimo è specificato dalla variabile \const{LINK\_MAX}, + vedi sez.~\ref{sec:sys_limits}. +\item[\errcode{ENAMETOOLONG} \textit{File name too long}.] Si è indicato un + \textit{pathname} troppo lungo per un file o una directory. +\item[\errcode{ENFILE} \textit{File table overflow}.] Il sistema ha troppi + file aperti in contemporanea. Si tenga presente che anche i socket contano + come file. Questa è una condizione temporanea, ed è molto difficile che si + verifichi nei sistemi moderni. +\item[\errcode{ENODEV} \textit{No such device}.] Si è indicato un tipo di + device sbagliato ad una funzione che ne richiede uno specifico. +\item[\errcode{ENOENT} \textit{No such file or directory}.] Il file indicato + dal \textit{pathname} non esiste: o una delle componenti non esiste o il + \textit{pathname} contiene un link simbolico spezzato. Errore tipico di un + riferimento ad un file che si suppone erroneamente essere esistente. +\item[\errcode{ENOEXEC} \textit{Invalid executable file format}.] Il file non + ha un formato eseguibile, è un errore riscontrato dalle funzioni + \func{exec}. +\item[\errcode{ENOLCK} \textit{No locks available}.] È usato dalle utilità per + la gestione del file locking; non viene generato da un sistema GNU, ma può + risultare da un'operazione su un server NFS di un altro sistema. +\item[\errcode{ENOSPC} \textit{No space left on device}.] La directory in cui + si vuole creare il link non ha spazio per ulteriori voci, o si è cercato di + scrivere o di creare un nuovo file su un dispositivo che è già pieno. +\item[\errcode{ENOTBLK} \textit{Block device required}.] Si è specificato un + file che non è un \textit{block device} in un contesto in cui era necessario + specificare un \textit{block device} (ad esempio si è tentato di montare un + file ordinario). +\item[\errcode{ENOTDIR} \textit{Not a directory}.] Si è specificato un file + che non è una directory in una operazione che richiede una directory. +\item[\errcode{ENOTEMPTY} \textit{Directory not empty}.] La directory non è + vuota quando l'operazione richiede che lo sia. È l'errore tipico che si ha quando si cerca di cancellare una directory contenente dei file. -\item \errcode{EUSERS} \textit{Too many users}. Troppi utenti, il sistema delle - quote rileva troppi utenti nel sistema. -\item \errcode{EDQUOT} \textit{Quota exceeded}. Si è ecceduta la quota di disco - dell'utente. -\item \errcode{ESTALE} \textit{Stale NFS file handle}. Indica un problema - interno a NFS causato da cambiamenti del filesystem del sistema remoto. Per - recuperare questa condizione in genere è necessario smontare e rimontare il - filesystem NFS. -\item \errcode{EREMOTE} \textit{Object is remote}. Si è fatto un tentativo di - montare via NFS un filesystem remoto con un nome che già specifica un +\item[\errcode{ENOTTY} \textit{Not a terminal}.] Si è tentata una operazione + di controllo relativa ad un terminale su un file che non lo è. +\item[\errcode{ENXIO} \textit{No such device or address}.] Dispositivo + inesistente: il sistema ha tentato di usare un dispositivo attraverso il + file specificato, ma non lo ha trovato. Può significare che il file di + dispositivo non è corretto, che il modulo relativo non è stato caricato nel + kernel, o che il dispositivo è fisicamente assente o non funzionante. +\item[\errcode{EPERM} \textit{Operation not permitted}.] L'operazione non è + permessa: solo il proprietario del file o un processo con sufficienti + privilegi può eseguire l'operazione. +\item[\errcode{EPIPE} \textit{Broken pipe}.] Non c'è un processo che stia + leggendo l'altro capo della \textit{pipe}. Ogni funzione che restituisce + questo errore genera anche un segnale \signal{SIGPIPE}, la cui azione + predefinita è terminare il programma; pertanto non si potrà vedere questo + errore fintanto che \signal{SIGPIPE} non viene gestito o bloccato. +\item[\errcode{EREMOTE} \textit{Object is remote}.] Si è fatto un tentativo di + montare via NFS un filesystem remoto con un nome che già specifica un filesystem montato via NFS. -\item \errcode{ENOLCK} \textit{No locks available}. È usato dalle utilità per - la gestione del file lock; non viene generato da un sistema GNU, ma può - risultare da un'operazione su un server NFS di un altro sistema. -\item \errcode{EFTYPE} \textit{Inappropriate file type or format}. Il file è di - tipo sbagliato rispetto all'operazione richiesta o un file di dati ha un - formato sbagliato. Alcuni sistemi restituiscono questo errore quando si - cerca di impostare lo \textit{sticky bit} su un file che non è una directory. -\end{description} - - +\item[\errcode{EROFS} \textit{Read-only file system}.] Si è cercato di + eseguire una operazione di scrittura su un file o una directory che risiede + su un filesystem montato un sola lettura. +\item[\errcode{ESPIPE} \textit{Invalid seek operation}.] Si cercato di + eseguire una \func{lseek} su un file che non supporta questa operazione (ad + esempio su una \textit{pipe}, da cui il nome). +\item[\errcode{ESTALE} \textit{Stale file handle}.] Indica un problema interno + ad un filesyste remoto (in genere con NFS) causato da cambiamenti del + filesystem del sistema remoto. Per recuperare questa condizione in genere è + necessario smontare e rimontare il filesystem. +\item[\errcode{ETXTBSY} \textit{Text file busy}.] Si è cercato di eseguire un + file che è aperto in scrittura, o di scrivere su un file che è in + esecuzione. +\item[\errcode{EUSERS} \textit{Too many users}.] Troppi utenti, il sistema delle + quote rileva troppi utenti nel sistema. +\item[\errcode{EXDEV} \textit{Cross-device link}.] Si è tentato di creare un + link diretto che attraversa due filesystem differenti. +\end{basedescript} \section{Gli errori dei processi} \label{sec:err_proc_errors} -In questa sezione sono raccolti i codici restituiti dalle funzioni di libreria +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{description} -\item \errcode{ESRCH} \textit{No process matches the specified process ID}. Non - esiste un processo con il \acr{pid} specificato. -\item \errcode{E2BIG} \textit{Argument list too long}. Lista degli argomenti - troppo lunga: è una condizione prevista da POSIX quando la lista degli - argomenti passata ad una delle funzioni \func{exec} occupa troppa memoria, - non può mai accadere in GNU/Linux. -\item \errcode{ECHILD} \textit{There are no child processes}. Non esiste un - processo figlio. Viene rilevato dalle funzioni per la gestione dei processi - figli. -%\item \errcode{EPROCLIM} \textit{}. Il limite dell'utente per nuovi processi -% sarà ecceduto alla prossima \func{fork}. (non credo esista in Linux) -\end{description} +\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 funzioni di libreria +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{description} -\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{EMSGSIZE} \textit{Message too long}. Le dimensioni di un +\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{EHOSTDOWN} \textit{Host is down}.] L'host remoto non risponde. +\item[\errcode{EHOSTUNREACH} \textit{No route to host}.] L'host remoto non è + raggiungibile. Si ottiene quando non esiste una rotta di rete per arrivare + all'host remoto con il protocollo di rete utilizzato. +\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{EPROTOTYPE} \textit{Protocol wrong type for socket}. Protocollo - sbagliato per il socket. Il socket usato non supporta il protocollo di - comunicazione richiesto. -\item \errcode{ENOPROTOOPT} \textit{Protocol not available}. Protocollo non - disponibile. Si è richiesta un'opzione per il socket non disponibile con il +\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{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{ESOCKTNOSUPPORT} \textit{Socket type not supported}. Socket non - supportato. Il tipo di socket scelto non è supportato. -\item \errcode{EOPNOTSUPP} \textit{Operation not supported on transport - endpoint}. L'operazione richiesta non è supportata. Alcune funzioni non +\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 è +\item[\errcode{EPFNOSUPPORT} \textit{Protocol family not supported}.] Famiglia + di protocolli non supportata. La famiglia di protocolli richiesta non è supportata. -\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{EADDRINUSE} \textit{Address already in use}. L'indirizzo del - socket richiesto è gia utilizzato (ad esempio si è richiesto il \func{bind} - per 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). -\item \errcode{ENETDOWN} \textit{Network is down}. L'operazione sul socket è - fallita perché la rete è sconnessa. -\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{ENETRESET} \textit{Network dropped connection because of reset}. - Una connessione è stata cancellata perché l'host remoto è caduto. -\item \errcode{ECONNABORTED} \textit{Software caused connection abort}. Una - connessione è stata abortita localmente. -\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{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{EISCONN} \textit{Transport endpoint is already connected}. Si è - tentato di connettere un socket che è gia connesso. -\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{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{ESHUTDOWN} \textit{Cannot send after transport endpoint - shutdown}. Il socket su cui si cerca di inviare dei dati ha avuto uno +\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{ETOOMANYREFS} \textit{Too many references: cannot splice}. La - glibc dice ??? -\item \errcode{ETIMEDOUT} \textit{Connection timed out}. Un'operazione sul +\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{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{EHOSTDOWN} \textit{Host is down}. L'host remoto di una - connessione è giù. -\item \errcode{EHOSTUNREACH} \textit{No route to host}. L'host remoto di una - connessione non è raggiungibile. -\end{description} +\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 funzioni di libreria +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{description} -\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. In questo - caso è necessario ripetere la chiamata alla funzione. -\item \errcode{ENOMEM} \textit{No memory available}. Il kernel non è in grado - di allocare ulteriore memoria per completare l'operazione richiesta. -\item \errcode{EDEADLK} \textit{Deadlock avoided}. L'allocazione di una - risorsa avrebbe causato un \textit{deadlock}\itindex{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 l'emissione di un segnale di \textit{segment violation} - (\const{SIGSEGV}). -\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{EDOM} \textit{Domain error}. È usato dalle funzioni matematiche - quando il valore di un argomento è al di fuori dell'intervallo in cui sono - definite. -\item \errcode{ERANGE} \textit{Range error}. È usato dalle funzioni matematiche - quando il risultato non è rappresentabile 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{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 + \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 + 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 è + \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 + 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}. In Linux è identico - a \errcode{EAGAIN}. -\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 +\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 + 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 è +\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{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{description} - - -\begin{description} -%\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{}. -%\item \errcode{ED} \textit{}. -%\item \errcode{EGREGIOUS} \textit{}. -%\item \errcode{EIEIO} \textit{}. -%\item \errcode{EGRATUITOUS} \textit{}. -\item \errcode{EBADMSG} \textit{Not a data message}. -\item \errcode{EIDRM} \textit{Identifier removed}. Indica che l'oggetto del - \textit{SysV IPC} cui si fa riferimento è stato cancellato. -\item \errcode{EMULTIHOP} \textit{Multihop attempted}. -\item \errcode{ENODATA} \textit{No data available}. -\item \errcode{ENOLINK} \textit{Link has been severed}. -\item \errcode{ENOMSG} \textit{No message of desired type}. -\item \errcode{ENOSR} \textit{Out of streams resources}. -\item \errcode{ENOSTR} \textit{Device not a stream}. -\item \errcode{EOVERFLOW} \textit{Value too large for defined data type}. -\item \errcode{EPROTO} \textit{Protocol error}. -\item \errcode{ETIME} \textit{Timer expired}. -\end{description} - - - - - -\section{Errori del kernel} -\label{sec:err_kernel_err} - -In questa sezione sono raccolti i codici di errore interni del kernel. Non -sono usati dalle funzioni di libreria, ma vengono riportati da alcune system -call (TODO verificare i dettagli, eventualmente cassare). - -\begin{description} -\item \errcode{ERESTART} \textit{Interrupted system call should be restarted}. -\item \errcode{ECHRNG} \textit{Channel number out of range}. -\item \errcode{EL2NSYNC} \textit{Level 2 not synchronized}. -\item \errcode{EL3HLT} \textit{Level 3 halted}. -\item \errcode{EL3RST} \textit{Level 3 reset}. -\item \errcode{ELNRNG} \textit{Link number out of range}. -\item \errcode{EUNATCH} \textit{Protocol driver not attached}. -\item \errcode{ENOCSI} \textit{No CSI structure available}. -\item \errcode{EL2HLT} \textit{Level 2 halted}. -\item \errcode{EBADE} \textit{Invalid exchange}. -\item \errcode{EBADR} \textit{Invalid request descriptor}. -\item \errcode{EXFULL} \textit{Exchange full}. -\item \errcode{ENOANO} \textit{No anode}. -\item \errcode{EBADRQC} \textit{Invalid request code}. -\item \errcode{EBADSLT} \textit{Invalid slot}. -\item \errcode{EDEADLOCK} Identico a \errcode{EDEADLK}. -\item \errcode{EBFONT} \textit{Bad font file format}. -\item \errcode{ENONET} \textit{Machine is not on the network}. -\item \errcode{ENOPKG} \textit{Package not installed}. -\item \errcode{EADV} \textit{Advertise error}. -\item \errcode{ESRMNT} \textit{Srmount error}. -\item \errcode{ECOMM} \textit{Communication error on send}. -\item \errcode{EDOTDOT} \textit{RFS specific error}. -\item \errcode{ENOTUNIQ} \textit{Name not unique on network}. -\item \errcode{EBADFD} \textit{File descriptor in bad state}. -\item \errcode{EREMCHG} \textit{Remote address changed}. -\item \errcode{ELIBACC} \textit{Can not access a needed shared library}. -\item \errcode{ELIBBAD} \textit{Accessing a corrupted shared library}. -\item \errcode{ELIBSCN} \textit{.lib section in a.out corrupted}. -\item \errcode{ELIBMAX} \textit{Attempting to link in too many shared - libraries}. -\item \errcode{ELIBEXEC} \textit{Cannot exec a shared library directly}. -\item \errcode{ESTRPIPE} \textit{Streams pipe error}. -\item \errcode{EUCLEAN} \textit{Structure needs cleaning}. -\item \errcode{ENAVAIL} \textit{No XENIX semaphores available}. -\item \errcode{EISNAM} \textit{Is a named type file}. -\item \errcode{EREMOTEIO} \textit{Remote I/O error}. -\item \errcode{ENOMEDIUM} \textit{No medium found}. -\item \errcode{EMEDIUMTYPE} \textit{Wrong medium type}. -\end{description} + 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} + +% In questa sezione sono raccolti i codici di errore interni del kernel. Non +% sono usati dalle funzioni di libreria, ma vengono riportati da alcune system +% call +% TODO verificare i dettagli degli errori del kernel, eventualmente cassare. + +% \begin{description} + +% \item[\errcode{ECHRNG} \textit{Channel number out of range}.] +% \item[\errcode{EL2NSYNC} \textit{Level 2 not synchronized}.] +% \item[\errcode{EL3HLT} \textit{Level 3 halted}.] +% \item[\errcode{EL3RST} \textit{Level 3 reset}.] +% \item[\errcode{ELNRNG} \textit{Link number out of range}.] +% \item[\errcode{EUNATCH} \textit{Protocol driver not attached}.] +% \item[\errcode{ENOCSI} \textit{No CSI structure available}.] +% \item[\errcode{EL2HLT} \textit{Level 2 halted}.] +% \item[\errcode{EBADE} \textit{Invalid exchange}.] +% \item[\errcode{EBADR} \textit{Invalid request descriptor}.] +% \item[\errcode{EXFULL} \textit{Exchange full}.] +% \item[\errcode{ENOANO} \textit{No anode}.] +% \item[\errcode{EBADRQC} \textit{Invalid request code}.] +% \item[\errcode{EBADSLT} \textit{Invalid slot}.] +% \item[\errcode{EDEADLOCK} Identico a \errcode{EDEADLK}.] + +% \item[\errcode{EBFONT} \textit{Bad font file format}.] +% \item[\errcode{ENONET} \textit{Machine is not on the network}.] +% \item[\errcode{ENOPKG} \textit{Package not installed}.] +% \item[\errcode{EREMOTEIO} \textit{Remote I/O error}.] si ottiene sul bus i2c +% se non si ottiene un acknoweledgment della comunicazione con un +% corrispondente su bus +% \item[\errcode{EADV} \textit{Advertise error}.] errore presumibilmente +% obsoleto, relativo a RFS +% (\url{https://en.wikipedia.org/wiki/Remote_File_Sharing}) interfaccia per +% filesystem remoti basta sugli stream SysV, non presente su Linux. +% \item[\errcode{ESRMNT} \textit{Srmount error}.] errore +% obsoleto, relativo a RFS +% (\url{https://en.wikipedia.org/wiki/Remote_File_Sharing}) interfaccia per +% filesystem remoti basta sugli stream SysV, non presente su Linux. +% \item[\errcode{ECOMM} \textit{Communication error on send}.] +% \item[\errcode{EDOTDOT} \textit{RFS specific error}.] +% \item[\errcode{ENOTUNIQ} \textit{Name not unique on network}.] +% \item[\errcode{EBADFD} \textit{File descriptor in bad state}.] +% \item[\errcode{EREMCHG} \textit{Remote address changed}.] +% \item[\errcode{ELIBACC} \textit{Can not access a needed shared library}.] +% \item[\errcode{ELIBBAD} \textit{Accessing a corrupted shared library}.] +% \item[\errcode{ELIBSCN} \textit{.lib section in a.out corrupted}.] +% \item[\errcode{ELIBMAX} \textit{Attempting to link in too many shared +% libraries}.] +% \item[\errcode{ELIBEXEC} \textit{Cannot exec a shared library directly}.] +% \item[\errcode{ERESTART} \textit{Interrupted system call should be +% restarted}.] +% \item[\errcode{ESTRPIPE} \textit{Streams pipe error}.] +% \item[\errcode{EUCLEAN} \textit{Structure needs cleaning}.] +% \item[\errcode{ENOTNAM} \textit{Not a XENIX named type file}.] +% \item[\errcode{ENAVAIL} \textit{No XENIX semaphores available}.] +% \item[\errcode{EISNAM} \textit{Is a named type file}.] +% \item[\errcode{EREMOTEIO} \textit{Remote I/O error}.] +% \item[\errcode{ENOMEDIUM} \textit{No medium found}.] +% \item[\errcode{EMEDIUMTYPE} \textit{Wrong medium type}.] +% \item[\errcode{ENOKEY} \textit{Required key not available}.] +% \item[\errcode{EKEYEXPIRED} \textit{Key has expired}.] +% \item[\errcode{EKEYREVOKED} \textit{Key has been revoked}.] +% \item[\errcode{EKEYREJECTED} \textit{Key was rejected by service}.] +%/* for robust mutexes */ +% \item[\errcode{EOWNERDEAD} \textit{Owner died}.] +% \item[\errcode{ENOTRECOVERABLE} \textit{State not recoverable}.] +% \item[\errcode{ERFKILL} \textit{Operation not possible due to RF-kill}.] +% \item[\errcode{EHWPOISON} \textit{Memory page has hardware error}.] + +% \end{description} + +% LocalWords: header errno perror int strerror sez EPERM Operation not ENOENT +% LocalWords: permitted such pathname EIO error ENXIO device address kernel Is +% LocalWords: ENOEXEC Invalid executable format exec EBADF Bad descriptor Too +% LocalWords: EACCES Permission denied ELOOP many symbolic links encountered +% LocalWords: ENAMETOOLONG name too long ENOTBLK Block required block EEXIST +% LocalWords: exists EBUSY Resource busy filesystem EXDEV ENODEV ENOTDIR files +% LocalWords: EISDIR EMFILE ulimit ENFILE table overflow ENOTTY ETXTBSY Text +% LocalWords: EFBIG big ENOSPC left ESPIPE seek operation EROFS Read only read +% LocalWords: system EMLINK EPIPE Broken SIGPIPE ENOTEMPTY empty EUSERS users +% LocalWords: EDQUOT exceeded ESTALE NFS handle EREMOTE Object is ENOLCK locks +% LocalWords: available locking EFTYPE type sticky ESRCH process matches the +% LocalWords: specified pid Argument list POSIX ECHILD There child processes +% LocalWords: socket ENOTSOCK EMSGSIZE Message EPROTOTYPE Protocol wrong for +% LocalWords: ENOPROTOOPT EPROTONOSUPPORT supported ESOCKTNOSUPPORT EOPNOTSUPP +% LocalWords: transport endpoint EPFNOSUPPORT family EAFNOSUPPORT protocol of +% LocalWords: EADDRINUSE already bind EADDRNOTAVAIL Cannot assign requested to +% LocalWords: ENETDOWN ENETUNREACH unreachable ENETRESET dropped connection +% LocalWords: because reset l'host ECONNABORTED caused abort ECONNRESET peer +% LocalWords: dell'host ENOBUFS ENOMEM EISCONN connected ENOTCONN UDP send now +% LocalWords: EDESTADDRREQ Destination ESHUTDOWN after shutdown ETOOMANYREFS +% LocalWords: references cannot splice glibc ETIMEDOUT timed ECONNREFUSED host +% LocalWords: refused EHOSTDOWN EHOSTUNREACH route EINTR Interrupted function +% LocalWords: call memory EDEADLK Deadlock avoided deadlock EFAULT segment IPC +% LocalWords: violation SIGSEGV EINVAL argument EDOM Domain ERANGE underflow +% LocalWords: EAGAIN temporarily unavailable EWOULDBLOCK select fork would has +% LocalWords: EINPROGRESS progress connect EALREADY ENOSYS implemented ENOTSUP +% LocalWords: EILSEQ Illegal sequence EBADMSG message EIDRM Identifier removed +% LocalWords: SysV EMULTIHOP Multihop attempted ENODATA ENOLINK been severed +% LocalWords: ENOMSG desired ENOSR streams resources ENOSTR stream EOVERFLOW +% LocalWords: Value large defined STAT EPROTO ETIME Timer expired group wait +% LocalWords: waitpid Specification cap USB did respond Stale %%% Local Variables: